使用Docker安裝隙袁、運行mysql

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

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

1.安裝Docker

brew cask install docker

2. 獲取mysql鏡像

從docker hub的倉庫中拉去mysql鏡像
sudo docker pull mysql
查看鏡像:
docker images
2.運行一個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)建容器時,最后mysql:5.6表示mysql鏡像的版本遍坟,可以寫拳亿,表示指定該版本;如果不寫也可以愿伴,docker會自動在本地檢測有沒有最新的肺魁,如果沒有會自動去docker hub上去下載。

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

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

查看當前docker容器的運行狀態(tài):

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

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

mysql -h192.168.95.4 -p3306 -uroot -p123456
訪問本機的mysql

進入docker中mysql:

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

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

  • 端口映射唯一性:一個容器只能映射到本機的唯一一個端口蹦误,故如果創(chuàng)建了一個容器,該容器在運行中涌哲,該容器映射到本地的端口為3306胖缤, 那么就不能再創(chuàng)建一個容器映射在3306端口號上,因為該端口已經(jīng)被分配給了第一個容器阀圾。
  • 容器名字唯一性:創(chuàng)建的容器的名字不能與已經(jīng)存在 的容器名字重復(fù)哪廓。
    否則創(chuàng)建容器失敗。

刪除一個容器:

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

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

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

現(xiàn)在兩個容器(實例)都正常運行了涡真,為了訪問第二個容器,我們指定端口號3307登陸到這個mysql的client肾筐。

docker exec -it mysql bash // 想進入docker中哆料,這里的mysql表示鏡像的名字
mysql -h192.168.95.4 -P3307 -uroot -p123456  

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

mysql -h192.168.95.4 -p3306 -uroot -p123456
如果在同一個局域網(wǎng)下吗铐,別人是可以通過ip地址來訪問我的電腦的东亦,如果在別人的機器上這
里的-h后面寫上我本機的ip地址,以及我的mysql的端口號和密碼唬渗,那么他就可以訪問我電腦
上的數(shù)據(jù)庫mysql典阵,前提是在一個局域網(wǎng)下奋渔。

參考鏈接

在電腦上 docker 中運行 mysql 終極大法

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

劃重點~~~
啟動數(shù)據(jù)的方式有兩種:

  • 方法一:根據(jù)本機的mysql server 啟動數(shù)據(jù)庫
    首先啟動mysql server:
    //啟動服務(wù)圖片
    [圖片上傳失敗...(image-47c838-1555518820643)]
    啟動本機的mysql 也可以使用命令行啟動:
    sudo /usr/local/mysql/support-files/mysql.server start
    報如下錯誤:
    [圖片上傳失敗...(image-a78666-1555519504962)]
    說缺少一個pid 文件壮啊,但是去查看 /usr/local/mysql/dat 目錄嫉鲸,目的是想看 local.err文件中的錯誤詳情,發(fā)現(xiàn)根本看不到該目錄歹啼,那猜測肯定是權(quán)限問題
    chown -R mysql:mysql /usr/local/mysql/data
    chmod -R 755 /usr/local/mysql/data
    然后就有權(quán)限看到 data 目錄了
    然后進入/usr/local/mysql/data 去查看錯誤詳情:cat CNmmqiu.local.err
    發(fā)現(xiàn)其實是3306 端口占用玄渗,因為本地docker 啟動了3306端口的服務(wù),然后把docker 服務(wù)停掉,再重新啟動 mysql server.
    mysql server可以成功啟動狸眼,不會再報沒有pid 的錯誤了~

默認啟動在3306端口藤树,會占用本機的 3306 端口

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

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

然后使用 docker-compose up -d 啟動mysql, 啟動mysql container 是沒有問題

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

Note: 本機的mysql 和docker 中的mysql 不是共享的

期間踩了一些坑:
錯誤一:

  • 沒有mysql.sock 文件

    這個我解決方法是啟動一下本機的mysql server甜紫, 然后再啟動 docker mysql,就可以了

錯誤二:

  • 密碼錯誤

其實是因為我數(shù)據(jù)庫密碼輸入錯誤了骂远,所以報這個錯囚霸,重新輸入正確的密碼,就可以進入mysql 了激才。

缺點:
以上就創(chuàng)建了一個mysql的docker容器拓型,可以看到版本為5.7.21。但是這樣創(chuàng)建的容器有兩個問題瘸恼,一是容器刪除后劣挫,數(shù)據(jù)就丟失了,二是要訪問數(shù)據(jù)庫东帅,必須進入到容器里面才可以压固。
a、創(chuàng)建宿主機數(shù)據(jù)存放目錄
$ mkdir -p /opt/data/mysql

b靠闭、啟動容器
$ 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帐我、查看宿主機上的mysql數(shù)據(jù)庫


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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末拦键,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子檩淋,更是在濱河造成了極大的恐慌芬为,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,561評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異媚朦,居然都是意外死亡捡絮,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評論 3 385
  • 文/潘曉璐 我一進店門莲镣,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人涎拉,你說我怎么就攤上這事瑞侮。” “怎么了鼓拧?”我有些...
    開封第一講書人閱讀 157,162評論 0 348
  • 文/不壞的土叔 我叫張陵半火,是天一觀的道長。 經(jīng)常有香客問我季俩,道長钮糖,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,470評論 1 283
  • 正文 為了忘掉前任酌住,我火速辦了婚禮店归,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘酪我。我一直安慰自己消痛,他們只是感情好,可當我...
    茶點故事閱讀 65,550評論 6 385
  • 文/花漫 我一把揭開白布都哭。 她就那樣靜靜地躺著秩伞,像睡著了一般。 火紅的嫁衣襯著肌膚如雪欺矫。 梳的紋絲不亂的頭發(fā)上纱新,一...
    開封第一講書人閱讀 49,806評論 1 290
  • 那天,我揣著相機與錄音穆趴,去河邊找鬼脸爱。 笑死,一個胖子當著我的面吹牛毡代,可吹牛的內(nèi)容都是我干的阅羹。 我是一名探鬼主播,決...
    沈念sama閱讀 38,951評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼教寂,長吁一口氣:“原來是場噩夢啊……” “哼捏鱼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起酪耕,我...
    開封第一講書人閱讀 37,712評論 0 266
  • 序言:老撾萬榮一對情侶失蹤导梆,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體看尼,經(jīng)...
    沈念sama閱讀 44,166評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡递鹉,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,510評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了藏斩。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片躏结。...
    茶點故事閱讀 38,643評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖狰域,靈堂內(nèi)的尸體忽然破棺而出媳拴,到底是詐尸還是另有隱情,我是刑警寧澤兆览,帶...
    沈念sama閱讀 34,306評論 4 330
  • 正文 年R本政府宣布屈溉,位于F島的核電站,受9級特大地震影響抬探,放射性物質(zhì)發(fā)生泄漏子巾。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,930評論 3 313
  • 文/蒙蒙 一小压、第九天 我趴在偏房一處隱蔽的房頂上張望线梗。 院中可真熱鬧,春花似錦怠益、人聲如沸缠导。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,745評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽僻造。三九已至,卻和暖如春孩饼,著一層夾襖步出監(jiān)牢的瞬間髓削,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,983評論 1 266
  • 我被黑心中介騙來泰國打工镀娶, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留立膛,地道東北人。 一個月前我還...
    沈念sama閱讀 46,351評論 2 360
  • 正文 我出身青樓梯码,卻偏偏與公主長得像宝泵,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子轩娶,可洞房花燭夜當晚...
    茶點故事閱讀 43,509評論 2 348

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