基於 Docker18.09.0
以下示例均以
Mysql
社區版爲例
獲取官方 Dockerfile
下載MySQL Community Edition映像
docker pull mysql/mysql-server:tag
tag 可以是:
5.5, 5.6,5.7, 8.0,或latest
如果省略,就是會是當前最新版本
-
查看當前拉取到本地的鏡像
啓動MySQL服務器實例
- 運行容器
docker run -d --name=mysql571 mysql/mysql-server:5.7
-d
後臺運行此容器
--name
給這個容器起一個名字
執行以上命令後,容器會進行Mysql
的初始化操作,可以使用docker logs mysql571
進行觀察。
- 獲取初始化後的
root
密碼
初始化完成後,容器的命令的輸出將包含爲root用戶生成的隨機密碼; 例如,使用以下命令檢查密碼:
shell> docker logs mysql571 2>&1 | grep GENERATED
輸出:
[Entrypoint] GENERATED ROOT PASSWORD:3n[UbgOMVyrEb3bUbaJ.IPeJ=Ym
紅色字體部分就是密碼了
- 連接到容器中的
Mysql
終端
docker exec -it mysql571 mysql -uroot -p
- 重置密碼
因爲MYSQL_ONETIME_PASSWORD
默認情況下該 選項爲true,所以在將mysql客戶端連接 到服務器之後,必須通過發出以下語句來重置服務器root
密碼
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '自己設置的密碼';
- 正常關閉
Mysql
容器
docker stop mysql571
- 再次啓動剛纔關閉的容器
docker start mysql571
- 重啓容器
docker restart mysql571
- 啓動容器時,給
Mysql
添加配置參數
- 設置字符集和排序規則
docker run --name mysql571 -d mysql/mysql-server:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_general_ci
持久化 Mysql
的數據
docker run --name=mysql571 \
--mount type=bind,src=/docker/mysql57/conf/my.cnf,dst=/etc/my.cnf \
--mount type=bind,src=/docker/mysql57/data,dst=/var/lib/mysql \
-d mysql/mysql-server:5.7
/docker/mysql57/conf/my.cnf
是本地已經創建好的配置文件
/docker/mysql57/data
是本地已經創建好的目錄,用於保存Mysql
的數據
注意,假如第一次啓動Mysql
容器,此目錄必須爲空。
假如,在進行初始化的時候,還需要運行其他初始化腳本,進行如下映射
--mount type=bind,src=/docker/mysql57/scripts/,dst=/docker-entrypoint-initdb.d/
從其他容器連接到這個 Mysql
容器中
可能在另外的容器中的應用程序需要連接到一個 Mysql
容器中,這時就需要藉助 Docker
網絡
- 創建一個
Docker
網絡
docker network create mysql57-net
- 啓動一個
Mysql
容器時指定這個網絡
docker run --name=mysql571 --network=mysql57-net -d mysql/mysql-server
- 啓動一個自己的應用容器時,也指定這個網絡
docker run --name=myapp1 --network=mysql57-net -d myapp
- 測試
--name
指的的名稱即是容器的名稱,也同時是容器的主機名,這個主機名 Docker
會爲其進行 DNS
解析,所以連在一個網絡的容器可以使用彼此的主機名進行通信。
下面就是我們在一個應用的容器內使用 Mysql
的客戶端,並利用 Mysql
的主機名進行連接到 Mysql
服務端的示例
首先在服務端進行授權
進入服務器容器
執行授權命令
mysql> grant all on *.* to 'root'@'172.%' identified by 'QFedu123';
下面我創建一個 Mysql
客戶端
- 編寫客戶端
Dockerfile
FROM alpine
RUN apk add --no-cache mysql-client
ENTRYPOINT ["mysql"]
- 構建
docker build -t mysqlclient:v1.1 .
- 使用
docker run -it --name=mysqlclient --networl=mysql57-net -h mysql571 -uroot -p'QFedu123'