本文介紹了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數據庫環境的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,