2--Docker容器相关命令
目录
一、docker容器基本操作
容器就是对外提供服务的一个实例。
容器启动的必要条件:容器内至少有一个进程运行在前台.
docker是一个进程隔离的软件,所运行的进程全部都运行在操作系统之上
一个容器内部只允许运行一个应用
说明:我们有了镜像才可以创建容器,Linux,下载一个centos镜像来测试学习
[root@docker ~]# docker pull centos
Using default tag: latest
latest: Pulling from library/centos
7a0437f04f83: Pull complete
Digest: sha256:5528e8b1b1719d34604c87e11dcd1c0a20bedf46e83b5632cdeac91b8c04efc1
Status: Downloaded newer image for centos:latest
docker.io/library/centos:latest
1、创建容器(运行镜像)
格式
docker run [参数] [镜像名称] [运行容器的启动命令]
# ps : 创建容器的命令(并未启动)
docker create
[root@k8s-m-01 ~]# docker create centos bash
ecfb35a4734e91dff21f6a0dd859083364cc3def4f37434625210a250632f68b
参数
-d : 以守护进程的方式运行一个容器(后台运行)
docker run -d [镜像名称] [cmd]
--name : 指定容器的名称(将容器名称解析到docker DNS上)
docker run -d --name [容器名称] [镜像的名称] [cmd]
-p : 指定端口映射
docker run -d -p 宿主主机端口:容器内端口 [镜像名称] [cmd]
-P :随机端口映射
docker run -d -P [镜像名称] [cmd]
-i : 打开标准输出
-t : 创建一个伪终端
docker run -it [镜像名称] [cmd]
-v : 挂载目录到容器中/做目录映射(宿主主机和docker容器主机间的文件共享)
docker run -v 宿主主机目录:容器内目录 [镜像名称] [cmd]
--rm : 容器生命周期结束时立即删除该容器
docker run --rm [镜像名称] [cmd]
参数: -f 强制删除
-e : 在容器中创建一个环境变量
docker run -e NAME=Centos -d [镜像名称] [cmd]
[root@k8s-m-01 ~]# docker run -it -e NAME=linux12 centos bash
[root@aa67f4bebdc1 /]# printenv
... ...
NAME=linux12
... ...
--link : 连接上另外一个容器,实现网络互通
docker run --link 被连接的容器的名称:连接别名 [镜像名称] [cmd]
注意:给连接起别名最好和被连接的容器的名称一致
-h : 设置容器主机名
docker run -h "主机名" [镜像名称] [cmd]
-m : 设置容器内存限制(默认:-1即为不做任何限制)
实例
[root@docker ~]# docker run -it centos /bin/bash #启动并进入容器
WARNING: IPv4 forwarding is disabled. Networking will not work.
[root@bf0b90672aed /]# ls #查看容器内的centos,基础版本,很多命令都是不完善的
bin etc lib lost+found mnt proc run srv tmp var
dev home lib64 media opt root sbin sys usr
[root@bf0b90672aed /]# exit #从容器中退回主机(容器停止并退出)
exit
Ctrl+p+q快捷键:容器不停止退出
#部署nginx
[root@docker ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx latest 4f380adfc10f 13 days ago 133MB
alpine latest d4ff818577bc 2 weeks ago 5.6MB
caodan999/alpine latest 965ea09ff2eb 20 months ago 5.55MB
nginx 1.12.2 4037a5562b03 3 years ago 108MB
[root@docker ~]# docker tag 4037a5562b03 caodan/nginx:v1.12.2
[root@docker ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
nginx latest 4f380adfc10f 13 days ago 133MB
alpine latest d4ff818577bc 2 weeks ago 5.6MB
caodan999/alpine latest 965ea09ff2eb 20 months ago 5.55MB
caodan/nginx v1.12.2 4037a5562b03 3 years ago 108MB
nginx 1.12.2 4037a5562b03 3 years ago 108MB
[root@docker ~]# docker run --rm --name mynginx -d -p81:80 caodan/nginx:v1.12.2
68815d7a018f580343665524fc603032b8565c8389c2ed728bf45d8cc1971879
[root@docker ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
68815d7a018f caodan/nginx:v1.12.2 "nginx -g 'daemon of…" 5 seconds ago Up 3 seconds 0.0.0.0:81->80/tcp, :::81->80/tcp mynginx
[root@docker ~]# netstat -lntp |grep 81
tcp 0 0 0.0.0.0:81 0.0.0.0:* LISTEN 11835/docker-proxy
tcp6 0 0 :::81 :::* LISTEN 11841/docker-proxy
[root@docker ~]# curl 127.0.0.1:81
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
... ...
docker run
运行流程
- 1、检查本地是否用指定镜像,如果没有则去对应的仓库下载镜像
- 2、启动容器,如果指定了命令则使用指定的命令,如果没有则使用默认的命令
- 3、返回容器ID
2、查看本机的容器列表
格式
docker ps [参数]
docker ps # 查看当前系统中正在运行的容器列表
参数
-a : 查看系统中所有的容器。
-q : 仅显示容器的ID
-n=: 显示最近创建的容器
状态解释
[root@k8s-m-01 ~]# docker ps -a
... ... ...
CONTAINER ID : 容器ID
IMAGE :镜像名称
COMMAND :容器启动时执行的命令
CREATED :容器的创建时间
STATUS :容器的状态(up : 正在运行, Exit:退出(停止)状态 Created :已创建状态)
PORTS :容器向外暴露的端口
NAMES :容器的名称
3、停止和启动一个容器
停止
docker stop [容器的ID|名称]
启动(该容器必须是系统已经存在的容器)
docker start [容器的ID|名称]
重启
docker restart [容器的ID|名称]
杀死
docker kill [容器的ID|名称]
实例
[root@docker ~]# docker run -it centos #先运行一个容器
WARNING: IPv4 forwarding is disabled. Networking will not work
[root@6f5810623fa2 /]# exit #退出并停止运行
exit
[root@docker ~]# docker ps #查看正在运行的容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
[root@docker ~]# docker ps -a #查看历史运行过的容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
6f5810623fa2 centos "/bin/bash" 35 seconds ago Exited (0) 23 seconds ago musing_borg
[root@docker ~]# docker start 6f5810623fa2 #开始centos容器
6f5810623fa2
[root@docker ~]# docker ps #查看正在运行的容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
6f5810623fa2 centos "/bin/bash" About a minute ago Up 12 seconds musing_borg
[root@docker ~]# docker stop 6f5810623fa2 #停止centos容器
6f5810623fa2
[root@docker ~]# docker ps #查看正在运行的容器
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4、* 端口印射
-p host_port:container_port
docker run -p 容器外端口:容器内端口
[root@docker ~]# systemctl stop firewalld
[root@docker ~]# setenforce 0
setenforce: SELinux is disabled
[root@docker ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
caodan920/nginx v1.20.1 7ca45f2d188b 2 weeks ago 133MB
nginx 1.20.1 7ca45f2d188b 2 weeks ago 133MB
[root@docker ~]# docker run --rm --name mynginx -d -p81:80 nginx
Unable to find image 'nginx:latest' locally
latest: Pulling from library/nginx
b4d181a07f80: Already exists
66b1c490df3f: Pull complete
d0f91ae9b44c: Pull complete
baf987068537: Pull complete
6bbc76cbebeb: Pull complete
32b766478bc2: Pull complete
Digest: sha256:3ca76089b14cf7db77cc5d4f3e9c9eb73768b9c85a0eabde1046435a6aa41c06
Status: Downloaded newer image for nginx:latest
16e027dfab716d7d243c7d8db9367d3ec802b69b01a36fed62d0455a82d2a1f0
[root@docker ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
16e027dfab71 nginx "/docker-entrypoint.…" 6 seconds ago Up 5 seconds 0.0.0.0:81->80/tcp, :::81->80/tcp mynginx
[root@docker ~]# curl 127.0.0.1:81
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
... ...
5、* 挂载数据卷
docker run -v 容器外目录:容器内目录
[root@docker ~]# mkdir html
[root@docker ~]# cd html
[root@docker html]# wget www.baidu.com -O index.html
--2021-07-08 08:52:39-- http://www.baidu.com/
Resolving www.baidu.com (www.baidu.com)... 112.80.248.76, 112.80.248.75
Connecting to www.baidu.com (www.baidu.com)|112.80.248.76|:80... connected.
HTTP request sent, awaiting response... 200 OK
Length: 2381 (2.3K) [text/html]
Saving to: ‘index.html’
100%[=================================>] 2,381 --.-K/s in 0s
2021-07-08 08:52:44 (327 MB/s) - ‘index.html’ saved [2381/2381]
[root@docker html]# cat index.html
<!DOCTYPE html>
... ...
[root@docker html]# cd
[root@docker ~]# docker run -d --rm --name nginx_baidu -d -p82:80 -v /root/html:/usr/share/nginx/html nginx
a600e50b1a1ebce161b71dd5c47ce6f2bccb29f558a652adf39047e78f0151f3
[root@docker ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
a600e50b1a1e nginx "/docker-entrypoint.…" 19 seconds ago Up 17 seconds 0.0.0.0:82->80/tcp, :::82->80/tcp nginx_baidu
16e027dfab71 nginx "/docker-entrypoint.…" 13 minutes ago Up 13 minutes 0.0.0.0:81->80/tcp, :::81->80/tcp mynginx
查看挂载的详细信息
[root@docker ~]# docker inspect nginx_baidu |grep -A 9 'Mounts'
"Mounts": [
{
"Type": "bind",
"Source": "/root/html",
"Destination": "/usr/share/nginx/html",
"Mode": "",
"RW": true,
"Propagation": "rprivate"
}
],
6、* 传递环境变量
-e variate_name=variate_value
docker run -e 环境变量key:环境变量value
[root@docker ~]# docker run --rm -e E_OPTS=abcdefg nginx printenv
HOSTNAME=bd14d48c46d7
HOME=/root
PKG_RELEASE=1~buster
NGINX_VERSION=1.21.1
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
NJS_VERSION=0.6.1
PWD=/
E_OPTS=abcdefg
#printenv:打印出环境变量的所有值
#传递多个环境变量
[root@docker ~]# docker run --rm -e E_OPTS=abcd -e C_OPTS=123456 nginx printenv
C_OPTS=123456
HOSTNAME=77295251509c
HOME=/root
PKG_RELEASE=1~buster
NGINX_VERSION=1.21.1
PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
NJS_VERSION=0.6.1
PWD=/
E_OPTS=abcd
7、* 容器内安装软件(工具)
红帽系 yum
debian系 apt-get
alpine apt
# 进入容器并且下载
[root@docker ~]# docker exec -it nginxbaidu /bin/bash
root@acf79798ce19:/# curl
bash: curl: command not found
root@acf79798ce19:/# tee /etc/apt/sources.list << EOF
deb http://mirrors.163.com/debian/ jessie main non-free contrib
deb http://mirrors.163.com/debian/ jessie-updates main non-free contrib
EOF
deb http://mirrors.163.com/debian/ jessie main non-free contrib
deb http://mirrors.163.com/debian/ jessie-updates main non-free contrib
root@acf79798ce19:/# cat /etc/apt/sources.list
deb http://mirrors.163.com/debian/ jessie main non-free contrib
deb http://mirrors.163.com/debian/ jessie-updates main non-free contrib
root@acf79798ce19:/# apt-get update && apt-get install curl -y
Ign:1 http://mirrors.163.com/debian jessie InRelease
... ...
安装好后commit并且推送到仓库
[root@alice ~]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
acf79798ce19 nginx:1.12.2 "nginx -g 'daemon of…" About an hour ago Up About an hour 0.0.0.0:84->80/tcp nginx_with_baidu
6ce9e4bb303b nginx:1.12.2 "nginx -g 'daemon of…" About an hour ago Up About an hour 0.0.0.0:83->80/tcp nginx
[root@alice ~]# docker commit -p acf79798ce19 mmdghh/nginx:curl
sha256:84b7a98f5ee209f0139febe7cac04a7edaaca7254ddf1c043e8ac779504204ba
[root@alice ~]# docker push docker.io/mmdghh/nginx:curl
The push refers to repository [docker.io/mmdghh/nginx]
bbadc5b62281: Pushed
4258832b2570: Mounted from library/nginx
683a28d1d7fd: Pushed
d626a8ad97a1: Mounted from library/nginx
curl: digest: sha256:f86f97bacf0ff37e3cc09f98dfb8153c486ee1e8bb9caad5046ed6aa58c43c50 size: 1160
8、删除容器
格式
docker rm [容器名称|ID]
参数
-f : 强制删除docker rm -f [容器名称|ID]
清空容器
docker rm $(docker ps -a -q)docker ps -a -q | xargs docker rm
常用的脚本:过滤出所有锁主机上退出的容器,然后干掉
[root@docker ~]# for i in `docker ps -a|grep -i exit|awk '{print $1}'`;do docker rm -f $i;done
实例
[root@docker ~]# docker rm 1714ae45e360 #删除正在运行容器会报错
Error response from daemon: You cannot remove a running container 1714ae45e360243fee68c907f335b34c83fb70217f4216e33a615a71ca66d23a. Stop the container before attempting removal or force remove
[root@docker ~]# docker rm -f 1714ae45e360 #强制删除
1714ae45e360
[root@docker ~]# docker ps -aq
bf0b90672aed
7518288dddfb
64a7c388b5f8
[root@docker ~]# docker rm -f $(docker ps -aq) #删除所有容器
bf0b90672aed
7518288dddfb
64a7c388b5f8
[root@docker ~]# docker ps -aq
9、查看容器详细信息
格式
docker inspect [容器名称|ID]
怎么监控docker运行状态?
docker inspect -f '{{.State.Running}}' nginx
10、复制命令
将文件复制到或复制出容器
# 1、复制到容器内
docker cp [宿主主机文件路径] 容器ID或名称:容器内路径
# 2、复制到容器外
docker cp 容器ID:容器内路径 [宿主主机文件路径]
实例(从容器内拷贝文件到主机上)
[root@docker ~]# docker run -it centos /bin/bash #先运行一个容器
WARNING: IPv4 forwarding is disabled. Networking will not work.
[root@94654381fb70 /]# cd /home #切换到家目录
[root@94654381fb70 home]# ls
[root@94654381fb70 home]# touch test.java #建一个文件
[root@94654381fb70 home]# ls
test.java
[root@94654381fb70 home]# exit #退出
exit
[root@docker ~]# docker ps -a #查看进程号
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
94654381fb70 centos "/bin/bash" 26 minutes ago Exited (0) 23 minutes ago
[root@docker ~]# docker cp 94654381fb70:/home/test.java /home #拷贝容器里那个文件到主机的家目录
[root@docker ~]# cd /home #切换到主机的家目录
[root@docker home]# ls #查看拷贝的文件
test.java
11、进入当前正在运行的容器
我们通常容器都是使用后台方式运行的,需要进入容器,修改一些配置,进入容器一般有四种
1、exec : 在容器外向容器内执行一个命令(官方推荐)
docker exec [参数] [容器的名称或ID] [cmd]
#实例:
[root@docker ~]# docker exec -it a428029e2e1b /bin/bash
2、attach : 在早期docker提供的进入容器的命令(缺点:当其结束时,容器也跟着结束了/ 通过进程管道连接上容器内部PID为1的进程
docker attach [容器ID|名称]
#实例:
[root@docker ~]# docker attach a428029e2e1b
[root@a428029e2e1b /]#
3、nsenter : 建立一个管道连接上容器主ID
nsenter --target $( docker inspect -f {{.State.Pid}} 30d369d70bcd) --mount --uts --ipc --net --pid
4、ssh : 通过ssh连接
## exec和attach进入容器的区别:
- exec :进入容器后开启一个新的终端,可以在里面操作(常用)
- attach :进入容器正在执行的终端,不会启动新的进程
12、查看容器内部的日志
#1.本身容器没有日志
docker logs -f -t --tail [容器ID/容器名称]
-f :实时打印日志
#2.运行一个程序(编写一个脚本)
docker run -d centos /bin/bash -c "while true; do echo 123;sleep 1;done"
-c:指定动作
#3.查看运行的容器
[root@docker ~]# docker ps
CONTAINER ID IMAGE
73f41ee70158 centos
#4.显示日志
docker logs -tf --tail 10 73f41ee70158 #显示10条日志内容
doc
13、查看容器内部的进程信息
查看容器内部的进程信息(容器必须是运行的,必须用容器ID查看)
[root@docker ~]# docker top a428029e2e1b
UID PID PPID C STIME TTY TIME CMD
root 16108 16088 0 01:10 pts/0 00:00:00 /bin/bash
容器的生命周期
dokcer run启动容器的时候,dokcer后台操作流程是
检查本地是否有该镜像,没有就下载
利用镜像创建且启动一个容器
分配容器文件系统,在只读的镜像层挂载读写层
宿主机的网桥接口会分配一个虚拟接口到容器中
容器获得地址池的ip地址
执行用户指定的程序
若程序里没有进程在运行,容器执行完毕后立即终止