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