1 | docker
|
2 | ===
|
3 |
|
4 | 容器化技术,可以将应用程序及其依赖项打包到一个可移植的容器中,使其可以在不同的环境中运行
|
5 |
|
6 | ## 补充说明
|
7 |
|
8 | Docker 容器可以快速部署、可移植、可扩展,并且可以在不同的平台上运行。Docker 可以帮助开发人员和运维人员更轻松地构建、发布和管理应用程序。
|
9 |
|
10 | ## 安装
|
11 |
|
12 | 在 Linux 中输入以下命令安装 Docker。
|
13 |
|
14 | ```bash
|
15 | # CentOS 参考:https://blog.csdn.net/zhaoyuanh/article/details/126610347
|
16 | #如果系统里有旧版本docker的话需要先行删除:
|
17 | sudo 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 | #设置仓库:
|
27 | yum install -y yum-utils
|
28 |
|
29 | #添加Docker仓库:
|
30 | yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
|
31 |
|
32 | #安装Docker引擎(默认最新):
|
33 | yum install docker-ce docker-ce-cli containerd.io docker-compose-plugin
|
34 |
|
35 | #启动docker:
|
36 | sudo systemctl start docker
|
37 |
|
38 | ```
|
39 |
|
40 | ## 语法
|
41 |
|
42 | ```shell
|
43 | docker create [options] IMAGE
|
44 | ```
|
45 |
|
46 | ## 选项参数
|
47 |
|
48 | ```shell
|
49 | attach 将本地标准输入、输出和错误流附加到正在运行的容器
|
50 | build 从 Dockerfile 构建镜像
|
51 | commit 从容器的更改创建新镜像
|
52 | cp 在容器和本地文件系统之间复制文件/文件夹
|
53 | create 创建一个新容器
|
54 | diff 检查容器文件系统上文件或目录的更改
|
55 | events 从服务器获取实时事件
|
56 | exec 在正在运行的容器中运行命令
|
57 | export 将容器的文件系统导出为 tar 存档
|
58 | history 显示镜像的历史
|
59 | images 列出镜像
|
60 | import 从 tarball 导入内容以创建文件系统映像
|
61 | info 显示系统范围的信息
|
62 | inspect 返回有关 Docker 对象的低级信息
|
63 | kill 杀死一个或多个正在运行的容器
|
64 | load 从 tar 存档或 STDIN 加载镜像
|
65 | login 登录到 Docker 注册表
|
66 | logout 从 Docker 注册表中注销
|
67 | logs 获取容器的日志
|
68 | pause 暂停一个或多个容器内的所有进程
|
69 | port 列出容器的端口映射或特定映射
|
70 | ps 列出容器
|
71 | pull 从注册表中提取镜像或存储库
|
72 | push 将镜像或存储库推送到注册表
|
73 | rename 重命名容器
|
74 | restart 重启一个或多个容器
|
75 | rm 移除一个或多个容器
|
76 | rmi 移除一张或多张镜像
|
77 | run 在新容器中运行命令
|
78 | save 将一个或多个镜像保存到 tar 存档(默认流式传输到 STDOUT)
|
79 | search 在 Docker Hub 中搜索镜像
|
80 | start 启动一个或多个停止的容器
|
81 | stats 显示容器资源使用统计的实时流
|
82 | stop 停止一个或多个正在运行的容器
|
83 | tag 创建一个引用 SOURCE_IMAGE 的标记 TARGET_IMAGE
|
84 | top 显示容器的运行进程
|
85 | unpause 取消暂停一个或多个容器中的所有进程
|
86 | update 更新一个或多个容器的配置
|
87 | version 显示 Docker 版本信息
|
88 | wait 阻塞直到一个或多个容器停止,然后打印它们的退出代码
|
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 |
|
194 | 1、下载docker hub镜像市场中的镜像。
|
195 |
|
196 | ```bash
|
197 | docker pull user/image
|
198 | ```
|
199 |
|
200 | 2、在 docker hub 中搜索镜像。
|
201 |
|
202 | ```bash
|
203 | # 注意需要下载镜像才能使用
|
204 | docker search search_word
|
205 | ```
|
206 |
|
207 | 3、向 docker hub 进行身份验证。
|
208 |
|
209 | ```bash
|
210 | docker login
|
211 | ```
|
212 |
|
213 | 4、将镜像上传到 docker hub。
|
214 |
|
215 | ```bash
|
216 | docker push user/image
|
217 | ```
|
218 |
|
219 |
|
220 | ## docker network
|
221 | ## 语法
|
222 |
|
223 | ```
|
224 | docker network [COMMAND]
|
225 | ```
|
226 |
|
227 | ## COMMAND
|
228 |
|
229 | ### docker network connect
|
230 | 将容器连接到网络。您可以按名称或ID连接容器。连接后,容器可以与同一网络中的其他容器通信。
|
231 |
|
232 | ```shell
|
233 | docker 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
|
251 | docker network disconnect [OPTIONS] NETWORK CONTAINER
|
252 | ```
|
253 |
|
254 | #### 选项参数
|
255 |
|
256 | ```shell
|
257 | -f,--force 强制容器断开网络连接
|
258 | ```
|
259 |
|
260 | ### docker network create
|
261 | 创建一个新的网络
|
262 |
|
263 | ```shell
|
264 | docker 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
|
292 | docker 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
|
306 | docker 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
|
322 | docker network prune [OPTIONS]
|
323 | ```
|
324 |
|
325 | #### 选项参数
|
326 |
|
327 | ```shell
|
328 | --filter 提供过滤器值(例如'until =')
|
329 | -f,--force 不提示确认
|
330 | ```
|
331 | ### docker network rm
|
332 | 按名称或标识符删除一个或多个网络。要删除网络,必须首先断开连接到它的所有容器。
|
333 |
|
334 | ```shell
|
335 | docker network rm NETWORKID [NETWORKID...]
|
336 | ```
|
337 |
|
338 | ## 官网
|
339 |
|
340 | 更多安装使用方法可以访问学习:https://wangchujiang.com/reference/docs/docker.html
|
341 | 由上海 屠天煜编写
|