Docker设置MySQL数据库环境
大家好,我正在安装一台新的WordPress扩展底座机器,我正在配置我的SQL数据库:
db:
build:
context: ./Docker/mysql
dockerfile: Dockerfile
container_name: mysql
volumes:
- db_data:/var/lib/mysql
environment:
MYSQL_ROOT_PASSWORD: "${DB_ROOT_PASSWORD}"
MYSQL_DATABASE: "${DB_NAME}"
MYSQL_USER: "${DB_USERNAME}"
MYSQL_PASSWORD: "${DB_PASSWORD}"
networks:
- back
SQL文档文件:
FROM mysql:latest
这也很好用,问题是我真的不知道应该在哪里设置环境道具,如数据库名称、用户等等。有什么建议吗?
解决方案
您可以将其设置为服务器上的环境变量,但如果您不想这样做,则可以为Compose命令设置它们:
DB_ROOT_PASSWORD=asdf DB_NAME=mydb DB_USERNAME=user DB_PASSWORD=pw docker compose
在注释中,您说要在Dockerfile中设置var。下面是一个示例:
FROM mysql:latest
ENV MYSQL_ROOT_PASSWORD=asdf
ENV MYSQL_DATABASE=mydb
ENV MYSQL_USER=user
ENV MYSQL_PASSWORD=pw
如果您不希望在Docker文件中硬编码这些参数,则可以将它们与生成时参数组合在一起。
FROM mysql:latest
ENV MYSQL_ROOT_PASSWORD=$db_root_pw
ENV MYSQL_DATABASE=$db_name
ENV MYSQL_USER=$db_username
ENV MYSQL_PASSWORD=$db_pw
确保在构建映像时包含参数:
docker build --build-arg db_root_pw=rootpw --build-arg db_name=mydb --build-arg db_username=user --build-arg db_pw=pw # [...]
相关文章