-
准备SQL脚本
将SQL脚本(如
init.sql
)放在宿主机目录下,例如:/path/to/sql-scripts/init.sql
-
启动MySQL容器并挂载脚本
使用
-v
参数将SQL脚本挂载到容器的初始化目录:docker run --name mysql-container
-e MYSQL_ROOT_PASSWORD=your_password
-e MYSQL_DATABASE=your_db
-p port:3306 \ //将宿主机端口映射到容器内的3306端口
-v /path/to/sql-scripts:/docker-entrypoint-initdb.d/init.sql
-d mysql:tag
-
关键参数:
-
-v /path/to/sql-scripts:/docker-entrypoint-initdb.d
:将宿主机目录挂载到容器初始化目录(容器启动时会自动执行该目录下所有.sql
或.sh
文件)。 -
-e MYSQL_DATABASE=your_db
:可选,创建默认数据库。docker run --name mysql-db \ -e MYSQL_ROOT_PASSWORD=123456 \ -e MYSQL_DATABASE=myapp \ -p port:3306 \ //将宿主机端口映射到容器内的3306端口 -v ./sql-scripts:/docker-entrypoint-initdb.d/init.sql \ -d mysql:8.0
-