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