相关推荐recommended
在 Docker 中配置 MySQL 数据库并初始化 Project 项目
作者:mmseoamin日期:2024-01-19

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 项目的过程。确保您了解每个步骤的含义,并根据实际情况进行适当的调整。希望这篇博客对您有所帮助!