剛看別人使用Docker的時(shí)候有很多不解,為什么要用Docker,Docker怎么用?Docker配置為什么這么難?為什么網(wǎng)絡(luò)訪問(wèn)不通?等等因素阻礙了筆者學(xué)習(xí)Docker?其實(shí)筆者也很笨,有很多思考不清晰的點(diǎn)。順便也分享下。學(xué)時(shí)疑惑:
Q:我一套服務(wù)為什么不放在一個(gè)容器里面(Java、MySQL、Nginx、Redis等)?A:因?yàn)榧纫S護(hù)容器內(nèi)網(wǎng)絡(luò),又要維護(hù)端口等等之類(lèi)的東西,Docker就是為了快速搭建環(huán)境而生的,而且Docker最好也是一個(gè)服務(wù)一個(gè)容器,這樣好打理。
Q:Docker能放到生產(chǎn)環(huán)境嗎?A:在公司沒(méi)有專(zhuān)門(mén)的運(yùn)維團(tuán)隊(duì)情況下,不建議使用Docker部署的環(huán)境作為生產(chǎn)環(huán)境,因?yàn)椴粌H僅要維護(hù)項(xiàng)目和中間件,Docker或者Kubernetes出現(xiàn)問(wèn)題后,還要解決這些問(wèn)題,也就是還要解決Docker的問(wèn)題。如果在沒(méi)有專(zhuān)門(mén)運(yùn)維團(tuán)隊(duì)的情況下,最好使用某里云的服務(wù),例如RDS,SLB等,最起碼別人還會(huì)幫你維護(hù)你的數(shù)據(jù)庫(kù)和服務(wù)。
基本命令
下載鏡像# 以Redis為例子
docker pull redis
運(yùn)行鏡像docker run \
-d \ # 后臺(tái)運(yùn)行
--name redis6 \ # 自定義名字
-p 6379:6379 \ # 端口映射
redis # 鏡像名稱
docker run -d --name redis6 -p 6379:6379 redis redis-server --appendonly yes --requirepass "123456" # 完整命令
進(jìn)入容器
第一種(不推薦,當(dāng)退出容器使用exit命令時(shí),會(huì)停止這個(gè)容器):docker attach 容器id
第二種:docker exec -it 容器id /bin/bash
暫停容器docker stop 容器id
啟動(dòng)容器docker start 容器id
查詢?nèi)萜髁斜?/span>docker ps -a # 查看所有容器
docker ps # 查看運(yùn)行中的容器
-
run是創(chuàng)建一個(gè)新的容器
- start是把已經(jīng)創(chuàng)建好的容器啟動(dòng)
查看容器信息docker inspect 容器id
掛載
掛載介紹
容器里面的文件都是在容器內(nèi)部,而跟你當(dāng)前電腦是沒(méi)有關(guān)系的,如果刪除了容器怎么辦?但是資料又想保存就像MySQL一樣,我只是換一臺(tái)電腦就要把整個(gè)容器復(fù)制過(guò)去,太麻煩了!所以需要把容器的文件跟當(dāng)前主機(jī)文件作為一個(gè)映射。
命令教程
參數(shù)-v宿主機(jī)路徑:容器路徑# 以MySQL為例子
docker run -d --name mysql8 -p 3306:3306 -v /data/mysql8/config:/etc/mysql/conf.d -v /data/mysql8/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 mysql
# 以上的命令可以參考:https://hub.docker.com/_/mysql,里面有詳細(xì)介紹
為什么要知道這么多路徑或者參數(shù)
每個(gè)中間件或者一個(gè)數(shù)據(jù)庫(kù)容器,他可能需要有很多配置,例如密碼,持久化文件的路徑等等。那我們?cè)趺粗缆窂绞鞘裁矗?/span>
-
可以進(jìn)hub.docker.com找到自己需要的容器然后看文檔
-
進(jìn)容器找了(這個(gè)方法有點(diǎn)笨,筆者一開(kāi)始就是這么找到的。)
容器之間怎么進(jìn)行通訊
容器雖然是能相互通訊的,但是容器每次重啟ip都跟上一次不一樣,所以這樣通訊會(huì)很復(fù)雜。
示范# 先拉個(gè)CentOS鏡像下來(lái)
docker pull centos
# 創(chuàng)建個(gè)容器
docker run -d -it --name centos1 centos
docker run -d -it --name centos2 centos
docker inspect centos1_id
{
"NetworkSettings": {
"Networks": {
"bridge": {
"IPAMConfig": null,
"Links": null,
"Aliases": null,
"NetworkID": "9e7ed6d29ca3474de04409833e39b7c7965c7c63d3a1f509886a7a998e4825f8",
"EndpointID": "41230bf523fac8fa4933989d98baaaa7655fba5c5dadd14e63839ffe868ed3f8",
"Gateway": "172.17.0.1",
"IPAddress": "172.17.0.4",
"IPPrefixLen": 16,
"IPv6Gateway": "",
"GlobalIPv6Address": "",
"GlobalIPv6PrefixLen": 0,
"MacAddress": "02:42:ac:11:00:04",
"DriverOpts": null
}
}
}
}
]
docker inspect centos2_id
[
{
"NetworkSettings": {
"Networks": {
"bridge": {
"IPAMConfig": null,
"Links": null,
"Aliases": null,
"NetworkID": "9e7ed6d29ca3474de04409833e39b7c7965c7c63d3a1f509886a7a998e4825f8",
"EndpointID": "8ae77d46887c795983ee7a8fb96951d05e236b4ca4b4caa5d5964f892e18a476",
"Gateway": "172.17.0.1",
"IPAddress": "172.17.0.5",
"IPPrefixLen": 16,
"IPv6Gateway": "",
"GlobalIPv6Address": "",
"GlobalIPv6PrefixLen": 0,
"MacAddress": "02:42:ac:11:00:05",
"DriverOpts": null
}
}
}
}
]
-
以上centos1 ip為172.17.0.4
- 以上centos2 ip為172.17.0.5
解決問(wèn)題docker network create centos-network
docker run -d -it --network centos-network --name centos3 centos
docker run -d -it --network centos-network --name centos4 centos
docker exec -it centos3_id /bin/bash
ping centos4
# 所以當(dāng)創(chuàng)建了一個(gè)network后 容器都能加入到這個(gè)網(wǎng)絡(luò)里面,很方便
小結(jié)
其實(shí)在剛使用容器的時(shí)候會(huì)很麻煩:
-
不知道Docker的命令和容器需要的參數(shù)
-
每次都要上官網(wǎng)找下有什么參數(shù)或者百度,但相比每次下載文件下來(lái),進(jìn)去配置省很多力氣,并且配置一次保存好用過(guò)的命令,以后都可以用了,不需要再重復(fù)去改很多東西
- 其實(shí)在一些小型公司,沒(méi)有專(zhuān)業(yè)的運(yùn)維的話盡量不要在生產(chǎn)環(huán)境上使用Docker,不然真的出現(xiàn)問(wèn)題的話會(huì)很頭疼,不僅僅要維護(hù)項(xiàng)目,還要維護(hù)Docker
原文鏈接:https://juejin.cn/post/6974427129748389902