目录
一、docker的基本命令
1.1 查看镜像
1.2 查看所有状态容器
1.3 run指令
1.4 查看docker信息
二、docker的镜像操作
2.1 搜索镜像
2.2 下载镜像
2.3 查看镜像列表
2.4 获取镜像的信息
2.5 添加镜像标签
2.6 删除镜像
2.7 批量删除镜像
2.8 导出和导入镜像
三、容器的操作
3.1 查询所有容器的运行状态
3.2 创建容器
3.3 启动容器
3.4 日志、端口、重命名
3.4.1 查看容器的运行日志
3.4.2 查看容器端口信息
3.4.3 容器的重命名
3.5 查看容器的IP地址
3.6 进入容器
扩展:生产方式进入容器
3.7 容器导出和导入
3.8 删除容器
3.9 docker日志的问题
3.9.1 执行持续性任务
3.9.2 设置docker日志文件大小和数量
3.10 容器打包成镜像
3.11 查看docker消耗资源的状态
总结
docker images
docker ps -a
docker run hello-world
docker client客户端连接到了服务端(服务端是以一个守护进程的形式跑在操作系统里面的)restful api典型的c/s架构
由docker服务端的守护进程从docker hub 上下载了镜像(Ps:服务端会先检查本地系统是否有这个镜像)
服务端创建了一个新的容器,然后从拉去的这个镜像启动了一个容器,容器执行了脚本/可执行程序让我们可以查看/使用(client)
docker 服务端把这些信息流(传递)返回到客户端并展示出来,(展示在终端上)docker client可以是多种形式,比如"docker"命令工具所在的终端
docker info
docker info
#可以用该命令统计每一个状态的容器有多少个
Client:
Context: default
Debug Mode: false
Plugins:
app: Docker App (Docker Inc., v0.9.1-beta3)
buildx: Docker Buildx (Docker Inc., v0.7.1-docker)
scan: Docker Scan (Docker Inc., v0.12.0)
Server:
Containers: 1 #容器连接数量
Running: 0 #正在运行的容器数量
Paused: 0 #暂停的容器数量
Stopped: 1 #停止的容器数量
Images: 2 #统计的镜像数量
Server Version: 20.10.12 #docker版本
Storage Driver: overlay2 #存储引擎,早期有一段用的是aufa存储引擎,可以把多个目录叠在在一起后挂载到同一个目录一下
Backing Filesystem: xfs #后端的文件系统
Supports d_type: true
Native Overlay Diff: true
userxattr: false
Logging Driver: json-file
Cgroup Driver: cgroupfs #linux中资源控制,资源管理的驱动:cgroupfs
Cgroup Version: 1
Plugins: #插件
Volume: local #镜像默认保存位置。可以不保存在本地,docker是以引擎的方式架设在linux之上的。
Network: bridge host ipvlan macvlan null overlay #所支持的默认的网络类型。bridge(桥接)、host(主机)、ipvlan(三层模式划分vlan)、macvlan(二层模式划分vlan)、null(躺平:不与别人交互)、overlay(叠加网络)
Log: awslogs fluentd gcplogs gelf journald json-file local logentries splunk syslog
Swarm: inactive
Runtimes: io.containerd.runc.v2 io.containerd.runtime.v1.linux runc #运行时
Default Runtime: runc #默认运行时的版本
Init Binary: docker-init
containerd version: 7b11cfaabd73bb80907dd23182b9347b4245eb5d
runc version: v1.0.2-0-g52b36a2
init version: de40ad0
Security Options:
seccomp
Profile: default
Kernel Version: 3.10.0-693.el7.x86_64
Operating System: CentOS Linux 7 (Core)
OSType: linux
Architecture: x86_64
CPUs: 4 #总计cpu
Total Memory: 1.718GiB #总计内存
Name: docker
ID: DT7Y:MDZR:NVOS:NQBJ:C2RV:L5IS:OSLD:E3DG:3PSN:EJDH:ZYMU:42HS
Docker Root Dir: /var/lib/docker #docker家目录
Debug Mode: false
Registry: https://index.docker.io/v1/ #默认仓库
Labels:
Experimental: false
Insecure Registries:
127.0.0.0/8
Registry Mirrors:
https://4abdkxlk.mirror.aliyuncs.com/
Live Restore Enabled: false
docker search 关键字
docker pull
docker images
docker inspect
docker tag 名称:旧标签 新名字:新标签
#格式:
docker rmi 仓库名称:标签 #当一个镜像有多个标签时,只是删除其中指定的标签
docker rmi 镜像ID号 #会彻底删除该镜像
可使用选项:
-f : 强制删除镜像
#docker images -q 可以加载镜像id
#批量删除所有镜像
docker rmi `docker images -q`
#批量删除nginx镜像
docker rmi `docker images|grep "nginx"`
#导出镜像
#格式:docker save -o 存储文件名 存储的镜像
docker save -o nginx_v1 nginx:latest #存出镜像命名为nginx存在当前目录下
scp nginx_v1 @root:192.168.59.111:/opt #将导出的镜像以scp方式导到别的服务器上
#导入镜像,可以异地导入,但是必须要有docker引擎,并且版本不可以差太多
#格式:docker load < 存出的文件
docker load < nginx_v1
导出:
2.9 批量打包镜像
docker save -o 包名.tar 镜像1 镜像2 镜像3
将所有的镜像打包到all.tar文件里
docker save $(docker images | grep -v REPOSITORY | awk 'BEGIN{OFS=":";ORS=" "}{print $1,$2}') -o all.tar
docker ps -a
-a : 显示所有的容器,包括未运行的。
-f : 根据条件过滤显示的内容。
--format : 指定返回值的模板文件。
-l : 显示最近创建的容器。
-n : 列出最近创建的n个容器。
--no-trunc : 不截断输出。
-q : 静默模式,只显示容器编号。
-s : 显示总的文件大小。
docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
8b0a7be0ff58 nginx:latest "/docker-entrypoint.…" 57 seconds ago Created inspiring_swanson
容器的ID号 加载的镜像 运行的程序 创建时间 当前的状态 端口映射 名称
docker create
新创建的容器默认处于停止状态,不运行任何程序,需要在其中发起一个进程来启动容器。
#格式:docker create [选项] 镜像
#常用选项:
-i:让容器的输入保持打开
-t:让 Docker 分配一个伪终端
#示例:
docker create -it nginx:latest /bin/bash
docker start
#格式:docker start 容器的ID/名称
docker start dad24816d6a0
docker ps -a
停止容器:
docker stop 容器ID
一次性启动容器
docker run
#加 -d 选项让 Docker 容器以守护形式在后台运行。并且容器所运行的程序不能结束。
#示例1:
docker run -itd nginx:latest /bin/bash
#示例2:执行后退出
docker run centos:7 /usr/bin/bash -c ls /
#示例3:执行后不退出,以守护进程方式执行持续性任务
docker run -d centos:7 /usr/bin/bash -c "while true;do echo hello;done"
#命令格式:
docker logs [容器id]
#命令效果:
$ docker logs 7c5a24a68f96
#命令格式:
docker port [容器id]
#命令效果:
$ docker port 930f29ccdf8a
#没有效果没有和宿主机关联
#作用:
修改容器的名称
#命令格式:
docker rename [容器id]或[容器名称] [容器新名称]
#命令效果:
$ docker rename 930f29ccdf8a u1
docker inspect
#格式:docker inspect 容器id
docker ps -a #先查看运行时容器的id
docker inspect ba8d61d35e32
docker exec
进入容器的容器状态必须是up状态
和shell 是两种运行模式
docker run -it 会创建前台进程,但是会在输入exit后终止进程。
docker attach 会通过连接stdin,连接到容器内输入输出流,会在输入exit后终止容器进程
docker exec -it 会连接到容器,可以像sSH一样进入容器内部,进行操作,可以通过exit退出容器,不影响容器运行。
#需要进入容器进行命令操作时,可以使用 docker exec 命令进入运行着的容器。
#格式:docker exec -it 容器ID/名称 /bin/bash
-i 选项表示让容器的输入保持打开;
-t 选项表示让 Docker 分配一个伪终端。
#示例:进入(三种方式)
docker run -itd centos:7 /bin/bash #先运行容器
docker ps -a
①使用run进入,可以使用ctrl+d退出,直接退出终端
docker run -it centos:7 /bin/bash
②想永久性进入,退出后还是运行状态,用docker exec
docker ps -a
docker exec -it b99e0771c4e1 /bin/bash
③docker attach,会通过连接stdin,连接到容器内输入输出流,
公在输入exit后终止容器进程(临时性的,不推荐)
docker exec 退出后容器不会退出
docker run
我们生产中常用的进入容器方法是使用脚本,脚本内容如下:
#!/bin/bash
#定义进入仓库函数
docker_in(){
NAME_ID=$1
PID=$(docker inspect --format {{.State.Pid}} $NAME_ID)
nsenter --target $PID --mount --uts --ipc --net --pid
}
docker_in $1
docker export
用户可以将任何一个 Docker 容器从一台机器迁移到另一台机器。在迁移过程中,可以使用docker export 命令将已经创建好的容器导出为文件,无论这个容器是处于运行状态还是停止状态均可导出。可将导出文件传输到其他机器,通过相应的导入命令实现容器的迁移。
#导出格式:docker export 容器ID/名称 > 文件名
docker export b99e0771c4e1 > centos_7
#导入格式:cat 文件名 | docker import – 镜像名称:标签
法①
docker import centos_7 centos:v1 #导入后会生成镜像,但不会创建容器
法②
cat centos_7 |docker import - centos:v2
导出:
导入:
docker rm-f
#格式:docker rm [-f] 容器ID/名称
1.#不能删除运行状态的容器,只能-f强制删除,或者先停止再删除
docker rm 3224eb044879
2.#已经退出的容器,可以直接删除
docker rm 1270a6791069
3.#基于名称匹配的方式删除
docker rm -f distracted_panini
4.#删除所有运行状态的容器
docker rm -f `docker ps -q`
5.#删除所有容器
docker rm -f `docker ps -aq`
6.#有选择性的批量删除 (正则匹配)
docker ps -a l awk ' {print "docker rm "$1}'l bash
7.#删除退出状态的容器
for i in `dockef ps -a l grep -i exit / awk '{print $1}' '; do docker rm -f $i;done
①-f强制删除正在运行的容器
docker日志存放在 /var/lib/docker/containers/
docker run -d centos:7 /usr/bin/bash -c "while true;do echo hello;done"
使用df -h查看
方法一:
echo " " > /data/docker/containers/xxxxx/xxxx-json.log
方法二:创建脚本执行文件
#!/bin/bash
logs=$(find /data/docker/containers/ -name *-json.log*)
for log in $logs
do
cat /dev/null > $log
done
vim /etc/docker/daemon.json
{
"registry-mirrors": ["https://3dilfytj.mirror.aliyuncs.com"],
"log-driver":"json-file", ###定义日志文件的格式
"log-opts":{"max-size":"500m","max-file":"3"} ###定义日志文件的大小和数量
}
自定义个容器:
docker run -it --name nginx \
-v /data_nginx/:/usr/local/nginx/conf \
-v /log_nginx:/usr/local/nginx/logs \
log-driver=json-file \
log-opts max-size=500m \
log-opts max-file=3 \
-p 81:80 \
-P 8443:443 \
--network ky19 \
--ip 172.18.0.10 \
nginx:latest
docker run -it --name nginx.01 nginx:latest /bin/bash
###指定一个容器运行
docker commit 39eaa5aa7332 nginx-v1beta
### commit 直接提交
docker stats
entos:7
5、下载镜像pulldocker pull nginx(镜像名称)
6、查看镜像docker images 查看镜像列表
docker images -q 查看镜像过滤id
7、查看当前docker下的镜像详细信息 获取镜像信息
docker inspect 镜像id
8、添加镜像标签
docker tag hello-world:latest hello-world:自定义名称
9、删除镜像
docker rm 容器ID
docker rmi 镜像ID
docker rmi hello-world:自定义名称
10、镜像导出/导入
docker save -o 文件名镜像名
scp hello-world [email protected]:/opt
docker load < hello.world
11、容器相关操作docker ps -a 显示所有的容器,包括未运行的 a:all
docker ps -aq 查看容器的id q:代表过滤,只过滤容器id
12、删除容器docker ps -aq 强制批量删除容器,不建议使用,若需要删除筛选出id进行删除
13、启动运行容器docker create -it nginx:latest /bin/bash -i:让容器的标准输入保持打开 -t:分配一个伪终端 -d:后台守护进程的方式进行
14、启动容器docker start
15、启动一次性运行容器
docker pull centos:7
docker run centos:7 /usr/bin/bash -c ls
16、持续后台运行
docker run -d centos:7 /usr/bin/bash -c “while true;do echo hello;done”
17、停止容器
docker stop 容器ID
18、进入/退出容器
docter run -tid -name 名字 --privileged=true centos /sbin/init
19、docker exec -it 容器id /bin/bash
20、删除
第一种:docker rm 容器ID
第二种:正则匹配删除 docker ps -a | awk ‘{print "docker rm " $1 }’ | bash
第三种:删除非UP状态的rm -f 强制删除所有 docker rm -f docker ps -q
第四种:批量删除exit状态的容器 for i docker ps -a | grep -i exit | awk '{print $1}' ; do docker rm -f $i ;done
21、docker stats 容器查看当前资源消耗信息状态
22、导入容器 docker import 导出文件名 指定镜像名称
23、导出容器 docker export 容器ID > 文件名