Mysql5.7容器化

基於 Docker18.09.0


以下示例均以Mysql社區版爲例

獲取官方 Dockerfile

官方 github 地址

下載MySQL Community Edition映像

docker pull mysql/mysql-server:tag

tag 可以是: 5.5, 5.6,5.7, 8.0,或latest
如果省略,就是會是當前最新版本

  • 查看當前拉取到本地的鏡像


啓動MySQL服務器實例

  1. 運行容器
docker run -d --name=mysql571 mysql/mysql-server:5.7

-d 後臺運行此容器
--name 給這個容器起一個名字
執行以上命令後,容器會進行 Mysql 的初始化操作,可以使用 docker logs mysql571 進行觀察。

  1. 獲取初始化後的 root 密碼
    初始化完成後,容器的命令的輸出將包含爲root用戶生成的隨機密碼; 例如,使用以下命令檢查密碼:
shell> docker logs mysql571 2>&1 | grep GENERATED

輸出:
[Entrypoint] GENERATED ROOT PASSWORD: 3n[UbgOMVyrEb3bUbaJ.IPeJ=Ym
紅色字體部分就是密碼了

  1. 連接到容器中的 Mysql 終端
docker exec -it mysql571 mysql -uroot -p
  1. 重置密碼
    因爲 MYSQL_ONETIME_PASSWORD 默認情況下該 選項爲true,所以在將mysql客戶端連接 到服務器之後,必須通過發出以下語句來重置服務器 root 密碼
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '自己設置的密碼';
  1. 正常關閉 Mysql 容器
docker stop mysql571
  1. 再次啓動剛纔關閉的容器
docker start mysql571
  1. 重啓容器
docker restart mysql571
  1. 啓動容器時,給 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 網絡

  1. 創建一個 Docker 網絡
docker network create mysql57-net
  1. 啓動一個 Mysql 容器時指定這個網絡
docker run --name=mysql571 --network=mysql57-net -d mysql/mysql-server
  1. 啓動一個自己的應用容器時,也指定這個網絡
docker run --name=myapp1 --network=mysql57-net -d myapp
  1. 測試

--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'
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章