首頁  >  文章  >  資料庫  >  Docker部署mysql服務的方法是什麼

Docker部署mysql服務的方法是什麼

WBOY
WBOY轉載
2023-05-26 22:56:041322瀏覽

第零步:從docker hub拉取官方mysql映像

#docker pull mysql

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

第一步:使用docker images指令查看映像

Docker部署mysql服務的方法是什麼

#你會看到我們這裡已經有了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 psDocker部署mysql服務的方法是什麼

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

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

不不不。我們可以使用docker inspect -f ='{{。 networksettings.ipaddress}}'5fef288f221f指令查看容器的ip,注意最後直接寫要查看的容器的id即可,網上那些人壞得很,還給你加一個,導致你很鬱悶,就照我這樣準沒錯

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

進入mysql容器:使用的docker exec命令,-it是參數,bash表示創建一個交互界面

Docker部署mysql服務的方法是什麼

登入mysql伺服器:使用的root使用者登入mysql,在輸入密碼之後,我們可以看到已經進去了mysql

Docker部署mysql服務的方法是什麼

使用show資料庫; 指令查看資料庫(注意不要忘了最後的分號中,mysql的指令都要有分號)

Docker部署mysql服務的方法是什麼

可以看到,我們的資料庫都列了出來,然後使用mysql; 指令進入mysql的這個資料庫(是不是很繞口,哈哈哈,這裡的mysql的資料庫是指的這一個資料庫,好吧我可能還是沒說明白)

然後使用show tables; 指令列出所有的表格

Docker部署mysql服務的方法是什麼

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

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

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

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

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

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

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

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

測試遠端連接

Docker部署mysql服務的方法是什麼

第四步:向我們的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服務的方法是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:yisu.com。如有侵權,請聯絡admin@php.cn刪除