主頁 > 知識庫 > Docker中部署mysql服務的方法及遇到的坑

Docker中部署mysql服務的方法及遇到的坑

熱門標簽:外呼系統(tǒng)不彈窗 外呼系統(tǒng)的經(jīng)營范圍 柳州市機器人外呼系統(tǒng)報價 智能電話機器人坐席 申請400電話價格多少 廈門營銷外呼系統(tǒng)平臺 安陽ai電銷機器人軟件 云會外呼系統(tǒng) 涪陵商都400電話開通辦理

最近一直在學習搬運工,感覺這么厲害的東西怎么以前不知道呢,把自己搗鼓的過程整理記錄下來,供同學們參考

第零步:從Docker Hub拉取官方mysql鏡像

docker pull mysql

然后就是進入漫長的等待,當然如果你配置了鏡像加速器,速度會快那么一丟丟

第一步:使用docker images命令查看鏡像

你會看到我們這里已經(jīng)有了MySQL的的鏡像

第二步:啟動我們的mysql的鏡像,創(chuàng)建一個MySQL的容器

使用命令:docker run -d --name mysql -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql

解釋一下這里的參數(shù):

-d表示在后臺運行,不隨當前命令行窗口的退出而退出

--name給容器起一個別名,以后可以通過這個別名管理此容器

-p 3307:3307把宿主機的3307端口映射到Mysql容器的3306端口

-e MySQL容器的環(huán)境配置

MYSQL_ROOT_PASSWORD=123456   指定mysql的密碼,用戶名默認為root,注意如果沒有指定密碼,會啟動失敗

第三步:查看我們已經(jīng)啟動的mysql容器

使用命令:docker ps

可以看到,我們的MySQL的的的的容器已經(jīng)跑起來了,dockeer給mysql的的的的容器分配了一個容器的編號,便于我們管理,還顯示我們設置的端口映射情況

這個時候有的老哥可能會想,雖然MySQL的的的的容器歡快的跑起來了,但是你丫只告訴我們端口,我們怎么知道它的IP呢,我信你個鬼你的老頭子壞得很。

不不不。我們可以使用docker inspect -f ='{{。NetworkSettings.IPAddress}}'5fef288f221f命令查看容器的ip,注意最后直接寫要查看的容器的id即可,網(wǎng)上那些人壞得很,還給你加一個<>,導致你很郁悶,就照我這樣準沒錯

還有一點需要注意的是:要是想在外部連接我們的Mysql容器,進行遠程管理的話,需要配置容器里mysql的root賬戶的主機,把它改成一個通配符%,就可以讓任意主機連接我們的MySQL的了,具體方法如下:

進入MySQl容器:使用的docker exec命令,-it是參數(shù),bash表示創(chuàng)建一個交互界面

登錄mysql服務器:使用的root用戶登錄mysql,在輸入密碼之后,我們可以看到已經(jīng)進去了mysql

使用show數(shù)據(jù)庫; 命令查看數(shù)據(jù)庫(注意不要忘了最后的分號中,MySQL的命令都要有分號)

可以看到,我們的數(shù)據(jù)庫都列了出來,然后使用mysql; 命令進入MySQL的這個數(shù)據(jù)庫(是不是很繞口,哈哈哈,這里的MySQL的數(shù)據(jù)庫是指的這一個數(shù)據(jù)庫,好吧我可能還是沒說明白)

然后使用show tables; 命令列出所有的表

可以看到,有好多個表,這都是MySQL的的配置,不用去關注,我們只需要修改一個用戶表即可

使用sql命令:update user set host ='%'where user ='root';

這個命令有的同學可能會報錯,原因是你的MySQL的可能有多個根用戶,所以要用下面的命令

update user set host ='%'其中user ='root'和host ='localhost';

配置完上面的步驟可以測試一下連接,如果能夠連接上,恭喜你,你很幸運。

如果連不上,也要恭喜你,因為你下的mysql鏡像是mysql8的,

你可能會遇見下面這個錯誤

至此,配置完成,使用退出; 命令退出即可。

測試遠程連接

第四步:向我們的MySQL的容器導入數(shù)據(jù)

雖然我們的Mysql的的的的容器跑起來了,但是這里面沒數(shù)據(jù)啊,可以通過以下方法向docker中的MySQL導入數(shù)據(jù)庫

先將文件導入到容器,cp后面是你準備導入的sql文件路徑

#docker cp **.sql mysql:/root/
進入容器
#docker exec -it mysql bash
將文件導入數(shù)據(jù)庫
# mysql -uroot -p 【數(shù)據(jù)庫名】 < ***.sql

mysql -h localhost -u root -p(進入mysql下面)
create database abc;(創(chuàng)建數(shù)據(jù)庫)
show databases;(就可看到所有已經(jīng)存在的數(shù)據(jù)庫,以及剛剛創(chuàng)建的數(shù)據(jù)庫abc)
use abc;(進入abc數(shù)據(jù)庫下面)
show tables;(產(chǎn)看abc數(shù)據(jù)庫下面的所有表,空的)
source /var/test.sql(導入數(shù)據(jù)庫表)
show tables;(查看abc數(shù)據(jù)庫下面的所有表,就可以看到表了)
desc pollution;(查看表結構設計)
select * from pollution;
exit(或者ctrl + c)退出mysql

總結

以上所述是小編給大家介紹的Docker中部署mysql服務的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

標簽:蕪湖 南充 孝感 晉城 撫順 綏化 巴中 福州

巨人網(wǎng)絡通訊聲明:本文標題《Docker中部署mysql服務的方法及遇到的坑》,本文關鍵詞  Docker,中,部署,mysql,服務,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Docker中部署mysql服務的方法及遇到的坑》相關的同類信息!
  • 本頁收集關于Docker中部署mysql服務的方法及遇到的坑的相關信息資訊供網(wǎng)民參考!
  • 企业400电话

    智能AI客服机器人
    15000

    在线订购

    合计11份范本:公司章程+合伙协议+出资协议+合作协议+股权转让协议+增资扩股协议+股权激励+股东会决议+董事会决议

    推薦文章