UNPKG

13.3 kBMarkdownView Raw
1docker
2===
3
4容器化技术,可以将应用程序及其依赖项打包到一个可移植的容器中,使其可以在不同的环境中运行
5
6## 补充说明
7
8Docker 容器可以快速部署、可移植、可扩展,并且可以在不同的平台上运行。Docker 可以帮助开发人员和运维人员更轻松地构建、发布和管理应用程序。
9
10## 安装
11
12在 Linux 中输入以下命令安装 Docker。
13
14```bash
15# CentOS 参考:https://blog.csdn.net/zhaoyuanh/article/details/126610347
16#如果系统里有旧版本docker的话需要先行删除:
17sudo yum remove docker \
18 docker-client \
19 docker-client-latest \
20 docker-common \
21 docker-latest \
22 docker-latest-logrotate \
23 docker-logrotate \
24 docker-engine
25
26#设置仓库:
27yum install -y yum-utils
28
29#添加Docker仓库:
30yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
31
32#安装Docker引擎(默认最新):
33yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin
34
35#启动docker:
36sudo systemctl start docker
37
38```
39
40## 语法
41
42```shell
43docker create [options] IMAGE
44```
45
46## 选项参数
47
48```shell
49attach 将本地标准输入、输出和错误流附加到正在运行的容器
50build 从 Dockerfile 构建镜像
51commit 从容器的更改创建新镜像
52cp 在容器和本地文件系统之间复制文件/文件夹
53create 创建一个新容器
54diff 检查容器文件系统上文件或目录的更改
55events 从服务器获取实时事件
56exec 在正在运行的容器中运行命令
57export 将容器的文件系统导出为 tar 存档
58history 显示镜像的历史
59images 列出镜像
60import 从 tarball 导入内容以创建文件系统映像
61info 显示系统范围的信息
62inspect 返回有关 Docker 对象的低级信息
63kill 杀死一个或多个正在运行的容器
64load 从 tar 存档或 STDIN 加载镜像
65login 登录到 Docker 注册表
66logout 从 Docker 注册表中注销
67logs 获取容器的日志
68pause 暂停一个或多个容器内的所有进程
69port 列出容器的端口映射或特定映射
70ps 列出容器
71pull 从注册表中提取镜像或存储库
72push 将镜像或存储库推送到注册表
73rename 重命名容器
74restart 重启一个或多个容器
75rm 移除一个或多个容器
76rmi 移除一张或多张镜像
77run 在新容器中运行命令
78save 将一个或多个镜像保存到 tar 存档(默认流式传输到 STDOUT)
79search 在 Docker Hub 中搜索镜像
80start 启动一个或多个停止的容器
81stats 显示容器资源使用统计的实时流
82stop 停止一个或多个正在运行的容器
83tag 创建一个引用 SOURCE_IMAGE 的标记 TARGET_IMAGE
84top 显示容器的运行进程
85unpause 取消暂停一个或多个容器中的所有进程
86update 更新一个或多个容器的配置
87version 显示 Docker 版本信息
88wait 阻塞直到一个或多个容器停止,然后打印它们的退出代码
89
90<环境参数>
91 --add-host list # 添加自定义主机到 IP 映射 (host:ip)
92-a, --attach list # 连接到 STDIN、STDOUT 或 STDERR
93 --blkio-weight uint16 # 块 IO(相对权重),介于 10 和 1000 之间,或 0 禁用(默认 0)
94 --blkio-weight-device list # 块 IO 权重(相对设备权重)(默认 [])
95 --cap-add list # 添加 Linux 功能
96 --cap-drop list # 放弃 Linux 功能
97 --cgroup-parent string # 容器的可选父 cgroup
98 --cgroupns string # 要使用的 Cgroup 命名空间(主机|私有)
99 # 'host': 在 Docker 主机的 cgroup 命名空间中运行容器
100 # 'private': 在自己的私有 cgroup 命名空间中运行容器
101 # '': 使用由守护进程上的
102 # default-cgroupns-mode 选项配置的 cgroup 命名空间(默认)
103 --cidfile string # 将容器 ID 写入文件
104 --cpu-period int # 限制 CPU CFS(完全公平调度器)周期
105 --cpu-quota int # 限制 CPU CFS(完全公平调度器)配额
106 --cpu-rt-period int # 以微秒为单位限制 CPU 实时周期
107 --cpu-rt-runtime int # 以微秒为单位限制 CPU 实时运行时间
108-c, --cpu-shares int # CPU 份额(相对权重)
109 --cpus decimal # CPU 数量
110 --cpuset-cpus string # 允许执行的 CPU (0-3, 0,1)
111 --cpuset-mems string # 允许执行的 MEM (0-3, 0,1)
112 --device list # 将主机设备添加到容器
113 --device-cgroup-rule list # 将规则添加到 cgroup 允许的设备列表
114 --device-read-bps list # 限制设备的读取速率(每秒字节数)(默认 [])
115 --device-read-iops list # 限制设备的读取速率(每秒 IO)(默认 [])
116 --device-write-bps list # 限制设备的写入速率(每秒字节数)(默认 [])
117 --device-write-iops list # 限制设备的写入速率(每秒 IO)(默认 [])
118 --disable-content-trust # 跳过镜像验证(默认为 true)
119 --dns list # 设置自定义 DNS 服务器
120 --dns-option list # 设置 DNS 选项
121 --dns-search list # 设置自定义 DNS 搜索域
122 --domainname string # 容器 NIS 域名
123 --entrypoint string # 覆盖镜像的默认入口点
124-e, --env list # 设置环境变量
125 --env-file list # 读入环境变量文件
126 --expose list # 公开一个端口或一系列端口
127 --gpus gpu-request # 要添加到容器中的 GPU 设备(“全部”以传递所有 GPU)
128 --group-add list # 添加其他组以加入
129 --health-cmd string # 运行以检查运行状况的命令
130 --health-interval duration # 运行检查之间的时间 (ms|s|m|h) (默认 0s)
131 --health-retries int # 需要报告不健康的连续失败
132 --health-start-period duration # 开始健康重试倒计时之前容器初始化的开始时间(ms|s|m|h)(默认 0s)
133 --health-timeout duration # 允许运行一项检查的最长时间 (ms|s|m|h) (默认 0s)
134 --help # 打印使用
135-h, --hostname string # 容器主机名
136 --init # 在容器内运行一个 init 来转发信号并收获进程
137-i, --interactive # 即使没有连接,也保持 STDIN 打开
138 --ip string # IPv4 地址(例如 172.30.100.104)
139 --ip6 string # IPv6 地址(例如,2001:db8::33)
140 --ipc string # 要使用的 IPC 模式
141 --isolation string # 容器隔离技术
142 --kernel-memory bytes # 内核内存限制
143-l, --label list # 在容器上设置元数据
144 --label-file list # 读入以行分隔的标签文件
145 --link list # 添加到另一个容器的链接
146 --link-local-ip list # 容器 IPv4/IPv6 链路本地地址
147 --log-driver string # 容器的日志记录驱动程序
148 --log-opt list # 日志驱动程序选项
149 --mac-address string # 容器 MAC 地址(例如 92:d0:c6:0a:29:33)
150-m, --memory bytes # 内存限制
151 --memory-reservation bytes # 内存软限制
152 --memory-swap bytes # 交换限制等于内存加上交换:'-1' 启用无限交换
153 --memory-swappiness int # 调整容器内存交换(0 到 100)(默认 -1)
154 --mount mount # 将文件系统挂载附加到容器
155 --name string # 为容器分配名称
156 --network network # 将容器连接到网络
157 --network-alias list # 为容器添加网络范围的别名
158 --no-healthcheck # 禁用任何容器指定的 HEALTHCHECK
159 --oom-kill-disable # 禁用 OOM 杀手
160 --oom-score-adj int # 调整主机的 OOM 首选项(-1000 到 1000)
161 --pid string # 要使用的 PID 命名空间
162 --pids-limit int # 调整容器 pids 限制(设置 -1 表示无限制)
163 --platform string # 如果服务器支持多平台,则设置平台
164 --privileged # 授予此容器扩展权限
165-p, --publish list # 将容器的端口发布到主机
166-P, --publish-all # 将所有暴露的端口发布到随机端口
167 --pull string # 创建前拉取镜像("always"|"missing"|"never")(默认"missing")
168 --read-only # 将容器的根文件系统挂载为只读
169 --restart string # 容器退出时应用的重启策略(默认“否”)
170 --rm # 容器退出时自动移除
171 --runtime string # 用于此容器的运行时
172 --security-opt list # 安全选项
173 --shm-size bytes # /dev/shm 的大小
174 --stop-signal string # 停止容器的信号(默认“SIGTERM”)
175 --stop-timeout int # 停止容器的超时(以秒为单位)
176 --storage-opt list # 容器的存储驱动程序选项
177 --sysctl map # Sysctl 选项(默认 map[])
178 --tmpfs list # 挂载 tmpfs 目录
179-t, --tty # 分配一个伪 TTY
180 --ulimit ulimit # ulimit 选项(默认 [])
181-u, --user string # 用户名或 UID(格式:<name|uid>[:<group|gid>])
182 --userns string # 要使用的用户命名空间
183 --uts string # 要使用的 UTS 命名空间
184-v, --volume list # 绑定挂载卷
185 --volume-driver string # 容器的可选卷驱动程序
186 --volumes-from list # 从指定容器挂载卷
187-w, --workdir string # 容器内的工作目录
188```
189
190## 实例
191
192介绍几个常用场景:Docker Hub镜像市场相关,镜像仓库命令。
193
1941、下载docker hub镜像市场中的镜像。
195
196```bash
197docker pull user/image
198```
199
2002、在 docker hub 中搜索镜像。
201
202```bash
203# 注意需要下载镜像才能使用
204docker search search_word
205```
206
2073、向 docker hub 进行身份验证。
208
209```bash
210docker login
211```
212
2134、将镜像上传到 docker hub。
214
215```bash
216docker push user/image
217```
218
219
220## docker network
221## 语法
222
223```
224docker network [COMMAND]
225```
226
227## COMMAND
228
229### docker network connect
230将容器连接到网络。您可以按名称或ID连接容器。连接后,容器可以与同一网络中的其他容器通信。
231
232```shell
233docker network connect [OPTIONS] NETWORK CONTAINER
234```
235
236#### 选项参数
237
238```shell
239--alias 为容器添加网络范围的别名
240--driver-opt 网络的驱动程序选项
241--ip IPv4地址(例如172.30.100.104)
242--ip6 IPv6地址(例如2001:db8 :: 33)
243--link 将链接添加到另一个容器(建议不用,后期应该会删除的)
244--link-local-ip 为容器添加本地链接地址
245```
246
247### docker network disconnect
248断开容器与网络的连接
249
250```shell
251docker network disconnect [OPTIONS] NETWORK CONTAINER
252```
253
254#### 选项参数
255
256```shell
257-f,--force 强制容器断开网络连接
258```
259
260### docker network create
261创建一个新的网络
262
263```shell
264docker network create [OPTIONS] NETWORK
265```
266
267#### 选项参数
268
269```shell
270--attachable API 1.25+启用手动容器附件
271--aux-address 网络驱动程序使用的辅助IPv4或IPv6地址
272--config-from API 1.30+从中复制配置的网络
273--config-only API 1.30+创建仅配置网络
274-d,--driver bridge 驱动程序来管理网络
275--gateway 主子网的IPv4或IPv6网关
276--ingress API 1.29+创建群集路由网状网络
277--internal 限制外部访问网络
278--ip-range 从子范围分配容器ip
279--ipam-driver IP地址管理驱动程序
280--ipam-opt 设置IPAM驱动程序特定选项
281--ipv6 启用IPv6网络
282--label 在网络上设置元数据
283-o,--opt 设置驱动程序特定选项
284--scope API 1.30+控制网络范围
285--subnet 代表网段的CIDR格式的子网
286```
287
288### docker network inspect
289返回有关一个或多个网络的信息。默认情况下,此命令将所有结果呈现在JSON对象中。
290
291```shell
292docker network inspect [OPTIONS] NETWORK [NETWORK...]
293```
294
295#### 选项参数
296
297```shell
298-f,--format 使用给定的Go模板格式化输出
299-v,--verbose 详细输出以进行诊断
300```
301
302### docker network ls
303列出引擎daemon知道的所有网络。这包括跨群集中多个主机的网络
304
305```shell
306docker network ls [OPTIONS]
307```
308
309#### 选项参数
310
311```shell
312-f,--filter 提供过滤器值(例如"driver = bridge")
313--format 使用Go模板的精美印刷网络
314--no-trunc 不要截断输出
315-q,--quiet 仅显示网络ID
316```
317
318### docker network prune
319删除所有未使用的网络。未使用的网络是未被任何正在使用的容器引用的网络()。
320
321```shell
322docker network prune [OPTIONS]
323```
324
325#### 选项参数
326
327```shell
328--filter 提供过滤器值(例如'until =')
329-f,--force 不提示确认
330```
331### docker network rm
332按名称或标识符删除一个或多个网络。要删除网络,必须首先断开连接到它的所有容器。
333
334```shell
335docker network rm NETWORKID [NETWORKID...]
336```
337
338## 官网
339
340更多安装使用方法可以访问学习:https://wangchujiang.com/reference/docs/docker.html
341由上海 屠天煜编写