当前位置: 首页 > news >正文

在 Docker 中配置 MySQL 数据库并初始化 Project 项目

1. 文件准备
1.1. 添加 SQL 文件头部内容
每个 SQL 文件的头部需要添加以下内容:

DROP DATABASE IF EXISTS xx_..;
CREATE DATABASE xx_..;
USE xx_..;

1.2. 修改 AUTO_INCREMENT
在每个 SQL 文件中,将 AUTO_INCREMENT 修改为 1。

1.3. 插入机型
在 SQL 文件中插入机型相关数据。

1.4. 插入管理员
在 SQL 文件中插入管理员相关数据。

1.5. 创建目录结构
创建目录 /project/mysql 以及 /project/mysql_data。

1.6. 拷贝 SQL 文件
将准备好的 SQL 文件复制到 /project/mysql 目录。

1.7. 创建 init.sql
新建 init.sql 文件,内容如下:

-- 创建数据库
CREATE DATABASE IF NOT EXISTS xxproject;
USE xxproject;-- 导入其他 SQL 文件
SOURCE /docker-entrypoint-initdb.d/xx_user.sql;
SOURCE /docker-entrypoint-initdb.d/xx_meteorology.sql;
SOURCE /docker-entrypoint-initdb.d/xx_turbine.sql;
SOURCE /docker-entrypoint-initdb.d/xx_geography.sql;
SOURCE /docker-entrypoint-initdb.d/xx_project.sql;
SOURCE /docker-entrypoint-initdb.d/xx_comprehensive.sql;
SOURCE /docker-entrypoint-initdb.d/xx_optimize.sql;-- 授予用户权限
GRANT ALL PRIVILEGES ON *.* TO 'userx'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;

将 init.sql 放到 /project/mysql 目录。

2. 启动容器
使用以下命令启动 MySQL 容器:

docker run -d \
--name project_db \
--network project_net \
--ip 10.100.1.3 \
--restart always \
-e MYSQL_ROOT_PASSWORD=123456789 \
-e MYSQL_DATABASE=userxproject \
-e MYSQL_USER=userx \
-e MYSQL_PASSWORD=123456789 \
-v /project/mysql:/docker-entrypoint-initdb.d \
-v /project/mysql_data:/var/lib/mysql \
-v /etc/localtime:/etc/localtime:ro \
-p 9003:3306 \
mysql:latest

3. 查看容器
使用以下命令查看容器信息:

查看网络:

docker inspect -f '{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' project_db

登录 MySQL 容器(管理员):

docker exec -it project_db mysql -u root -p

登录 MySQL 容器(用户):

docker exec -it project_db mysql -h 10.100.1.3 -u userx -p

在 MySQL 容器中执行以下命令:

sql
Copy code
SHOW DATABASES;
USE xx_user;
SHOW TABLES;
SELECT * FROM user;

4. 重启数据库
若需要重启数据库,执行以下命令:

docker restart project_db

这样,您就完成了在 Docker 中配置 MySQL 数据库并初始化 Project 项目的过程。确保您了解每个步骤的含义,并根据实际情况进行适当的调整。希望这篇博客对您有所帮助!

http://www.lryc.cn/news/274531.html

相关文章:

  • 生活中的物理3——神奇陷阱(随机倒下的抽屉柜门)
  • 数模学习day08-拟合算法
  • 第13课 利用openCV检测物体是否运动了
  • C#之反编译之路(一)
  • 使用CentOS 7.6搭建HTTP隧道代理服务器
  • Swift爬虫使用代理IP采集唯品会商品详情
  • 高性价比LDR6028Type-C转3.5mm音频和PD快充转接器
  • 【Docker】docker 服务相关命令
  • 基于SpringBoot的在线问卷调查系统
  • 智能分析网关V4太阳能风光互补远程视频智能监控方案
  • 250:vue+openlayers 加载geotiff文件,并在地图上显示
  • 【JavaEE】多线程(7) -- 线程池的概念和简单实现
  • 集合基础知识点
  • 最新版付费进群系统源码 /同城定位付费进群源码 /自带定位完整版/后台分销站点
  • 【论文阅读笔记】医学多模态新数据集-Large-scale Long-tailed Disease Diagnosis on Radiology Images
  • (C语言)指针的进阶
  • 【网络面试(5)】收发数据及断开服务器(四次挥手)
  • 【Maven】下载及配置
  • 【方法】PPT设置密码后如何修改?
  • 第34期 | GPTSecurity周报
  • 2023新版edge浏览器页面加载不出来的解决办法
  • 算法基础之二分与前缀和 day 6
  • github短视频去除水印项目Douyin_TikTok_Download_API介绍
  • FindMy技术用于键盘
  • 认识jmeter接口测试工具!
  • 强大的按钮类CButtonST
  • 学习ing
  • linux下数据库定时备份
  • Qt/QML编程学习之心得:QSocketNotifier(二十一)
  • 【linux】lsblk和df -h显示的磁盘信息不同