Docker命令
创始人
2024-04-04 16:37:20
0

1. docker run

1.1. 命令说明

创建一个新的容器并运行一个命令

1.2. 语法

docker run [OPTIONS] IMAGE [COMMAND] [ARG…]

1.3. OPTIONS说明

-a stdin: 指定标准输入输出内容类型,可选 STDIN/STDOUT/STDERR 三项;

-d: 后台运行容器,并返回容器ID;

-i: 以交互模式运行容器,通常与 -t 同时使用;

-P: 随机端口映射,容器内部端口随机映射到主机的端口

-p: 指定端口映射,格式为:主机(宿主)端口:容器端口

-t: 为容器重新分配一个伪输入终端,通常与 -i 同时使用;

--name="nginx-lb": 为容器指定一个名称;

--dns 8.8.8.8: 指定容器使用的DNS服务器,默认和宿主一致;

--dns-search example.com: 指定容器DNS搜索域名,默认和宿主一致;

-h "mars": 指定容器的hostname;

-e username="ritchie": 设置环境变量;

--env-file=[]: 从指定文件读入环境变量;

--cpuset="0-2" or --cpuset="0,1,2": 绑定容器到指定CPU运行;

-m :设置容器使用内存最大值;

--net="bridge": 指定容器的网络连接类型,支持 bridge/host/none/container: 四种类型;

--link=[]: 添加链接到另一个容器;

--expose=[]: 开放一个端口或一组端口;

--volume , -v: 绑定一个卷

1.4. 常用实例

使用docker镜像fate:latest以后台模式启动一个容器,并将容器命名为myfate。

docker run --name myfate -d fate:latest

使用镜像fate:latest以后台模式启动一个容器,并将容器的80端口映射到主机随机端口。

docker run -P -d fate:latest

使用镜像 fate:latest,以后台模式启动一个容器,将容器的 80 端口映射到主机的 80 端口,主机的目录 /home/data 映射到容器的 /data

docker run -p 80:80 -v /home/data:/data -d fate:latest

绑定容器的 8080 端口,并将其映射到本地主机 127.0.0.1 的 80 端口上。

docker run -p 127.0.0.1:80:8080/tcp ubuntu bash

使用镜像fate:latest以交互模式启动一个容器,在容器内执行/bin/bash命令。

docker run -it fate:latest /bin/bash

2. docker start/stop/restart

2.1. 命令说明

docker start :启动一个或多个已经被停止的容器
docker stop :停止一个运行中的容器
docker restart :重启容器

2.2. 使用方法

启动已被停止的容器myfate

docker start myfate

停止运行中的容器myfate

docker stop myfate

重启容器myfate

docker restart myfate

3. docker kill

3.1. 命令说明

杀掉一个运行中的容器

3.2. 实例

杀掉运行中的容器myfate

docker kill -s KILL myfate

4. docker rm

4.1. 命令说明

删除一个或多个容器

4.2. 语法

docker rm [OPTIONS] CONTAINER [CONTAINER…]

4.3. OPTIONS说明

-f :通过 SIGKILL 信号强制删除一个运行中的容器。

-l :移除容器间的网络连接,而非容器本身。

-v :删除与容器关联的卷。

4.4. 常用实例

强制删除容器 fate01、fate02:

docker rm -f fate01 fate02

移除容器 fate01 对容器 fate02 的连接,连接名 db:

docker rm -l db

删除容器 fate, 并删除容器挂载的数据卷:

docker rm -v fate

删除所有已经停止的容器:

docker rm $(docker ps -a -q)

杀死所有正在运行的容器

docker kill $(docker ps -a -q)

删除所有已经停止的容器

docker rm $(docker ps -a -q)

删除所有未打 dangling 标签的镜像

docker rmi $(docker images -q -f dangling=true)

通过镜像的id来删除指定镜像

docker rmi 

删除所有镜像

docker rmi $(docker images -q)

5. docker pause/unpause

5.1. 命令说明

docker pause :暂停容器中所有的进程。
docker unpause :恢复容器中所有的进程。

5.2. 语法

docker pause CONTAINER [CONTAINER…]
docker unpause CONTAINER [CONTAINER…]

5.3. 常用实例

暂停数据库容器fate提供服务。

docker pause fate

恢复数据库容器 fate 提供服务。

docker unpause fate

6. docker create

6.1. 命令说明

docker create :创建一个新的容器但不启动它
用法同 docker run

6.2. 语法

docker create [OPTIONS] IMAGE [COMMAND] [ARG…]
语法同 docker run

6.3. 常用实例

使用docker镜像fate:latest创建一个容器,并将容器命名为myfate

docker create  --name myfate  fate:latest    

7. docker exec

7.1. 命令说明

在运行的容器中执行命令

7.2. 语法

docker exec [OPTIONS] CONTAINER COMMAND [ARG…]

7.3. OPTIONS说明

-d :分离模式: 在后台运行
-i :即使没有附加也保持STDIN 打开
-t :分配一个伪终端

7.4. 常用实例

在容器 myfate中以交互模式执行容器内 /root/init.sh 脚本:

docker exec -it myfate /bin/sh /root/runoob.sh

在容器 fate 中开启一个交互模式的终端:

docker exec -i -t  myfate /bin/bash

也可以通过 docker ps -a 命令查看已经在运行的容器,然后使用容器 ID 进入容器。
查看已经在运行的容器 ID:

# docker ps -a 
...
9df70f9a0714        openjdk             "/usercode/script.sh…" 
...

第一列的 9df70f9a0714 就是容器 ID。
通过 exec 命令对指定的容器执行 bash:

docker exec -it 9df70f9a0714 /bin/bash

8. docker ps

8.1. 命令说明

列出容器

8.2. 语法

docker ps [OPTIONS]

8.3. OPTIONS说明

-a :显示所有的容器,包括未运行的。
-f :根据条件过滤显示的内容。
–format :指定返回值的模板文件。
-l :显示最近创建的容器。
-n :列出最近创建的n个容器。
–no-trunc :不截断输出。
-q :静默模式,只显示容器编号。
-s :显示总的文件大小。

8.4. 常用实例

列出所有在运行的容器信息。

docker ps
CONTAINER ID   IMAGE          COMMAND                ...  PORTS                    NAMES
09b93464c2f7   fate:latest   "fate -g 'daemon off" ...  80/tcp, 443/tcp              myfate
96f7f14e99ab   mysql:5.6      "docker-entrypoint.sh" ...  0.0.0.0:3306->3306/tcp   mymysql

输出详情介绍:

CONTAINER ID: 容器 ID。
IMAGE: 使用的镜像。
COMMAND: 启动容器时运行的命令。
CREATED: 容器的创建时间。
STATUS: 容器状态。

状态有7种:

created(已创建)
restarting(重启中)
running(运行中)
removing(迁移中)
paused(暂停)
exited(停止)
dead(死亡)

PORTS: 容器的端口信息和使用的连接类型(tcp\udp)。
NAMES: 自动分配的容器名称。
列出最近创建的5个容器信息。

docker ps -n 5
CONTAINER ID        IMAGE               COMMAND                   CREATED           
09b93464c2f7        fate:latest        "fate -g 'daemon off"    2 days ago   ...     
b8573233d675        fate:latest        "/bin/bash"               2 days ago   ...     
b1a0703e41e7        fate:latest        "fate -g 'daemon off"    2 days ago   ...    
f46fb1dec520        5c6e1090e771        "/bin/sh -c 'set -x \t"   2 days ago   ...   
a63b4a5597de        860c279d2fec        "bash"                    2 days ago   ..

根据标签过滤

docker run -d --name=test-nginx --label color=blue nginx
docker ps --filter "label=color"
docker ps --filter "label=color=blue"

根据名称过滤

docker ps --filter"name=test-nginx"

根据状态过滤

docker ps -a --filter 'exited=0'
docker ps --filter status=running
docker ps --filter status=paused

根据镜像过滤

#镜像名称
docker ps --filter ancestor=nginx#镜像ID
docker ps --filter ancestor=d0e008c6cf02

根据启动顺序过滤

docker ps -f before=9c3527ed70ce
docker ps -f since=6e63f6ff38b0

9. docker inspect

9.1. 命令说明

docker inspect : 获取容器/镜像的元数据。

9.2. 语法

docker inspect [OPTIONS] NAME|ID [NAME|ID…]

9.3. OPTIONS说明

-f :指定返回值的模板文件。
-s :显示总的文件大小。
–type :为指定类型返回JSON。

9.4. 常用实例

获取镜像fate:1.6的元信息

docker inspect fate:1.6
[{"Id": "sha256:2c0964ec182ae9a045f866bbc2553087f6e42bfc16074a74fb820af235f070ec","RepoTags": ["fate:1.6"],"RepoDigests": [],"Parent": "","Comment": "","Created": "2016-05-24T04:01:41.168371815Z","Container": "e0924bc460ff97787f34610115e9363e6363b30b8efa406e28eb495ab199ca54","ContainerConfig": {"Hostname": "b0cf605c7757","Domainname": "","User": "","AttachStdin": false,"AttachStdout": false,"AttachStderr": false,"ExposedPorts": {"3306/tcp": {}},
...

获取正在运行的容器mymysql的 IP。

docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' myfate
192.17.0.3

10. docker top

10.1. 命令说明

查看容器中运行的进程信息,支持 ps 命令参数。

10.2. 常用实例

docker top mysql
UID    PID    PPID    C      STIME   TTY  TIME       CMD
999    40347  40331   18     00:58   ?    00:00:02   mysqld

参考文献

Docker 命令以及常用实例汇总_AI浩的博客-CSDN博客_docker 查看所有实例

Docker 命令大全 | 菜鸟教程 

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...