使用 docker-compose 運行 MySQL的方法
目錄結(jié)構(gòu)
. │ .env │ docker-compose.yml │ └─mysql ├─config │ my.cnf │ └─data
mysql 目錄下的 data 為數(shù)據(jù)目錄,mysql 的數(shù)據(jù)表、二進制日志文件就在這里。.env 文件包含了一些變量,這些變量可以在 docker-compose.yml
文件中通過 ${variable_name}
來引用。
當然也可以把 mysql 的目錄放到其它地方,這里圖個方便,直接放在 yml 文件同級目錄了。
.env 文件
MYSQL_ROOT_PASSWORD=root MYSQL_ROOT_HOST=% MYSQL_DIR=./mysql
MySQL 配置文件 my.cnf
[mysqld] character-set-server=utf8mb4 default-time-zone='+8:00' innodb_rollback_on_timeout='ON' max_connections=500 innodb_lock_wait_timeout=500
如果使用默認配置,這個文件可以省略。
docker-compose.yml
version: '3' services: mysql-db: container_name: mysql-docker # 指定容器的名稱 image: mysql:8.0 # 指定鏡像和版本 ports: - "3306:3306" environment: MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD} MYSQL_ROOT_HOST: ${MYSQL_ROOT_HOST} volumes: - "${MYSQL_DIR}/data:/var/lib/mysql" # 掛載數(shù)據(jù)目錄 - "${MYSQL_DIR}/config:/etc/mysql/conf.d" # 掛載配置文件目錄
Environment 變量
- MYSQL_ROOT_PASSWORD :這個不用解釋,root 用戶的密碼。
- MYSQL_USER,MYSQL_PASSWORD :這兩個變量為可選,創(chuàng)建一個新用戶,這個用戶在 MYSQL_DATABASE 變量指定的數(shù)據(jù)庫上擁有超級用戶權(quán)限。
- MYSQL_DATABASE :指定一個數(shù)據(jù)庫,在容器啟動時創(chuàng)建。
- MYSQL_ALLOW_EMPTY_PASSWORD :設置為 yes 允許 root 用戶的密碼為空。(不推薦)
- MYSQL_RANDOM_ROOT_PASSWORD :設置為 yes 將在容器啟動時為 root 用戶生成一個隨機的密碼,密碼會顯示到標準輸出流(GENERATED ROOT PASSWORD:......)。
- MYSQL_ONETIME_PASSWORD :字面意思就是一次性密碼,為 root 用戶設置,第一次登錄后必須修改密碼(僅支持 5.6 以上的版本)。
運行容器
在 docker-compose.yml 目錄下執(zhí)行:
> docker-compose up
如果要在后臺運行,使用 docker-compose up -d
。
停止容器:
> docker-compose down
如果是前臺運行的,使用:Ctrl + C 停止。這兩種方式在停止后都會刪除容器,下次啟動必須使用 up 命令。
停止但不刪除容器:
> docker-compose stop
使用 stop 停止后,再次啟動使用 start 命令即可。
總結(jié)
以上所述是小編給大家介紹的使用 docker-compose 運行 MySQL的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
docker compose部署cassandra集群的操作代碼
這篇文章主要介紹了docker compose部署cassandra集群的操作代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2024-03-03docker安裝kong網(wǎng)關(guān)的方法示例
這篇文章主要介紹了docker安裝kong網(wǎng)關(guān)的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05SpringBoot打包docker鏡像發(fā)布的詳細步驟
這篇文章主要介紹了SpringBoot打包docker鏡像發(fā)布,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-04-04Docker構(gòu)建ELK Docker集群日志收集系統(tǒng)
為了在Docker集群中更好的管理查看日志 我們使用Docker 來搭建集群的ELK日志收集系統(tǒng),這篇文章介紹了Docker構(gòu)建ELK Docker集群日志收集系統(tǒng)的相關(guān)資料,需要的朋友可以參考下2016-11-11