文章主要介紹了Docker中部署mysql服務的方法及遇到的坑,本文是小編細心給大家收藏整理下來的,非常不錯,具有一定的參考借鑑價值,需要的朋友可以參考下
最近一直在學習搬運工,感覺這麼厲害的東西怎麼以前不知道呢,把自己搗鼓的過程整理記錄下來,供同學們參考
第零步:從Docker Hub拉取官方mysql映象
docker pull mysql
然後就是進入漫長的等待,當然如果你配置了映象加速器,速度會快那麼一丟丟
第一步:使用docker images命令檢視映象
你會看到我們這裡已經有了MySQL的的映象
第二步:啟動我們的mysql的映象,建立一個MySQL的容器
使用命令:
docker run -d --name mysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql
解釋一下這裡的引數:
-d表示在後臺執行,不隨當前命令列視窗的退出而退出
--name給容器起一個別名,以後可以透過這個別名管理此容器
-p 3307:3307把宿主機的3307埠對映到Mysql容器的3306埠
-e MySQL容器的環境配置
MYSQL_ROOT_PASSWORD=123456
指定mysql的密碼,使用者名稱預設為root,注意如果沒有指定密碼,會啟動失敗
第三步:檢視我們已經啟動的mysql容器
使用命令:docker ps
可以看到,我們的MySQL的的的的容器已經跑起來了,dockeer給mysql的的的的容器分配了一個容器的編號,便於我們管理,還顯示我們設定的埠對映情況
這個時候有的老哥可能會想,雖然MySQL的的的的容器歡快的跑起來了,但是你丫只告訴我們埠,我們怎麼知道它的IP呢,我信你個鬼你的老頭子壞得很。
不不不。我們可以使用docker inspect -f ='{{。NetworkSettings.IPAddress}}'5fef288f221f命令檢視容器的ip,注意最後直接寫要檢視的容器的id即可,網上那些人壞得很,還給你加一個<>,導致你很鬱悶,就照我這樣準沒錯
還有一點需要注意的是:要是想在外部連線我們的Mysql容器,進行遠端管理的話,需要配置容器裡mysql的root賬戶的主機,把它改成一個萬用字元%,就可以讓任意主機連線我們的MySQL的了,具體方法如下:
進入MySQl容器:使用的docker exec命令,-it是引數,bash表示建立一個互動介面
登入mysql伺服器:使用的root使用者登入mysql,在輸入密碼之後,我們可以看到已經進去了mysql
使用show資料庫; 命令檢視資料庫(注意不要忘了最後的分號中,MySQL的命令都要有分號)
可以看到,我們的資料庫都列了出來,然後使用mysql; 命令進入MySQL的這個資料庫(是不是很繞口,哈哈哈,這裡的MySQL的資料庫是指的這一個資料庫,好吧我可能還是沒說明白)
然後使用show tables; 命令列出所有的表
可以看到,有好多個表,這都是MySQL的的配置,不用去關注,我們只需要修改一個使用者表即可
使用sql命令:
update user set host ='%'where user ='root';
這個命令有的同學可能會報錯,原因是你的MySQL的可能有多個根使用者,所以要用下面的命令
update
user
set
host =
'%'
其中
user
=
'root'
和host =
'localhost'
;
配置完上面的步驟可以測試一下連線,如果能夠連線上,恭喜你,你很幸運。
如果連不上,也要恭喜你,因為你下的mysql映象是mysql8的,
你可能會遇見下面這個錯誤
至此,配置完成,使用退出; 命令退出即可。
測試遠端連線
第四步:向我們的MySQL的容器匯入資料
雖然我們的Mysql的的的的容器跑起來了,但是這裡面沒資料啊,可以透過以下方法向docker中的MySQL匯入資料庫
先將檔案匯入到容器,cp後面是你準備匯入的sql檔案路徑
#docker cp **.sql mysql:/root/
進入容器
#docker exec -it mysql bash
將檔案匯入資料庫
# mysql -uroot -p 【資料庫名】 < ***.sql
mysql -h localhost -u root -p(進入mysql下面)
create database abc;(建立資料庫)
show databases;(就可看到所有已經存在的資料庫,以及剛剛建立的資料庫abc)
use abc;(進入abc資料庫下面)
show tables;(產看abc資料庫下面的所有表,空的)
source
/var/test
.sql(匯入資料庫表)
show tables;(檢視abc資料庫下面的所有表,就可以看到表了)
desc pollution;(檢視錶結構設計)
select
* from pollution;
exit
(或者ctrl + c)退出mysql
總結
以上所述是小編給大家介紹的Docker中部署mysql服務的方法,希望對大家有所幫助。