Docker设置MySQL数据库环境

  
本文介绍了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 # [...]

这篇关于Docker设置MySQL数据库环境的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

相关文章