Docker基本使用命令



# 以Redis為例子
docker pull redis
docker run \
-d \ # 后臺運行
--name redis6 \ # 自定義名字
-p 6379:6379 \ # 端口映射
redis # 鏡像名稱
docker run -d --name redis6 -p 6379:6379 redis redis-server --appendonly yes --requirepass "123456" # 完整命令
docker attach 容器id
docker exec -it 容器id /bin/bash
docker stop 容器id
docker start 容器id
docker ps -a # 查看所有容器
docker ps # 查看運行中的容器
run是創(chuàng)建一個新的容器
start是把已經(jīng)創(chuàng)建好的容器啟動
docker inspect 容器id

# 以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,里面有詳細介紹
可以進hub.docker.com找到自己需要的容器然后看文檔
進容器找了(這個方法有點笨,筆者一開始就是這么找到的。)

# 先拉個CentOS鏡像下來
docker pull centos
# 創(chuàng)建個容器
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
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
# 所以當創(chuàng)建了一個network后 容器都能加入到這個網(wǎng)絡(luò)里面,很方便

不知道Docker的命令和容器需要的參數(shù)
每次都要上官網(wǎng)找下有什么參數(shù)或者百度,但相比每次下載文件下來,進去配置省很多力氣,并且配置一次保存好用過的命令,以后都可以用了,不需要再重復(fù)去改很多東西
其實在一些小型公司,沒有專業(yè)的運維的話盡量不要在生產(chǎn)環(huán)境上使用Docker,不然真的出現(xiàn)問題的話會很頭疼,不僅僅要維護項目,還要維護Docker
原文鏈接:https://juejin.cn/post/6974427129748389902 轉(zhuǎn)自:分布式實驗室
![]()
