使用Docker安裝、運(yùn)行mysql

Docker 和傳統(tǒng)虛擬化方式的不同之處,可見(jiàn)容器是在操作系統(tǒng)層面上實(shí)現(xiàn)虛擬化,直接復(fù)用本地主機(jī)的操作系統(tǒng),而傳統(tǒng)方式則是在硬件層面實(shí)現(xiàn)。

和虛擬機(jī)還是有區(qū)別的, 虛擬機(jī)相當(dāng)于又起了一套操作系統(tǒng),分配了內(nèi)存和CPU,這個(gè)本身的損耗就大很多。

1.安裝Docker

brew cask install docker

2. 獲取mysql鏡像

從docker hub的倉(cāng)庫(kù)中拉去mysql鏡像
sudo docker pull mysql
查看鏡像:
docker images
2.運(yùn)行一個(gè)mysql容器

 docker run -p 3306:3306 --name qmm-mysql -v ~/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=669988  -d mysql:5.6
//創(chuàng)建容器時(shí),最后mysql:5.6表示mysql鏡像的版本,可以寫,表示指定該版本;如果不寫也可以,docker會(huì)自動(dòng)在本地檢測(cè)有沒(méi)有最新的,如果沒(méi)有會(huì)自動(dòng)去docker hub上去下載。

上述命令各個(gè)參數(shù)的含義:

run                 運(yùn)行一個(gè)docker容器
--name           后面這個(gè)是生成的容器的名字qmm-mysql
-p 3306:3306  表示這個(gè)容器中使用3306(第二個(gè))映射到本機(jī)的端口號(hào)也為3306(第一個(gè)) 
-e MYSQL_ROOT_PASSWORD=123456  初始化root用戶的密碼
-d                   表示使用守護(hù)進(jìn)程運(yùn)行,即服務(wù)掛在后臺(tái)

查看當(dāng)前docker容器的運(yùn)行狀態(tài):

docker ps   : 查看運(yùn)行中的容器
或者docker ps -a : 查看所有創(chuàng)建的容器

如果想要訪問(wèn)mysql ,需要在本機(jī)上裝一個(gè)mysql-client。
本機(jī)裝好mysql后,可以使用mysql命令訪問(wèn)本機(jī)的mysql服務(wù)器,密碼就是上面創(chuàng)建容器時(shí)設(shè)置的密碼為123456, 192.168.95.4 為現(xiàn)在我這臺(tái)機(jī)器的ip, 3306為剛才所示的占用本物理機(jī)的端口(不是docker內(nèi)部的端口)

mysql -h192.168.95.4 -p3306 -uroot -p123456
訪問(wèn)本機(jī)的mysql

進(jìn)入docker中mysql:

$ docker exec -it mysql bash
$ mysql -u root -p
數(shù)據(jù)數(shù)據(jù)庫(kù)密碼就可以進(jìn)入docker中的mysql

創(chuàng)建容器注意事項(xiàng):

  • 端口映射唯一性:一個(gè)容器只能映射到本機(jī)的唯一一個(gè)端口,故如果創(chuàng)建了一個(gè)容器,該容器在運(yùn)行中,該容器映射到本地的端口為3306, 那么就不能再創(chuàng)建一個(gè)容器映射在3306端口號(hào)上,因?yàn)樵摱丝谝呀?jīng)被分配給了第一個(gè)容器。
  • 容器名字唯一性:創(chuàng)建的容器的名字不能與已經(jīng)存在 的容器名字重復(fù)。
    否則創(chuàng)建容器失敗。

刪除一個(gè)容器:

sudo docker rm 容器名字(如上容器名字就是:qmm-mysql)

重新再創(chuàng)建一個(gè)容器second-mysql,占用物理機(jī)的3307端口:

sudo docker run --name second-mysql -p 3307:3306 -e MYSQL\_ROOT\_PASSWORD=123456 -d mysql

現(xiàn)在兩個(gè)容器(實(shí)例)都正常運(yùn)行了,為了訪問(wèn)第二個(gè)容器,我們指定端口號(hào)3307登陸到這個(gè)mysql的client。

docker exec -it mysql bash // 想進(jìn)入docker中,這里的mysql表示鏡像的名字
mysql -h192.168.95.4 -P3307 -uroot -p123456  

還可以在別人的機(jī)器上訪問(wèn)我本機(jī)的mysql,這個(gè)就是-h參數(shù)的作用:
比如:

mysql -h192.168.95.4 -p3306 -uroot -p123456
如果在同一個(gè)局域網(wǎng)下,別人是可以通過(guò)ip地址來(lái)訪問(wèn)我的電腦的,如果在別人的機(jī)器上這
里的-h后面寫上我本機(jī)的ip地址,以及我的mysql的端口號(hào)和密碼,那么他就可以訪問(wèn)我電腦
上的數(shù)據(jù)庫(kù)mysql,前提是在一個(gè)局域網(wǎng)下。

參考鏈接

在電腦上 docker 中運(yùn)行 mysql 終極大法

這里默認(rèn)電腦上是已經(jīng)裝好了docker .
今天在電腦上docker 中啟動(dòng) mysql, 但是一路走了好多坑

劃重點(diǎn)~~~
啟動(dòng)數(shù)據(jù)的方式有兩種:

  • 方法一:根據(jù)本機(jī)的mysql server 啟動(dòng)數(shù)據(jù)庫(kù)
    首先啟動(dòng)mysql server:
    //啟動(dòng)服務(wù)圖片
    [圖片上傳失敗...(image-47c838-1555518820643)]
    啟動(dòng)本機(jī)的mysql 也可以使用命令行啟動(dòng):
    sudo /usr/local/mysql/support-files/mysql.server start
    報(bào)如下錯(cuò)誤:
    [圖片上傳失敗...(image-a78666-1555519504962)]
    說(shuō)缺少一個(gè)pid 文件,但是去查看 /usr/local/mysql/dat 目錄,目的是想看 local.err文件中的錯(cuò)誤詳情,發(fā)現(xiàn)根本看不到該目錄,那猜測(cè)肯定是權(quán)限問(wèn)題
    chown -R mysql:mysql /usr/local/mysql/data
    chmod -R 755 /usr/local/mysql/data
    然后就有權(quán)限看到 data 目錄了
    然后進(jìn)入/usr/local/mysql/data 去查看錯(cuò)誤詳情:cat CNmmqiu.local.err
    發(fā)現(xiàn)其實(shí)是3306 端口占用,因?yàn)楸镜豥ocker 啟動(dòng)了3306端口的服務(wù),然后把docker 服務(wù)停掉,再重新啟動(dòng) mysql server.
    mysql server可以成功啟動(dòng),不會(huì)再報(bào)沒(méi)有pid 的錯(cuò)誤了~

默認(rèn)啟動(dòng)在3306端口,會(huì)占用本機(jī)的 3306 端口

進(jìn)入mysql:
mysql -hlocalhost(這個(gè)是可選的) -uroot -p{數(shù)據(jù)庫(kù)密碼}
連接數(shù)據(jù)庫(kù):
如下

  • 方法二:在docker 中使用mysql 鏡像啟動(dòng)mysql 服務(wù)
    首先,第一步,寫一個(gè)docker-compose.yml:
version: '2'
services:
  mysql-database:
    image: mysql
    ports:
    - "3306:3306"
    restart: always
    environment:
      MYSQL_DATABASE: 數(shù)據(jù)庫(kù)名  // 這里docker 在啟動(dòng)的時(shí)候,會(huì)自動(dòng)創(chuàng)建該數(shù)據(jù)庫(kù),不需要手動(dòng)去創(chuàng)建
      MYSQL_USER: root
      MYSQL_ROOT_PASSWORD: 數(shù)據(jù)庫(kù)密碼

然后使用 docker-compose up -d 啟動(dòng)mysql, 啟動(dòng)mysql container 是沒(méi)有問(wèn)題

那該怎么進(jìn)去mysql, 去使用數(shù)據(jù)庫(kù)呢?
先進(jìn)入docker 容器中:
docker exec -it {container-id/container-name} bash
再連接mysql:
mysql -uroot -p{數(shù)據(jù)庫(kù)密碼}
連接數(shù)據(jù)庫(kù):
use 數(shù)據(jù)庫(kù)名 // 切換到數(shù)據(jù)庫(kù)
show databases; // 展示所有的數(shù)據(jù)庫(kù)
show tables; //展示所有表

Note: 本機(jī)的mysql 和docker 中的mysql 不是共享的

期間踩了一些坑:
錯(cuò)誤一:

  • 沒(méi)有mysql.sock 文件

    這個(gè)我解決方法是啟動(dòng)一下本機(jī)的mysql server, 然后再啟動(dòng) docker mysql,就可以了

錯(cuò)誤二:

  • 密碼錯(cuò)誤

其實(shí)是因?yàn)槲覕?shù)據(jù)庫(kù)密碼輸入錯(cuò)誤了,所以報(bào)這個(gè)錯(cuò),重新輸入正確的密碼,就可以進(jìn)入mysql 了。

缺點(diǎn):
以上就創(chuàng)建了一個(gè)mysql的docker容器,可以看到版本為5.7.21。但是這樣創(chuàng)建的容器有兩個(gè)問(wèn)題,一是容器刪除后,數(shù)據(jù)就丟失了,二是要訪問(wèn)數(shù)據(jù)庫(kù),必須進(jìn)入到容器里面才可以。
a、創(chuàng)建宿主機(jī)數(shù)據(jù)存放目錄
$ mkdir -p /opt/data/mysql

b、啟動(dòng)容器
$ docker run -d -v /opt/data/mysql/:/var/lib/mysql -p 3306:3306 --name liying-mysql -e MYSQL_ROOT_PASSWORD=attack docker.io/mysql

查看日志

$ docker logs mysql-container

d、查看宿主機(jī)上的mysql數(shù)據(jù)庫(kù)


-p 3306:3306 ->把容器的mysql端口3306映射到宿主機(jī)的3306端口,這樣想訪問(wèn)mysql就可以直接訪問(wèn)宿主機(jī)的3306端口。
-v /opt/data/mysql:/var/lib/mysql ->把宿主機(jī)/opt/data/mysql/目錄映射到容器的/var/lib/mysql目錄

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,732評(píng)論 6 539
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,214評(píng)論 3 426
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事?!?“怎么了?”我有些...
    開(kāi)封第一講書人閱讀 177,781評(píng)論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 63,588評(píng)論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,315評(píng)論 6 410
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 55,699評(píng)論 1 327
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,698評(píng)論 3 446
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 42,882評(píng)論 0 289
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,441評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,189評(píng)論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,388評(píng)論 1 372
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,933評(píng)論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,613評(píng)論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 35,023評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 36,310評(píng)論 1 293
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,112評(píng)論 3 398
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,334評(píng)論 2 377

推薦閱讀更多精彩內(nèi)容