您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“Docker中部署mysql服務的方法是什么”,內容詳細,步驟清晰,細節處理妥當,希望這篇“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服務的方法是什么”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。