参考源

https://www.bilibili.com/video/BV1og4y1q7M4?spm_id_from=333.999.0.0

https://www.bilibili.com/video/BV1kv411q7Qc?spm_id_from=333.999.0.0

版本

本文章基于 Docker 20.10.11


启动 Docker

systemctl start docker

在服务器关机或者重启后,是需要重新启动 Docker 的。 命令如下:

  1. systemctl start docker

查看日志

docker logs

语法

  1. docker logs [参数] 容器

参数

  • -f:日志流动输出。
  • -t:展示时间戳。
  • --tail:从日志末尾显示的行数。

为模拟日志输出效果,我们先编写一段脚本

  1. while true;do echo sail;sleep 3;done

以上脚本实现的效果为:每隔 3 秒输出字符串 sail。

以脚本启动容器

  1. [root@sail ~]# docker run -d centos /bin/sh -c "while true;do echo sail;sleep 3;done"
  2. c3d59f55d600566a5bbd9411ce716fbd338efc1c7c991f5baf1152f021d7e151
  1. [root@sail ~]# docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. c3d59f55d600 centos "/bin/sh -c 'while t…" 7 seconds ago Up 7 seconds musing_poincare
  1. [root@sail ~]# docker logs -f -t --tail 10 c3d59f55d600
  2. 2021-12-10T03:01:28.607288480Z sail
  3. 2021-12-10T03:01:31.609334595Z sail
  4. 2021-12-10T03:01:34.611361943Z sail
  5. 2021-12-10T03:01:37.613461457Z sail
  6. 2021-12-10T03:01:40.615619089Z sail
  7. 2021-12-10T03:01:43.617595572Z sail
  8. 2021-12-10T03:01:46.619526233Z sail
  9. 2021-12-10T03:01:49.621856800Z sail
  10. 2021-12-10T03:01:52.623864131Z sail
  11. 2021-12-10T03:01:55.626146643Z sail
  12. 2021-12-10T03:01:58.628272273Z sail
  13. 2021-12-10T03:02:01.630370420Z sail
  14. 2021-12-10T03:02:04.632430066Z sail
  15. 2021-12-10T03:02:07.634690353Z sail
  16. 2021-12-10T03:02:10.636760025Z sail

可以看到,按此命令会看到容器最后 10 条日志,且每隔 3 秒滚动输出一条日志。

后台启动

docker run -d

语法

  1. docker run -d 镜像

后台启动镜像

  1. [root@sail ~]# docker run -d centos
  2. 0aee6f74b913f120195ca323892867bba7d72f2671f2f8b17278a3e029ad5bfd
  1. [root@sail ~]# docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

使用 docker run -d 启动,也并不能保证容器一定能在后台运行,如果没有前台使用,容器启动后发现自己没有提供服务,会立刻停止。

前面的 docker run -d centos /bin/sh -c "while true;do echo sail;sleep 3;done" 命令,由于启动后运行了脚本打印日志,即提供了服务,所以不会停止。

查看容器信息

docker inspect

语法

  1. docker inspect 容器

示例

  1. [root@sail ~]# docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. c3d59f55d600 centos "/bin/sh -c 'while t…" 24 minutes ago Up 5 seconds musing_poincare
  1. [root@sail ~]# docker inspect c3d59f55d600
  2. [
  3. {
  4. "Id": "c3d59f55d600566a5bbd9411ce716fbd338efc1c7c991f5baf1152f021d7e151", # 容器的完整ID
  5. "Created": "2021-12-10T02:59:43.245101004Z", # 创建时间
  6. "Path": "/bin/sh", # 脚本位置
  7. "Args": [ # 运行的脚本
  8. "-c",
  9. "while true;do echo sail;sleep 3;done"
  10. ],
  11. "State": {
  12. "Status": "running", # 状态:正在运行
  13. "Running": true,
  14. "Paused": false,
  15. "Restarting": false,
  16. "OOMKilled": false,
  17. "Dead": false,
  18. "Pid": 31277, # 父进程ID
  19. "ExitCode": 0,
  20. "Error": "",
  21. "StartedAt": "2021-12-10T03:23:37.744951214Z",
  22. "FinishedAt": "2021-12-10T03:04:59.090158114Z"
  23. },
  24. "Image": "sha256:5d0da3dc976460b72c77d94c8a1ad043720b0416bfc16c52c45d4847e53fadb6", # 来源镜像
  25. "ResolvConfPath": "/var/lib/docker/containers/c3d59f55d600566a5bbd9411ce716fbd338efc1c7c991f5baf1152f021d7e151/resolv.conf",
  26. "HostnamePath": "/var/lib/docker/containers/c3d59f55d600566a5bbd9411ce716fbd338efc1c7c991f5baf1152f021d7e151/hostname",
  27. "HostsPath": "/var/lib/docker/containers/c3d59f55d600566a5bbd9411ce716fbd338efc1c7c991f5baf1152f021d7e151/hosts",
  28. "LogPath": "/var/lib/docker/containers/c3d59f55d600566a5bbd9411ce716fbd338efc1c7c991f5baf1152f021d7e151/c3d59f55d600566a5bbd9411ce716fbd338efc1c7c991f5baf1152f021d7e151-json.log",
  29. "Name": "/musing_poincare",
  30. "RestartCount": 0,
  31. "Driver": "overlay2",
  32. "Platform": "linux",
  33. "MountLabel": "",
  34. "ProcessLabel": "",
  35. "AppArmorProfile": "",
  36. "ExecIDs": null,
  37. "HostConfig": { # 主机配置
  38. "Binds": null,
  39. "ContainerIDFile": "",
  40. "LogConfig": {
  41. "Type": "json-file",
  42. "Config": {}
  43. },
  44. "NetworkMode": "default",
  45. "PortBindings": {},
  46. "RestartPolicy": {
  47. "Name": "no",
  48. "MaximumRetryCount": 0
  49. },
  50. "AutoRemove": false,
  51. "VolumeDriver": "",
  52. "VolumesFrom": null,
  53. "CapAdd": null,
  54. "CapDrop": null,
  55. "CgroupnsMode": "host",
  56. "Dns": [],
  57. "DnsOptions": [],
  58. "DnsSearch": [],
  59. "ExtraHosts": null,
  60. "GroupAdd": null,
  61. "IpcMode": "private",
  62. "Cgroup": "",
  63. "Links": null,
  64. "OomScoreAdj": 0,
  65. "PidMode": "",
  66. "Privileged": false,
  67. "PublishAllPorts": false,
  68. "ReadonlyRootfs": false,
  69. "SecurityOpt": null,
  70. "UTSMode": "",
  71. "UsernsMode": "",
  72. "ShmSize": 67108864,
  73. "Runtime": "runc",
  74. "ConsoleSize": [
  75. 0,
  76. 0
  77. ],
  78. "Isolation": "",
  79. "CpuShares": 0,
  80. "Memory": 0,
  81. "NanoCpus": 0,
  82. "CgroupParent": "",
  83. "BlkioWeight": 0,
  84. "BlkioWeightDevice": [],
  85. "BlkioDeviceReadBps": null,
  86. "BlkioDeviceWriteBps": null,
  87. "BlkioDeviceReadIOps": null,
  88. "BlkioDeviceWriteIOps": null,
  89. "CpuPeriod": 0,
  90. "CpuQuota": 0,
  91. "CpuRealtimePeriod": 0,
  92. "CpuRealtimeRuntime": 0,
  93. "CpusetCpus": "",
  94. "CpusetMems": "",
  95. "Devices": [],
  96. "DeviceCgroupRules": null,
  97. "DeviceRequests": null,
  98. "KernelMemory": 0,
  99. "KernelMemoryTCP": 0,
  100. "MemoryReservation": 0,
  101. "MemorySwap": 0,
  102. "MemorySwappiness": null,
  103. "OomKillDisable": false,
  104. "PidsLimit": null,
  105. "Ulimits": null,
  106. "CpuCount": 0,
  107. "CpuPercent": 0,
  108. "IOMaximumIOps": 0,
  109. "IOMaximumBandwidth": 0,
  110. "MaskedPaths": [
  111. "/proc/asound",
  112. "/proc/acpi",
  113. "/proc/kcore",
  114. "/proc/keys",
  115. "/proc/latency_stats",
  116. "/proc/timer_list",
  117. "/proc/timer_stats",
  118. "/proc/sched_debug",
  119. "/proc/scsi",
  120. "/sys/firmware"
  121. ],
  122. "ReadonlyPaths": [
  123. "/proc/bus",
  124. "/proc/fs",
  125. "/proc/irq",
  126. "/proc/sys",
  127. "/proc/sysrq-trigger"
  128. ]
  129. },
  130. "GraphDriver": { # 其他配置
  131. "Data": {
  132. "LowerDir": "/var/lib/docker/overlay2/ed38d7c2061c4ebc46138b1e181e8286c0ca9242292945be7e2d4a9cef77eb48-init/diff:/var/lib/docker/overlay2/03139488f80fb2bbb139709a63d45233d63ef0258452b719b74f23e78a6aca7c/diff",
  133. "MergedDir": "/var/lib/docker/overlay2/ed38d7c2061c4ebc46138b1e181e8286c0ca9242292945be7e2d4a9cef77eb48/merged",
  134. "UpperDir": "/var/lib/docker/overlay2/ed38d7c2061c4ebc46138b1e181e8286c0ca9242292945be7e2d4a9cef77eb48/diff",
  135. "WorkDir": "/var/lib/docker/overlay2/ed38d7c2061c4ebc46138b1e181e8286c0ca9242292945be7e2d4a9cef77eb48/work"
  136. },
  137. "Name": "overlay2"
  138. },
  139. "Mounts": [], # 挂载
  140. "Config": { # 基本配置
  141. "Hostname": "c3d59f55d600",
  142. "Domainname": "",
  143. "User": "",
  144. "AttachStdin": false,
  145. "AttachStdout": false,
  146. "AttachStderr": false,
  147. "Tty": false,
  148. "OpenStdin": false,
  149. "StdinOnce": false,
  150. "Env": [ # 基本环境变量
  151. "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
  152. ],
  153. "Cmd": [ # 基本命令
  154. "/bin/sh",
  155. "-c",
  156. "while true;do echo sail;sleep 3;done"
  157. ],
  158. "Image": "centos",
  159. "Volumes": null,
  160. "WorkingDir": "",
  161. "Entrypoint": null,
  162. "OnBuild": null,
  163. "Labels": {
  164. "org.label-schema.build-date": "20210915",
  165. "org.label-schema.license": "GPLv2",
  166. "org.label-schema.name": "CentOS Base Image",
  167. "org.label-schema.schema-version": "1.0",
  168. "org.label-schema.vendor": "CentOS"
  169. }
  170. },
  171. "NetworkSettings": { # 网卡设置
  172. "Bridge": "",
  173. "SandboxID": "421b87a4fcfaff65125a707b61b1ba88aa9fc731c452a66f8f1731131721a90a",
  174. "HairpinMode": false,
  175. "LinkLocalIPv6Address": "",
  176. "LinkLocalIPv6PrefixLen": 0,
  177. "Ports": {},
  178. "SandboxKey": "/var/run/docker/netns/421b87a4fcfa",
  179. "SecondaryIPAddresses": null,
  180. "SecondaryIPv6Addresses": null,
  181. "EndpointID": "3c3fce24d19469194202087ff3fe08135ebdc969773c75300c54db4190609467",
  182. "Gateway": "172.17.0.1",
  183. "GlobalIPv6Address": "",
  184. "GlobalIPv6PrefixLen": 0,
  185. "IPAddress": "172.17.0.4",
  186. "IPPrefixLen": 16,
  187. "IPv6Gateway": "",
  188. "MacAddress": "02:42:ac:11:00:04",
  189. "Networks": {
  190. "bridge": { # 桥接类型网卡
  191. "IPAMConfig": null,
  192. "Links": null,
  193. "Aliases": null,
  194. "NetworkID": "f3eeb014197a66bb6d740738f4e8148db7f8cb6c0b7432e429ff61a0cf5e0b06",
  195. "EndpointID": "3c3fce24d19469194202087ff3fe08135ebdc969773c75300c54db4190609467",
  196. "Gateway": "172.17.0.1",
  197. "IPAddress": "172.17.0.4",
  198. "IPPrefixLen": 16,
  199. "IPv6Gateway": "",
  200. "GlobalIPv6Address": "",
  201. "GlobalIPv6PrefixLen": 0,
  202. "MacAddress": "02:42:ac:11:00:04",
  203. "DriverOpts": null
  204. }
  205. }
  206. }
  207. }
  208. ]

不管容器是否运行,都可以使用该命令查看。

进入正在运行的容器

容器是一个微型的 Linux 系统,我们通常需要进入容器进行操作。

docker exec

使用 docker exec 可以进入容器并开启一个新的终端,可以在里面操作。

语法

  1. docker exec [参数] 容器 路径

参数

  • -d:后台运行。
  • -it:交互模式进入。
  1. [root@sail ~]# docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. 96ed3fe3e7f1 centos "/bin/bash" 15 hours ago Up 15 hours centos01
  1. [root@sail ~]# docker exec -it 96ed3fe3e7f1 /bin/bash
  2. [root@96ed3fe3e7f1 /]# ls
  3. bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var
  1. [root@96ed3fe3e7f1 /]# ps -ef
  2. UID PID PPID C STIME TTY TIME CMD
  3. root 1 0 0 Dec09 pts/0 00:00:00 /bin/bash
  4. root 15 0 0 03:38 pts/1 00:00:00 /bin/bash
  5. root 30 15 0 03:39 pts/1 00:00:00 ps -ef

这种进入方式是单独开了一个新进程的方式。

docker attach

使用 docker attach 会进入容器正在执行的终端,不会启动新的进程。

语法

  1. docker attach 容器
  1. [root@sail ~]# docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. 96ed3fe3e7f1 centos "/bin/bash" 17 hours ago Up 17 hours centos01
  1. [root@sail ~]# docker attach 96ed3fe3e7f1
  2. [root@96ed3fe3e7f1 /]# ps -ef
  3. UID PID PPID C STIME TTY TIME CMD
  4. root 1 0 0 Dec09 pts/0 00:00:00 /bin/bash
  5. root 33 1 0 05:49 pts/0 00:00:00 ps -ef

这种进入方式没有开启新的进程(/bin/bash 是 centos 容器的默认终端)。

从容器内拷贝文件到主机

查看启动的容器

  1. [root@sail ~]# docker ps
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. 96ed3fe3e7f1 centos "/bin/bash" 17 hours ago Up 17 hours centos01

进入容器,创建一个文件

  1. [root@sail ~]# docker attach 96ed3fe3e7f1
  2. [root@96ed3fe3e7f1 /]# cd /home
  3. [root@96ed3fe3e7f1 home]# touch test.java
  4. [root@96ed3fe3e7f1 home]# ls
  5. test.java
  6. [root@96ed3fe3e7f1 home]# exit
  7. exit

退出容器后,不管容器是否启动,都可以复制容器中的文件到主机上

  1. [root@sail ~]# cd /home
  2. [root@sail home]# docker cp 96ed3fe3e7f1:/home/test.java /home
  3. [root@sail home]# ls
  4. admin f2 f3 sail test.java

这种方式是一个手动过程,很不方便,推荐使用数据卷技术,可以实现自动同步主机和容器的目录。

详情见:Docker 12 数据卷

查看Docker内存占用

docker stats

语法

  1. docker stats [参数] [容器...]

参数

  • -a:查看所有容器的内存占用(默认只展示运行的容器)。
  1. [root@sail home]# docker stats
  2. CONTAINER ID NAME CPU % MEM USAGE / LIMIT MEM % NET I/O BLOCK I/O PIDS
  3. 96ed3fe3e7f1 centos01 0.00% 524KiB / 1.694GiB 0.03% 0B / 0B 0B / 0B 1
  1. [root@sail home]# docker stats -a
  2. CONTAINER ID NAME CPU % MEM USAGE / LIMIT MEM % NET I/O BLOCK I/O PIDS
  3. 0aee6f74b913 brave_rosalind 0.00% 0B / 0B 0.00% 0B / 0B 0B / 0B 0
  4. c3d59f55d600 musing_poincare 0.00% 0B / 0B 0.00% 0B / 0B 0B / 0B 0
  5. 569026bc0955 centos03 0.00% 0B / 0B 0.00% 0B / 0B 0B / 0B 0
  6. 71a97b830ec5 centos02 0.00% 0B / 0B 0.00% 0B / 0B 0B / 0B 0
  7. 96ed3fe3e7f1 centos01 0.00% 524KiB / 1.694GiB 0.03% 0B / 0B 0B / 0B 1

Docker 05 常用命令的更多相关文章

  1. Docker Kubernetes 常用命令

    Docker Kubernetes 常用命令 增 # 通过文件名或标准输入创建资源. kubectl create # 读取指定文件内容,进行创建.(配置文件可指定json,yaml文件). kube ...

  2. Docker(二十二)-Docker Swarm常用命令

    #查看集群节点 docker node ls #创建nginx服务 #docker pull hub.test.com:5000/almi/nginx:0.1 #下载私有仓库镜像 docker ser ...

  3. Dockerfile指令及docker的常用命令

    DockerfileFROM: FROM <image> FROM <image>:<tag> MAINTAINER: MAINTAINER <name> ...

  4. Docker Swarm常用命令

    #查看集群节点 docker node ls #创建nginx服务 #docker pull hub.test.com:5000/almi/nginx:0.1 #下载私有仓库镜像 docker ser ...

  5. Docker学习(三)认识Docker和常用命令

    Docker学习(三)认识Docker和常用命令 Docker体系结构 docker服务端,作为服务的提供方,核心进程 docker daemon,所有docker命令都是通过这个进程完成的 REST ...

  6. 【Docker入门】Docker的常用命令

    ​ ​ 了解和安装完docker之后,我们学习一下docker的常用命令就和当初学linux命令一样,放心命令其实大致相同只不过细节不同. 一.Docker启动类命令 1.启动docker:syste ...

  7. docker 初试---常用命令

    http://blog.csdn.net/wsscy2004/article/details/25878363 常用命令 查看容器的root用户密码 docker logs <容器名orID&g ...

  8. Docker之常用命令(二)

    这篇博客就不扯皮了,简单粗暴地贴上自己整理的一份Docker常用命令. docker search ** // 查找镜像 docker pull nginx // 载入镜像 # -a 拉取所有tagg ...

  9. Docker:常用命令大全 [七]

    一.docker的命令的解释 1.命令解释 docker run -d -p 80:80 nginx run (创建并运行一个容器) -d 放在后台 -p 端口映射 nginx docker镜像的名字 ...

随机推荐

  1. ARM学习1

    ARM相关概念 1.ARM的发展史 1. 1978年,CPU公司 Cambridge processing Unit 2. 1979年 Acorn 3. 1985年, 32位,8MHz, 使用的精简指 ...

  2. 怎样生成分布式的流水ID

    流水编号 日常在我们开发的过程中可能会用到编号的功能,如销售订单号,采购订单号,日志编号,凭证号...等等,为了保证唯一有些表的主键要么用自增长,要么用GUID值,或通过雪花ID算法生成.这此方式基本 ...

  3. java基础题(5)

    6.常用API 6.1string类 1.动态字符串 描述 将一个由英文字母组成的字符串转换成从末尾开始每三个字母用逗号分隔的形式. 输入描述: 一个字符串 输出描述: 修改后的字符串 示例1 输入: ...

  4. React项目中使用less/scss&全局样式/变量

    使用create-react-app脚手架搭建初始化项目 > npm install -g create-react-app > npx create-react-app my-app c ...

  5. GDOI 2021 普及组溺水记

    Day 1 T1 一看样例:答案不就是 \(\dfrac{\max_{i=1}^n a_i +1}{2}\) 吗? 于是自信打上,拍都不拍.然后就,,对了? 插曲:自己出了一个极端数据,发现 scan ...

  6. pytorch自定义模型时实现父类构造函数的问题

    问题 有的类继承nn.Module在init函数里面是super(类名, self).init():但是有的里面就是super().init() exp: · 解答: python2与python3的 ...

  7. Java-调用R语言和调用Python(前后端展示)

    1. 背景 R语言和Python用于数据分析和数据处理,并生成相应的直方图和散点图 需要实现一个展示平台,后端使用Java,分别调用R语言和调用Python,并返回数据和图给前端显示 这个平台主要实现 ...

  8. 解决Invalid bound statement (not found)的异常

    今天在搭建框架的时候,报了一个Invalid bound statement (not found)的异常 经过分析,得出原因: 我的mybatis相关的dao和mapper.xml是通过逆向工程生成 ...

  9. Spring框架系列(7) - Spring IOC实现原理详解之IOC初始化流程

    上文,我们看了IOC设计要点和设计结构:紧接着这篇,我们可以看下源码的实现了:Spring如何实现将资源配置(以xml配置为例)通过加载,解析,生成BeanDefination并注册到IoC容器中的. ...

  10. 网络通讯之Socket-Tcp(一)

    网络通讯之Socket-Tcp  分成3部分讲解: 网络通讯之Socket-Tcp(一): 1.如何理解Socket 2.Socket通信重要函数 网络通讯之Socket-Tcp(二): 1.简单So ...