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
進入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 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目錄