Files
reference/docs/docker-compose.html
2025-05-11 17:34:02 +00:00

606 lines
72 KiB
HTML
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!doctype html>
<html lang="en" data-color-mode="dark">
<head>
<meta charset="utf-8">
<title>Docker Compose 备忘清单
&#x26; docker-compose cheatsheet &#x26; Quick Reference</title>
<meta content="width=device-width, initial-scale=1" name="viewport">
<meta description="这是 docker-compose 的快速参考备忘单。你可以在这里找到最常见的 Docker Compose 使用方式。
入门,为开发人员分享快速参考备忘单。">
<meta keywords="docker-compose,reference,Quick,Reference,cheatsheet,cheat,sheet">
<meta name="author" content="jaywcjlove">
<meta name="license" content="MIT">
<meta name="funding" content="https://jaywcjlove.github.io/#/sponsor">
<meta rel="apple-touch-icon" href="../icons/touch-icon-iphone.png">
<meta rel="apple-touch-icon" sizes="152x152" href="../icons/touch-icon-ipad.png">
<meta rel="apple-touch-icon" sizes="180x180" href="../icons/touch-icon-iphone.png">
<meta rel="apple-touch-icon" sizes="167x167" href="../icons/touch-icon-ipad-retina.png">
<meta rel="apple-touch-icon" sizes="120x120" href="../icons/touch-icon-iphone-retina.png">
<link rel="icon" href="../icons/favicon.svg" type="image/svg+xml">
<link href="../style/style.css" rel="stylesheet">
<link href="../style/katex.css" rel="stylesheet">
</head>
<body><nav class="header-nav"><div class="max-container"><a href="../index.html" class="logo"><svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg" height="1em" width="1em">
<path d="m21.66 10.44-.98 4.18c-.84 3.61-2.5 5.07-5.62 4.77-.5-.04-1.04-.13-1.62-.27l-1.68-.4c-4.17-.99-5.46-3.05-4.48-7.23l.98-4.19c.2-.85.44-1.59.74-2.2 1.17-2.42 3.16-3.07 6.5-2.28l1.67.39c4.19.98 5.47 3.05 4.49 7.23Z" fill="#c9d1d9"></path>
<path d="M15.06 19.39c-.62.42-1.4.77-2.35 1.08l-1.58.52c-3.97 1.28-6.06.21-7.35-3.76L2.5 13.28c-1.28-3.97-.22-6.07 3.75-7.35l1.58-.52c.41-.13.8-.24 1.17-.31-.3.61-.54 1.35-.74 2.2l-.98 4.19c-.98 4.18.31 6.24 4.48 7.23l1.68.4c.58.14 1.12.23 1.62.27Zm2.43-8.88c-.06 0-.12-.01-.19-.02l-4.85-1.23a.75.75 0 0 1 .37-1.45l4.85 1.23a.748.748 0 0 1-.18 1.47Z" fill="#228e6c"></path>
<path d="M14.56 13.89c-.06 0-.12-.01-.19-.02l-2.91-.74a.75.75 0 0 1 .37-1.45l2.91.74c.4.1.64.51.54.91-.08.34-.38.56-.72.56Z" fill="#228e6c"></path>
</svg>
<span class="title">Quick Reference</span></a><div class="menu"><a href="javascript:void(0);" class="searchbtn" id="searchbtn"><svg xmlns="http://www.w3.org/2000/svg" height="1em" width="1em" viewBox="0 0 18 18">
<path fill="currentColor" d="M17.71,16.29 L14.31,12.9 C15.4069846,11.5024547 16.0022094,9.77665502 16,8 C16,3.581722 12.418278,0 8,0 C3.581722,0 0,3.581722 0,8 C0,12.418278 3.581722,16 8,16 C9.77665502,16.0022094 11.5024547,15.4069846 12.9,14.31 L16.29,17.71 C16.4777666,17.8993127 16.7333625,18.0057983 17,18.0057983 C17.2666375,18.0057983 17.5222334,17.8993127 17.71,17.71 C17.8993127,17.5222334 18.0057983,17.2666375 18.0057983,17 C18.0057983,16.7333625 17.8993127,16.4777666 17.71,16.29 Z M2,8 C2,4.6862915 4.6862915,2 8,2 C11.3137085,2 14,4.6862915 14,8 C14,11.3137085 11.3137085,14 8,14 C4.6862915,14 2,11.3137085 2,8 Z"></path>
</svg><span>搜索</span><span>⌘K</span></a><a href="https://github.com/jaywcjlove/reference/blob/main/docs/docker-compose.md" class="edit" target="__blank"><svg viewBox="0 0 36 36" fill="currentColor" height="1em" width="1em"><path d="m33 6.4-3.7-3.7a1.71 1.71 0 0 0-2.36 0L23.65 6H6a2 2 0 0 0-2 2v22a2 2 0 0 0 2 2h22a2 2 0 0 0 2-2V11.76l3-3a1.67 1.67 0 0 0 0-2.36ZM18.83 20.13l-4.19.93 1-4.15 9.55-9.57 3.23 3.23ZM29.5 9.43 26.27 6.2l1.85-1.85 3.23 3.23Z"></path><path fill="none" d="M0 0h36v36H0z"></path></svg><span>编辑</span></a><button id="darkMode" type="button"><svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="currentColor" class="light" height="1em" width="1em">
<path d="M6.995 12c0 2.761 2.246 5.007 5.007 5.007s5.007-2.246 5.007-5.007-2.246-5.007-5.007-5.007S6.995 9.239 6.995 12zM11 19h2v3h-2zm0-17h2v3h-2zm-9 9h3v2H2zm17 0h3v2h-3zM5.637 19.778l-1.414-1.414 2.121-2.121 1.414 1.414zM16.242 6.344l2.122-2.122 1.414 1.414-2.122 2.122zM6.344 7.759 4.223 5.637l1.415-1.414 2.12 2.122zm13.434 10.605-1.414 1.414-2.122-2.122 1.414-1.414z"></path>
</svg>
<svg xmlns="http://www.w3.org/2000/svg" fill="currentColor" viewBox="0 0 24 24" class="dark" height="1em" width="1em">
<path d="M12 11.807A9.002 9.002 0 0 1 10.049 2a9.942 9.942 0 0 0-5.12 2.735c-3.905 3.905-3.905 10.237 0 14.142 3.906 3.906 10.237 3.905 14.143 0a9.946 9.946 0 0 0 2.735-5.119A9.003 9.003 0 0 1 12 11.807z"></path>
</svg>
</button><script src="../js/dark.js?v=1.8.3"></script><a href="https://github.com/jaywcjlove/reference" class="" target="__blank"><svg viewBox="0 0 16 16" fill="currentColor" height="1em" width="1em"><path d="M8 0C3.58 0 0 3.58 0 8c0 3.54 2.29 6.53 5.47 7.59.4.07.55-.17.55-.38 0-.19-.01-.82-.01-1.49-2.01.37-2.53-.49-2.69-.94-.09-.23-.48-.94-.82-1.13-.28-.15-.68-.52-.01-.53.63-.01 1.08.58 1.23.82.72 1.21 1.87.87 2.33.66.07-.52.28-.87.51-1.07-1.78-.2-3.64-.89-3.64-3.95 0-.87.31-1.59.82-2.15-.08-.2-.36-1.02.08-2.12 0 0 .67-.21 2.2.82.64-.18 1.32-.27 2-.27.68 0 1.36.09 2 .27 1.53-1.04 2.2-.82 2.2-.82.44 1.1.16 1.92.08 2.12.51.56.82 1.27.82 2.15 0 3.07-1.87 3.75-3.65 3.95.29.25.54.73.54 1.48 0 1.07-.01 1.93-.01 2.2 0 .21.15.46.55.38A8.012 8.012 0 0 0 16 8c0-4.42-3.58-8-8-8z"></path></svg></a></div></div></nav><div class="wrap h1body-exist max-container"><header class="wrap-header h1wrap"><h1 id="docker-compose-备忘清单"><svg xmlns="http://www.w3.org/2000/svg" fill="currentColor" viewBox="0 0 640 512" height="1em" width="1em">
<path d="M349.9 236.3h-66.1v-59.4h66.1v59.4zm0-204.3h-66.1v60.7h66.1V32zm78.2 144.8H362v59.4h66.1v-59.4zm-156.3-72.1h-66.1v60.1h66.1v-60.1zm78.1 0h-66.1v60.1h66.1v-60.1zm276.8 100c-14.4-9.7-47.6-13.2-73.1-8.4-3.3-24-16.7-44.9-41.1-63.7l-14-9.3-9.3 14c-18.4 27.8-23.4 73.6-3.7 103.8-8.7 4.7-25.8 11.1-48.4 10.7H2.4c-8.7 50.8 5.8 116.8 44 162.1 37.1 43.9 92.7 66.2 165.4 66.2 157.4 0 273.9-72.5 328.4-204.2 21.4.4 67.6.1 91.3-45.2 1.5-2.5 6.6-13.2 8.5-17.1l-13.3-8.9zm-511.1-27.9h-66v59.4h66.1v-59.4zm78.1 0h-66.1v59.4h66.1v-59.4zm78.1 0h-66.1v59.4h66.1v-59.4zm-78.1-72.1h-66.1v60.1h66.1v-60.1z"></path>
</svg>
<a aria-hidden="true" tabindex="-1" href="#docker-compose-备忘清单"><span class="icon icon-link"></span></a>Docker Compose 备忘清单</h1><div class="wrap-body">
<p>这是 <a href="https://docs.docker.com/compose/">docker-compose</a> 的快速参考备忘单。你可以在这里找到最常见的 Docker Compose 使用方式。</p>
</div></header><div class="menu-tocs"><div class="menu-btn"><svg aria-hidden="true" fill="currentColor" height="1em" width="1em" viewBox="0 0 16 16" version="1.1" data-view-component="true">
<path fill-rule="evenodd" d="M2 4a1 1 0 100-2 1 1 0 000 2zm3.75-1.5a.75.75 0 000 1.5h8.5a.75.75 0 000-1.5h-8.5zm0 5a.75.75 0 000 1.5h8.5a.75.75 0 000-1.5h-8.5zm0 5a.75.75 0 000 1.5h8.5a.75.75 0 000-1.5h-8.5zM3 8a1 1 0 11-2 0 1 1 0 012 0zm-1 6a1 1 0 100-2 1 1 0 000 2z"></path>
</svg></div><div class="menu-modal"><a aria-hidden="true" class="leve2 tocs-link" data-num="2" href="#入门">入门</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#docker-compose-是什么">Docker Compose 是什么?</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#基本概念">基本概念</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#docker-compose-文件结构">Docker-Compose 文件结构</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#安装">安装</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#独立安装-compose">独立安装 Compose</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#更新-compose">更新 Compose</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#卸载-docker-compose">卸载 Docker Compose</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#检查-compose-的安装位置">检查 Compose 的安装位置</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#常用命令">常用命令</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#常用运维命令">常用运维命令</a><a aria-hidden="true" class="leve2 tocs-link" data-num="2" href="#docker-compose-配置">Docker Compose 配置</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#示例配置文件">示例配置文件</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#使用环境变量">使用环境变量</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#额外的信息">额外的信息</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#image">image</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#ports-端口">ports 端口</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#platform-平台">platform 平台</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#command">command</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#depends_on">depends_on</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#volumes">volumes</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#driver">driver</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#driver_opts">driver_opts</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#external">external</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#labels">labels</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#name">name</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#networks">networks</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#aliases">aliases</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#ipv4_address-ipv6_address">ipv4_address, ipv6_address</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#link_local_ips">link_local_ips</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#mac_address">mac_address</a><a aria-hidden="true" class="leve4 tocs-link" data-num="4" href="#priority-优先级">priority 优先级</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#expose">expose</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#links">links</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#pids_limit">pids_limit</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#devices">devices</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#dns">dns</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#dns_opt">dns_opt</a><a aria-hidden="true" class="leve3 tocs-link" data-num="3" href="#dns_search">dns_search</a></div></div><div class="h1wrap-body"><div class="wrap h2body-exist"><div class="wrap-header h2wrap"><h2 id="入门"><a aria-hidden="true" tabindex="-1" href="#入门"><span class="icon icon-link"></span></a>入门</h2><div class="wrap-body">
</div></div><div class="h2wrap-body"><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="docker-compose-是什么"><a aria-hidden="true" tabindex="-1" href="#docker-compose-是什么"><span class="icon icon-link"></span></a>Docker Compose 是什么?</h3><div class="wrap-body">
<ul>
<li><code>Docker-compsoe</code> 是一个开源项目,用于定义和运行多容器 <code>Docker</code> 应用程序的工具。由 <code>Docker</code> 社区维护。</li>
<li>通过一个 <code>YAML</code> 文件来配置应用程序的服务,以便可以使用一个命令启动、停止和重启整个应用程序。</li>
<li><a href="https://github.com/docker/compose">Docker Compose 开源地址</a></li>
<li><a href="https://github.com/docker/compose/releases">Docker Compose 发行地址</a> <em>github.com</em></li>
</ul>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="基本概念"><a aria-hidden="true" tabindex="-1" href="#基本概念"><span class="icon icon-link"></span></a>基本概念</h3><div class="wrap-body">
<ul>
<li><strong>服务 (services):</strong> 一个服务指的是一个容器,即一个应用程序的一个实例。</li>
<li><strong>容器 (container):</strong> <code>Docker</code> 容器,其中运行着应用程序的一个实例。</li>
<li><strong>镜像 (image):</strong> <code>Docker</code> 镜像,用于创建容器的模板。</li>
<li><strong>Docker-Compose 文件:</strong> 一个 <code>YAML</code> 文件,描述了应用程序的各个服务以及它们之间的关系、配置等信息。</li>
</ul>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="docker-compose-文件结构"><a aria-hidden="true" tabindex="-1" href="#docker-compose-文件结构"><span class="icon icon-link"></span></a>Docker-Compose 文件结构</h3><div class="wrap-body">
<ul>
<li><code>version</code>: <em>Docker-Compose</em> 文件的版本。</li>
<li><code>services</code>: 定义了各个服务,每个服务都有自己的配置项,如镜像、端口映射、依赖等。</li>
<li><code>networks</code>: 定义了应用程序使用的网络,可以自定义网络以控制服务之间的通信。</li>
<li><code>volumes</code>: 定义了应用程序使用的卷,用于持久化数据或与主机共享文件。</li>
</ul>
</div></div></div><div class="wrap h3body-not-exist row-span-2"><div class="wrap-header h3wrap"><h3 id="安装"><a aria-hidden="true" tabindex="-1" href="#安装"><span class="icon icon-link"></span></a>安装</h3><div class="wrap-body">
<!--rehype:wrap-class=row-span-2-->
<p>对于 Ubuntu 和 Debian运行</p>
<pre class="language-bash"><code class="language-bash code-highlight"><span class="code-line"><span class="token function">sudo</span> <span class="token function">apt-get</span> update
</span><span class="code-line"><span class="token function">sudo</span> <span class="token function">apt-get</span> <span class="token function">install</span> docker-compose-plugin
</span></code></pre>
<p>对于基于 RPM 的发行版,运行:</p>
<pre class="language-bash"><code class="language-bash code-highlight"><span class="code-line"><span class="token function">sudo</span> yum update
</span><span class="code-line"><span class="token function">sudo</span> yum <span class="token function">install</span> docker-compose-plugin
</span></code></pre>
<p>通过检查版本来验证 Docker Compose 是否正确安装</p>
<pre class="language-sh"><code class="language-sh code-highlight"><span class="code-line"><span class="token function">docker</span> compose version
</span><span class="code-line"><span class="token comment"># Docker Compose version v2.17.3</span>
</span><span class="code-line">
</span><span class="code-line"><span class="token function">docker</span> <span class="token parameter variable">--version</span>
</span><span class="code-line"><span class="token comment"># Docker version 23.0.5, build bc4487a</span>
</span><span class="code-line">
</span><span class="code-line"><span class="token function">docker</span> version
</span><span class="code-line"><span class="token comment"># Client: Docker Engine - Community</span>
</span><span class="code-line"><span class="token comment"># Cloud integration: v1.0.31</span>
</span><span class="code-line"><span class="token comment"># Version: 23.0.5</span>
</span><span class="code-line"><span class="token comment"># API version: 1.42</span>
</span><span class="code-line"><span class="token comment"># &#x3C;...></span>
</span></code></pre>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="独立安装-compose"><a aria-hidden="true" tabindex="-1" href="#独立安装-compose"><span class="icon icon-link"></span></a>独立安装 Compose</h3><div class="wrap-body">
<pre class="wrap-text"><code class="language-sh code-highlight"><span class="code-line"><span class="token function">curl</span> <span class="token parameter variable">-SL</span> https://github.com/docker/compose/releases/download/v2.27.0/docker-compose-linux-x86_64 <span class="token parameter variable">-o</span> /usr/local/bin/docker-compose
</span></code></pre>
<!--rehype:className=wrap-text-->
<p>如果命令 <code>docker-compose</code> 安装失败,请检查你的路径。你也可以创建一个符号链接,指向 <code>/usr/bin</code> 或路径中的任何其他目录。例如</p>
<pre class="wrap-text"><code class="language-sh code-highlight"><span class="code-line">$ <span class="token function">sudo</span> <span class="token function">ln</span> <span class="token parameter variable">-s</span> /usr/local/bin/docker-compose /usr/bin/docker-compose
</span></code></pre>
<!--rehype:className=wrap-text-->
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="更新-compose"><a aria-hidden="true" tabindex="-1" href="#更新-compose"><span class="icon icon-link"></span></a>更新 Compose</h3><div class="wrap-body">
<p>对于 Ubuntu 和 Debian运行</p>
<pre class="language-sh"><code class="language-sh code-highlight"><span class="code-line"><span class="token function">sudo</span> <span class="token function">apt-get</span> update
</span><span class="code-line"><span class="token function">sudo</span> <span class="token function">apt-get</span> <span class="token function">install</span> docker-compose-plugin
</span></code></pre>
<p>对于基于 RPM 的发行版,运行:</p>
<pre class="language-sh"><code class="language-sh code-highlight"><span class="code-line"><span class="token function">sudo</span> yum update
</span><span class="code-line"><span class="token function">sudo</span> yum <span class="token function">install</span> docker-compose-plugin
</span></code></pre>
</div></div></div><div class="wrap h3body-not-exist col-span-2"><div class="wrap-header h3wrap"><h3 id="卸载-docker-compose"><a aria-hidden="true" tabindex="-1" href="#卸载-docker-compose"><span class="icon icon-link"></span></a>卸载 Docker Compose</h3><div class="wrap-body">
<!--rehype:wrap-class=col-span-2-->
<p>Ubuntu, Debian:</p>
<pre class="language-sh"><code class="language-sh code-highlight"><span class="code-line"><span class="token function">sudo</span> <span class="token function">apt-get</span> remove docker-compose-plugin
</span></code></pre>
<p>基于 RPM 的发行版</p>
<pre class="language-sh"><code class="language-sh code-highlight"><span class="code-line"><span class="token function">sudo</span> yum remove docker-compose-plugin
</span></code></pre>
<p>如果您使用curl安装Compose CLI插件要卸载它请运行</p>
<pre class="language-sh"><code class="language-sh code-highlight"><span class="code-line"><span class="token function">rm</span> <span class="token variable">$DOCKER_CONFIG</span>/cli-plugins/docker-compose
</span></code></pre>
<p>为所有用户删除,或者,如果您已为所有用户安装 Compose请运行</p>
<pre class="language-sh"><code class="language-sh code-highlight"><span class="code-line"><span class="token function">rm</span> /usr/local/lib/docker/cli-plugins/docker-compose
</span></code></pre>
</div></div></div><div class="wrap h3body-not-exist col-span-3"><div class="wrap-header h3wrap"><h3 id="检查-compose-的安装位置"><a aria-hidden="true" tabindex="-1" href="#检查-compose-的安装位置"><span class="icon icon-link"></span></a>检查 Compose 的安装位置</h3><div class="wrap-body">
<!--rehype:wrap-class=col-span-3-->
<pre class="language-sh"><code class="language-sh code-highlight"><span class="code-line"><span class="token function">docker</span> info <span class="token parameter variable">--format</span> <span class="token string">'{{range .ClientInfo.Plugins}}{{if eq .Name "compose"}}{{.Path}}{{end}}{{end}}'</span>
</span></code></pre>
</div></div></div><div class="wrap h3body-not-exist col-span-2"><div class="wrap-header h3wrap"><h3 id="常用命令"><a aria-hidden="true" tabindex="-1" href="#常用命令"><span class="icon icon-link"></span></a>常用命令</h3><div class="wrap-body">
<!--rehype:wrap-class=col-span-2-->
<table class="left-align"><thead><tr><th>docker compose命令</th><th>说明</th><th>常见参数说明</th></tr></thead><tbody><tr><td><code>docker compose up</code></td><td>启动容器</td><td><code>-d</code> 后台运行容器</td></tr><tr><td><code>docker compose down</code></td><td>停止容器</td><td><code>-v</code> 删除容器和卷</td></tr><tr><td><code>docker compose logs</code></td><td>查看容器日志</td><td><code>-f</code> 跟随日志输出</td></tr><tr><td><code>docker compose exec</code></td><td>进入容器</td><td><code>-it</code> 启动交互式终端</td></tr><tr><td><code>docker compose pull</code></td><td>拉取镜像</td><td></td></tr><tr><td><code>docker compose build</code></td><td>构建镜像</td><td></td></tr><tr><td><code>docker compose images</code></td><td>列出镜像</td><td></td></tr><tr><td><code>docker compose push</code></td><td>推送镜像</td><td></td></tr><tr><td><code>docker compose config</code></td><td>显示配置信息</td><td></td></tr><tr><td><code>docker compose version</code></td><td>查看版本信息</td><td></td></tr></tbody></table>
<!--rehype:className=left-align-->
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="常用运维命令"><a aria-hidden="true" tabindex="-1" href="#常用运维命令"><span class="icon icon-link"></span></a>常用运维命令</h3><div class="wrap-body">
<table class="left-align"><thead><tr><th>docker compose命令</th><th>说明</th></tr></thead><tbody><tr><td><code>docker compose stop</code></td><td>停止容器</td></tr><tr><td><code>docker compose start</code></td><td>启动容器</td></tr><tr><td><code>docker compose rm</code></td><td>删除容器</td></tr><tr><td><code>docker compose restart</code></td><td>重启容器</td></tr><tr><td><code>docker compose run</code></td><td>运行一个临时容器</td></tr><tr><td><code>docker compose ps</code></td><td>查看容器状态</td></tr></tbody></table>
<!--rehype:className=left-align-->
</div></div></div></div></div><div class="wrap h2body-exist"><div class="wrap-header h2wrap"><h2 id="docker-compose-配置"><a aria-hidden="true" tabindex="-1" href="#docker-compose-配置"><span class="icon icon-link"></span></a>Docker Compose 配置</h2><div class="wrap-body">
</div></div><div class="h2wrap-body"><div class="wrap h3body-not-exist col-span-2"><div class="wrap-header h3wrap"><h3 id="示例配置文件"><a aria-hidden="true" tabindex="-1" href="#示例配置文件"><span class="icon icon-link"></span></a>示例配置文件</h3><div class="wrap-body">
<!--rehype:wrap-class=col-span-2-->
<p><code>docker-compose</code> 的配置文件是一个 <code>YAML</code> 文件,用于定义和运行多容器 Docker 应用程序。通常命名为 <code>docker-compose.yml</code>,它使用单一的 YAML 文件来定义多个容器的集合,以及它们之间的依赖关系和服务。以下是一份 <code>docker-compose.yml</code> 文件的配置模板,包含了常用配置项和解释:</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">name</span><span class="token punctuation">:</span> myapp
</span><span class="code-line"><span class="token key atrule">version</span><span class="token punctuation">:</span> <span class="token string">'3'</span> <span class="token comment"># 已过时</span>
</span><span class="code-line">
</span><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span> <span class="token comment"># 定义一个或多个服务</span>
</span><span class="code-line"> <span class="token key atrule">service1</span><span class="token punctuation">:</span> <span class="token comment"># 服务名称</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> nginx<span class="token punctuation">:</span>latest <span class="token comment"># 使用的 Docker 镜像,这里是 Nginx 的最新版本</span>
</span><span class="code-line"> <span class="token comment"># 或者使用构建指令来从 Dockerfile 构建镜像</span>
</span><span class="code-line"> <span class="token key atrule">build</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">context</span><span class="token punctuation">:</span> ./path/to/Dockerfile <span class="token comment"># Dockerfile 所在的目录</span>
</span><span class="code-line"> <span class="token key atrule">dockerfile</span><span class="token punctuation">:</span> Dockerfile<span class="token punctuation">-</span>alternative <span class="token comment"># 可选的 Dockerfile 名称,默认是 Dockerfile</span>
</span><span class="code-line"> <span class="token comment"># 容器启动时执行的命令,覆盖默认的命令</span>
</span><span class="code-line"> <span class="token key atrule">command</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"nginx"</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"-g"</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"daemon off;"</span> <span class="token comment"># 以数组形式指定,防止 shell 解析</span>
</span><span class="code-line"> <span class="token key atrule">ports</span><span class="token punctuation">:</span> <span class="token comment"># 容器端口与主机端口映射</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"80:80"</span> <span class="token comment"># 主机 80 端口映射到容器的 80 端口</span>
</span><span class="code-line">
</span><span class="code-line"> <span class="token key atrule">volumes</span><span class="token punctuation">:</span> <span class="token comment"># 数据卷挂载</span>
</span><span class="code-line"> <span class="token punctuation">-</span> ./nginx.conf<span class="token punctuation">:</span>/etc/nginx/nginx.conf<span class="token punctuation">:</span>ro <span class="token comment"># 将主机上的 nginx.conf </span>
</span><span class="code-line"> <span class="token comment"># 挂载到容器的 /etc/nginx/nginx.conf只读</span>
</span><span class="code-line"> <span class="token punctuation">-</span> ./logs<span class="token punctuation">:</span>/var/log/nginx <span class="token comment"># 将 logs 目录挂载到容器的 /var/log/nginx</span>
</span><span class="code-line"> <span class="token key atrule">environment</span><span class="token punctuation">:</span> <span class="token comment"># 设置环境变量</span>
</span><span class="code-line"> <span class="token punctuation">-</span> MYSQL_HOST=database <span class="token comment"># 可以引用其他服务,这里假设有一个名为 database 的服务</span>
</span><span class="code-line"> <span class="token punctuation">-</span> MYSQL_PORT=3306
</span><span class="code-line"> <span class="token key atrule">depends_on</span><span class="token punctuation">:</span> <span class="token comment"># 服务启动顺序,这里表明 service1 依赖于 database 服务</span>
</span><span class="code-line"> <span class="token punctuation">-</span> database
</span><span class="code-line"> <span class="token key atrule">networks</span><span class="token punctuation">:</span> <span class="token comment"># 定义网络</span>
</span><span class="code-line"> <span class="token punctuation">-</span> my_network <span class="token comment"># 参与名为 my_network 的网络</span>
</span><span class="code-line">
</span><span class="code-line"> <span class="token key atrule">service2</span><span class="token punctuation">:</span> <span class="token comment"># 另一个服务示例</span>
</span><span class="code-line"> <span class="token comment"># ... 类似地定义其他服务</span>
</span><span class="code-line">
</span><span class="code-line"><span class="token key atrule">networks</span><span class="token punctuation">:</span> <span class="token comment"># 定义网络</span>
</span><span class="code-line"> <span class="token key atrule">my_network</span><span class="token punctuation">:</span> <span class="token comment"># 网络名称</span>
</span><span class="code-line"> <span class="token key atrule">driver</span><span class="token punctuation">:</span> bridge <span class="token comment"># 网络驱动,通常是 bridge 模式</span>
</span><span class="code-line">
</span><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span> <span class="token comment"># 定义数据卷</span>
</span><span class="code-line"> <span class="token key atrule">nginx_logs</span><span class="token punctuation">:</span> <span class="token comment"># 卷名称</span>
</span><span class="code-line">
</span></code></pre>
<p>备忘录事项</p>
<ul>
<li>使用 Docker-Compose 可以简化多容器应用程序的部署和管理,但需要注意容器之间的依赖关系和通信。</li>
<li>配置文件中的缩进必须使用空格,不能使用制表符。</li>
<li>可以使用环境变量来动态设置配置项,如数据库密码。</li>
<li>当你修改了 <code>docker-compose.yml</code> 文件后,需要重新运行 <code>docker-compose up</code> 来使改动生效。</li>
<li>使用 <code>docker-compose build</code> 仅重建镜像,而不启动容器。</li>
<li>使用 <code>docker-compose restart</code> 重启容器。</li>
<li>记得清理不再需要的容器和镜像,以避免磁盘空间不足。</li>
</ul>
</div></div></div><div class="wrap h3body-exist"><div class="wrap-header h3wrap"><h3 id="使用环境变量"><a aria-hidden="true" tabindex="-1" href="#使用环境变量"><span class="icon icon-link"></span></a>使用环境变量</h3><div class="wrap-body">
<p><code>docker run -e VARIABLE=VALUE ...</code> 相同</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">web</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">environment</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> DEBUG=1
</span></code></pre>
<p>您可以选择不设置值并将环境变量从 shell 直接传递到容器。它的工作方式与 <code>docker run -e VARIABLE ...</code> 相同:</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">web</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">environment</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> DEBUG
</span><span class="code-line"><span class="token key atrule">web</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">environment</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> DEBUG=$<span class="token punctuation">{</span>DEBUG<span class="token punctuation">}</span>
</span></code></pre>
<p><code>env_file</code> 属性允许您在 Compose 应用程序中使用多个 <code>.env</code> 文件。
它的工作方式与 <code>docker run --env-file=FILE ...</code> 相同。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">web</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">env_file</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> web<span class="token punctuation">-</span>variables.env
</span></code></pre>
<h4 id="额外的信息"><a aria-hidden="true" tabindex="-1" href="#额外的信息"><span class="icon icon-link"></span></a>额外的信息</h4>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">env_file</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token key atrule">path</span><span class="token punctuation">:</span> ./default.env
</span><span class="code-line"> <span class="token key atrule">required</span><span class="token punctuation">:</span> <span class="token boolean important">true</span> <span class="token comment"># default</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token key atrule">path</span><span class="token punctuation">:</span> ./override.env
</span><span class="code-line"> <span class="token key atrule">required</span><span class="token punctuation">:</span> <span class="token boolean important">false</span>
</span></code></pre>
<ul>
<li>如果指定了多个文件,则它们将按顺序进行评估,可以覆盖先前文件中设置的值。</li>
<li><code>.env</code> 文件中声明的环境变量不能在 Compose 文件中单独再次引用。</li>
<li>如果同时使用 <code>env_file</code><code>environment</code> 属性,则由 <code>environment</code> 设置的环境变量优先级更高。</li>
<li><code>env_file</code> 属性中指定的 <code>.env</code> 文件的路径是相对于 compose.yml 文件的位置的。</li>
<li><code>.env</code> 文件中的值可以通过使用 <code>docker compose run -e</code> 命令行来从命令行覆盖。</li>
<li>如果使用 <code>--env-file</code> 替换了另一个 <code>.env</code>,则您的 <code>.env</code> 文件可以被另一个 <code>.env</code> 文件覆盖。</li>
<li>从 Docker Compose 版本 2.24.0 开始,您可以通过使用 <code>required</code> 字段将 <code>.env</code> 文件设置为可选项。当 <code>required</code> 设置为 <code>false</code><code>.env</code> 文件丢失时Compose 将静默忽略该条目</li>
</ul>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="image"><a aria-hidden="true" tabindex="-1" href="#image"><span class="icon icon-link"></span></a>image</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">image</span><span class="token punctuation">:</span> redis
</span><span class="code-line"><span class="token key atrule">image</span><span class="token punctuation">:</span> redis<span class="token punctuation">:</span><span class="token number">5</span>
</span><span class="code-line"><span class="token key atrule">image</span><span class="token punctuation">:</span> redis@sha256<span class="token punctuation">:</span>0ed5d5928d473745<span class="token punctuation">...</span>
</span><span class="code-line"><span class="token key atrule">image</span><span class="token punctuation">:</span> library/redis
</span><span class="code-line"><span class="token key atrule">image</span><span class="token punctuation">:</span> docker.io/library/redis
</span><span class="code-line"><span class="token key atrule">image</span><span class="token punctuation">:</span> my_private.registry<span class="token punctuation">:</span>5000/redis
</span></code></pre>
</div></div></div><div class="wrap h3body-not-exist col-span-2 row-span-2"><div class="wrap-header h3wrap"><h3 id="ports-端口"><a aria-hidden="true" tabindex="-1" href="#ports-端口"><span class="icon icon-link"></span></a>ports 端口</h3><div class="wrap-body">
<!--rehype:wrap-class=col-span-2 row-span-2-->
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">ports</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token comment"># 将容器的端口 3000 映射到主机的随机端口</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"3000"</span>
</span><span class="code-line"> <span class="token comment"># 将容器的端口范围从 3000 到 3005 映射到主机的相同端口范围</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"3000-3005"</span>
</span><span class="code-line"> <span class="token comment"># 将容器的端口 8000 映射到主机的端口 8000</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"8000:8000"</span>
</span><span class="code-line"> <span class="token comment"># 将容器的端口范围从 8080 到 8081 映射到主机的端口范围从 9090 到 9091</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"9090-9091:8080-8081"</span>
</span><span class="code-line"> <span class="token comment"># 将容器的端口 22SSH端口映射到主机的端口 49100</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"49100:22"</span>
</span><span class="code-line"> <span class="token comment"># 将容器的端口范围从 8000 到 9000 映射到主机的端口 80</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"8000-9000:80"</span>
</span><span class="code-line"> <span class="token comment"># 将容器的端口 8001 映射到主机的 127.0.0.1 地址的端口 8001</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"127.0.0.1:8001:8001"</span>
</span><span class="code-line"> <span class="token comment"># 将容器的端口范围从 5000 到 5010 映射到主机的 127.0.0.1 地址的相同端口范围</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"127.0.0.1:5000-5010:5000-5010"</span>
</span><span class="code-line"> <span class="token comment"># 将容器的 UDP 端口 6060 映射到主机的端口 6060</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"6060:6060/udp"</span>
</span></code></pre>
<p>暴露容器端口</p>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="platform-平台"><a aria-hidden="true" tabindex="-1" href="#platform-平台"><span class="icon icon-link"></span></a>platform 平台</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">platform</span><span class="token punctuation">:</span> darwin
</span><span class="code-line"><span class="token key atrule">platform</span><span class="token punctuation">:</span> windows/amd64
</span><span class="code-line"><span class="token key atrule">platform</span><span class="token punctuation">:</span> linux/arm64/v8
</span></code></pre>
<p>定义了服务容器运行的目标平台。值必须符合 <a href="https://github.com/opencontainers/image-spec/blob/v1.0.2/image-index.md">OCI Image Spec</a> 使用的约定</p>
</div></div></div><div class="wrap h3body-not-exist col-span-2"><div class="wrap-header h3wrap"><h3 id="command"><a aria-hidden="true" tabindex="-1" href="#command"><span class="icon icon-link"></span></a>command</h3><div class="wrap-body">
<!--rehype:wrap-class=col-span-2-->
<p>会覆盖容器镜像声明的默认命令,例如 Dockerfile 的 CMD。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">command</span><span class="token punctuation">:</span> bundle exec thin <span class="token punctuation">-</span>p 3000
</span></code></pre>
<p>该值也可以是一个列表,其方式类似于 Dockerfile</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">command</span><span class="token punctuation">:</span> <span class="token punctuation">[</span> <span class="token string">"bundle"</span><span class="token punctuation">,</span> <span class="token string">"exec"</span><span class="token punctuation">,</span> <span class="token string">"thin"</span><span class="token punctuation">,</span> <span class="token string">"-p"</span><span class="token punctuation">,</span> <span class="token string">"3000"</span> <span class="token punctuation">]</span>
</span></code></pre>
<p>如果该值为 null则使用映像中的默认命令。如果值为 [](空列表)或 ''(空字符串),则忽略图像声明的默认命令,即覆盖为空。</p>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="depends_on"><a aria-hidden="true" tabindex="-1" href="#depends_on"><span class="icon icon-link"></span></a>depends_on</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">web</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">build</span><span class="token punctuation">:</span> .
</span><span class="code-line"> <span class="token key atrule">depends_on</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> db
</span><span class="code-line"> <span class="token punctuation">-</span> redis
</span><span class="code-line"> <span class="token key atrule">redis</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> redis
</span><span class="code-line"> <span class="token key atrule">db</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> postgres
</span></code></pre>
<p>服务之间的启动和关闭依赖关系。</p>
</div></div></div><div class="wrap h3body-exist col-span-2"><div class="wrap-header h3wrap"><h3 id="volumes"><a aria-hidden="true" tabindex="-1" href="#volumes"><span class="icon icon-link"></span></a>volumes</h3><div class="wrap-body">
<!--rehype:wrap-class=col-span-2-->
<p>下面的示例显示了双服务设置,其中数据库的数据目录作为名为 db-data 的卷与另一个服务共享,以便定期备份。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">backend</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> example/database
</span><span class="code-line"> <span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> db<span class="token punctuation">-</span>data<span class="token punctuation">:</span>/etc/data
</span><span class="code-line">
</span><span class="code-line"> <span class="token key atrule">backup</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> backup<span class="token punctuation">-</span>service
</span><span class="code-line"> <span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> db<span class="token punctuation">-</span>data<span class="token punctuation">:</span>/var/lib/backup/data
</span><span class="code-line">
</span><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">db-data</span><span class="token punctuation">:</span>
</span></code></pre>
<p>db-data 卷安装在 <code>/var/lib/backup/data</code><code>/etc/data</code> 容器路径中,分别用于备份和后端。如果卷尚不存在,则运行 <code>docker compose up</code> 会创建该卷。否则,如果在 Compose 外部手动删除现有卷,则会使用并重新创建现有卷。</p>
<h4 id="driver"><a aria-hidden="true" tabindex="-1" href="#driver"><span class="icon icon-link"></span></a>driver</h4>
<p>指定应使用哪个卷驱动程序。如果驱动程序不可用Compose 将返回错误并且不会部署应用程序。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">db-data</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">driver</span><span class="token punctuation">:</span> foobar
</span></code></pre>
<h4 id="driver_opts"><a aria-hidden="true" tabindex="-1" href="#driver_opts"><span class="icon icon-link"></span></a>driver_opts</h4>
<p>指定一个选项列表,作为键值对传递给此卷的驱动程序。这些选项取决于驾驶员。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">example</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">driver_opts</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">type</span><span class="token punctuation">:</span> <span class="token string">"nfs"</span>
</span><span class="code-line"> <span class="token key atrule">o</span><span class="token punctuation">:</span> <span class="token string">"addr=10.40.0.199,nolock,soft,rw"</span>
</span><span class="code-line"> <span class="token key atrule">device</span><span class="token punctuation">:</span> <span class="token string">":/docker/example"</span>
</span></code></pre>
<h4 id="external"><a aria-hidden="true" tabindex="-1" href="#external"><span class="icon icon-link"></span></a>external</h4>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">backend</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> example/database
</span><span class="code-line"> <span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> db<span class="token punctuation">-</span>data<span class="token punctuation">:</span>/etc/data
</span><span class="code-line">
</span><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">db-data</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">external</span><span class="token punctuation">:</span> <span class="token boolean important">true</span>
</span></code></pre>
<p>在示例中Compose 不会尝试创建名为 <code>{project_name}_db-data</code> 的卷,而是查找名为 <code>db-data</code> 的现有卷,并将其挂载到后端服务的容器中。</p>
<h4 id="labels"><a aria-hidden="true" tabindex="-1" href="#labels"><span class="icon icon-link"></span></a>labels</h4>
<p>标签用于将元数据添加到卷中。您可以使用数组或字典。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">db-data</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">labels</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">com.example.description</span><span class="token punctuation">:</span> <span class="token string">"Database volume"</span>
</span><span class="code-line"> <span class="token key atrule">com.example.department</span><span class="token punctuation">:</span> <span class="token string">"IT/Ops"</span>
</span><span class="code-line"> <span class="token key atrule">com.example.label-with-empty-value</span><span class="token punctuation">:</span> <span class="token string">""</span>
</span></code></pre>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">db-data</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">labels</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"com.demo.description=Database volume"</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"com.demo.department=IT/Ops"</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"com.demo.label-with-empty-value"</span>
</span></code></pre>
<h4 id="name"><a aria-hidden="true" tabindex="-1" href="#name"><span class="icon icon-link"></span></a>name</h4>
<p>设置卷的自定义名称。名称字段可用于引用包含特殊字符的卷。该名称按原样使用,并且不受堆栈名称的限制。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">db-data</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">name</span><span class="token punctuation">:</span> <span class="token string">"my-app-data"</span>
</span></code></pre>
<p>这使得可以将此查找名称作为 Compose 文件的参数,以便卷的模型 ID 被硬编码,但平台上的实际卷 ID 是在部署期间在运行时设置的。例如,如果 <code>.env</code> 文件中的 <code>DATABASE_VOLUME=my_volume_001</code></p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">db-data</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">name</span><span class="token punctuation">:</span> $<span class="token punctuation">{</span>DATABASE_VOLUME<span class="token punctuation">}</span>
</span></code></pre>
<p>它还可以与外部属性结合使用。这意味着用于在平台上查找实际卷的卷名称与用于在 Compose 文件中引用它的名称分开设置:</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">volumes</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">db-data</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">external</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">name</span><span class="token punctuation">:</span> actual<span class="token punctuation">-</span>name<span class="token punctuation">-</span>of<span class="token punctuation">-</span>volume
</span></code></pre>
</div></div></div><div class="wrap h3body-exist row-span-3"><div class="wrap-header h3wrap"><h3 id="networks"><a aria-hidden="true" tabindex="-1" href="#networks"><span class="icon icon-link"></span></a>networks</h3><div class="wrap-body">
<!--rehype:wrap-class=row-span-3-->
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">some-service</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> some<span class="token punctuation">-</span>network
</span><span class="code-line"> <span class="token punctuation">-</span> other<span class="token punctuation">-</span>network
</span></code></pre>
<h4 id="aliases"><a aria-hidden="true" tabindex="-1" href="#aliases"><span class="icon icon-link"></span></a>aliases</h4>
<p>声明网络上服务的替代主机名。同一网络上的其他容器可以使用服务名称或别名来连接到服务的容器之一</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">some-service</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">some-network</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">aliases</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> alias1
</span><span class="code-line"> <span class="token punctuation">-</span> alias3
</span><span class="code-line"> <span class="token key atrule">other-network</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">aliases</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> alias2
</span></code></pre>
<p>在以下示例中,服务前端能够通过主机名 <code>backend</code> 或者 <code>back-tier</code> 网络上的数据库来访问 <code>backend</code> 服务。服务 <code>monitoring</code> 能够在 admin 网络上通过主机名 <code>backend</code> 或者 <code>mysql</code> 来访问相同的 <code>backend</code> 服务。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">frontend</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> example/webapp
</span><span class="code-line"> <span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> front<span class="token punctuation">-</span>tier
</span><span class="code-line"> <span class="token punctuation">-</span> back<span class="token punctuation">-</span>tier
</span><span class="code-line">
</span><span class="code-line"> <span class="token key atrule">monitoring</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> example/monitoring
</span><span class="code-line"> <span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> admin
</span><span class="code-line">
</span><span class="code-line"> <span class="token key atrule">backend</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> example/backend
</span><span class="code-line"> <span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">back-tier</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">aliases</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> database
</span><span class="code-line"> <span class="token key atrule">admin</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">aliases</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> mysql
</span><span class="code-line">
</span><span class="code-line"><span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">front-tier</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">back-tier</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">admin</span><span class="token punctuation">:</span>
</span></code></pre>
<h4 id="ipv4_address-ipv6_address"><a aria-hidden="true" tabindex="-1" href="#ipv4_address-ipv6_address"><span class="icon icon-link"></span></a>ipv4_address, ipv6_address</h4>
<p>加入网络时为服务容器指定静态IP地址。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">frontend</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> example/webapp
</span><span class="code-line"> <span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">front-tier</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">ipv4_address</span><span class="token punctuation">:</span> 172.16.238.10
</span><span class="code-line"> <span class="token key atrule">ipv6_address</span><span class="token punctuation">:</span> 2001<span class="token punctuation">:</span>3984<span class="token punctuation">:</span>3989<span class="token punctuation">:</span><span class="token punctuation">:</span><span class="token number">10</span>
</span><span class="code-line">
</span><span class="code-line"><span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">front-tier</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">ipam</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">driver</span><span class="token punctuation">:</span> default
</span><span class="code-line"> <span class="token key atrule">config</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token key atrule">subnet</span><span class="token punctuation">:</span> <span class="token string">"172.16.238.0/24"</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token key atrule">subnet</span><span class="token punctuation">:</span> <span class="token string">"2001:3984:3989::/64"</span>
</span></code></pre>
<h4 id="link_local_ips"><a aria-hidden="true" tabindex="-1" href="#link_local_ips"><span class="icon icon-link"></span></a>link_local_ips</h4>
<p>指定了链接本地IP的列表。链路本地IP是属于知名子网的特殊IP纯粹由运营商管理通常取决于部署它们的架构。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">app</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> busybox
</span><span class="code-line"> <span class="token key atrule">command</span><span class="token punctuation">:</span> top
</span><span class="code-line"> <span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">app_net</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">link_local_ips</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> 57.123.22.11
</span><span class="code-line"> <span class="token punctuation">-</span> 57.123.22.13
</span><span class="code-line"><span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">app_net</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">driver</span><span class="token punctuation">:</span> bridge
</span></code></pre>
<h4 id="mac_address"><a aria-hidden="true" tabindex="-1" href="#mac_address"><span class="icon icon-link"></span></a>mac_address</h4>
<p>设置服务容器连接特定网络时使用的 MAC 地址。</p>
<h4 id="priority-优先级"><a aria-hidden="true" tabindex="-1" href="#priority-优先级"><span class="icon icon-link"></span></a>priority 优先级</h4>
<p>将服务的容器连接到其网络的顺序。如果未指定,默认值为 0。在以下示例中应用服务首先连接到 <code>app_net_1</code>,因为它具有最高优先级。然后它连接到 <code>app_net_3</code>,然后是 <code>app_net_2</code>,后者使用默认优先级值 0。</p>
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">services</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">app</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">image</span><span class="token punctuation">:</span> busybox
</span><span class="code-line"> <span class="token key atrule">command</span><span class="token punctuation">:</span> top
</span><span class="code-line"> <span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">app_net_1</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">priority</span><span class="token punctuation">:</span> <span class="token number">1000</span>
</span><span class="code-line"> <span class="token key atrule">app_net_2</span><span class="token punctuation">:</span>
</span><span class="code-line">
</span><span class="code-line"> <span class="token key atrule">app_net_3</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">priority</span><span class="token punctuation">:</span> <span class="token number">100</span>
</span><span class="code-line"><span class="token key atrule">networks</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">app_net_1</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">app_net_2</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">app_net_3</span><span class="token punctuation">:</span>
</span></code></pre>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="expose"><a aria-hidden="true" tabindex="-1" href="#expose"><span class="icon icon-link"></span></a>expose</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">expose</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"3000"</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"8000"</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"8080-8085/tcp"</span>
</span></code></pre>
<p>定义 Compose 从容器公开的(传入)端口或端口范围。这些端口必须可供链接服务访问,并且不应发布到主机。只能指定内部容器端口。</p>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="links"><a aria-hidden="true" tabindex="-1" href="#links"><span class="icon icon-link"></span></a>links</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">web</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token key atrule">links</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> db
</span><span class="code-line"> <span class="token punctuation">-</span> db<span class="token punctuation">:</span>database
</span><span class="code-line"> <span class="token punctuation">-</span> redis
</span></code></pre>
<p>定义到另一个服务中的容器的网络链接。同时指定服务名称和链接别名 (SERVICE:ALIAS),或者仅指定服务名称。</p>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="pids_limit"><a aria-hidden="true" tabindex="-1" href="#pids_limit"><span class="icon icon-link"></span></a>pids_limit</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">pids_limit</span><span class="token punctuation">:</span> <span class="token number">10</span>
</span></code></pre>
<p>调整容器的 PID 限制。设置为 -1 以获取无限 PID。</p>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="devices"><a aria-hidden="true" tabindex="-1" href="#devices"><span class="icon icon-link"></span></a>devices</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">devices</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"/dev/ttyUSB0:/dev/ttyUSB0"</span>
</span><span class="code-line"> <span class="token punctuation">-</span> <span class="token string">"/dev/sda:/dev/xvda:rwm"</span>
</span></code></pre>
<p>定义已创建容器的设备映射列表</p>
<pre class="language-sh"><code class="language-sh code-highlight"><span class="code-line">HOST_PATH:CONTAINER_PATH<span class="token punctuation">[</span>:CGROUP_PERMISSIONS<span class="token punctuation">]</span>
</span></code></pre>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="dns"><a aria-hidden="true" tabindex="-1" href="#dns"><span class="icon icon-link"></span></a>dns</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">dns</span><span class="token punctuation">:</span> 8.8.8.8
</span><span class="code-line"><span class="token key atrule">dns</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> 8.8.8.8
</span><span class="code-line"> <span class="token punctuation">-</span> 9.9.9.9
</span></code></pre>
<p>定义在容器网络接口配置上设置的自定义 DNS 服务器。它可以是单个值或列表。</p>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="dns_opt"><a aria-hidden="true" tabindex="-1" href="#dns_opt"><span class="icon icon-link"></span></a>dns_opt</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">dns_opt</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> use<span class="token punctuation">-</span>vc
</span><span class="code-line"> <span class="token punctuation">-</span> no<span class="token punctuation">-</span>tld<span class="token punctuation">-</span>query
</span></code></pre>
<p>列出要传递给容器的 DNS 解析器Linux 上的 /etc/resolv.conf 文件)的自定义 DNS 选项。</p>
</div></div></div><div class="wrap h3body-not-exist"><div class="wrap-header h3wrap"><h3 id="dns_search"><a aria-hidden="true" tabindex="-1" href="#dns_search"><span class="icon icon-link"></span></a>dns_search</h3><div class="wrap-body">
<pre class="language-yml"><code class="language-yml code-highlight"><span class="code-line"><span class="token key atrule">dns_search</span><span class="token punctuation">:</span> example.com
</span><span class="code-line"><span class="token key atrule">dns_search</span><span class="token punctuation">:</span>
</span><span class="code-line"> <span class="token punctuation">-</span> dc1.example.com
</span><span class="code-line"> <span class="token punctuation">-</span> dc2.example.com
</span></code></pre>
<p>定义在容器网络接口配置上设置的自定义 DNS 搜索域。它可以是单个值或列表。</p>
</div></div></div></div></div></div><script src="https://giscus.app/client.js" data-repo="jaywcjlove/reference" data-repo-id="R_kgDOID2-Mw" data-category="Q&#x26;A" data-category-id="DIC_kwDOID2-M84CS5wo" data-mapping="pathname" data-strict="0" data-reactions-enabled="1" data-emit-metadata="0" data-input-position="bottom" data-theme="dark" data-lang="zh-CN" crossorigin="anonymous" async></script><div class="giscus"></div></div><footer class="footer-wrap"><footer class="max-container">© 2022 <a href="https://wangchujiang.com/#/app" target="_blank">Kenny Wang</a>.</footer></footer><script src="../data.js?v=1.8.3" defer></script><script src="../js/fuse.min.js?v=1.8.3" defer></script><script src="../js/main.js?v=1.8.3" defer></script><div id="mysearch"><div class="mysearch-box"><div class="mysearch-input"><div><svg xmlns="http://www.w3.org/2000/svg" height="1em" width="1em" viewBox="0 0 18 18">
<path fill="currentColor" d="M17.71,16.29 L14.31,12.9 C15.4069846,11.5024547 16.0022094,9.77665502 16,8 C16,3.581722 12.418278,0 8,0 C3.581722,0 0,3.581722 0,8 C0,12.418278 3.581722,16 8,16 C9.77665502,16.0022094 11.5024547,15.4069846 12.9,14.31 L16.29,17.71 C16.4777666,17.8993127 16.7333625,18.0057983 17,18.0057983 C17.2666375,18.0057983 17.5222334,17.8993127 17.71,17.71 C17.8993127,17.5222334 18.0057983,17.2666375 18.0057983,17 C18.0057983,16.7333625 17.8993127,16.4777666 17.71,16.29 Z M2,8 C2,4.6862915 4.6862915,2 8,2 C11.3137085,2 14,4.6862915 14,8 C14,11.3137085 11.3137085,14 8,14 C4.6862915,14 2,11.3137085 2,8 Z"></path>
</svg><input id="mysearch-input" type="search" placeholder="搜索" autocomplete="off"><div class="mysearch-clear"></div></div><button id="mysearch-close" type="button">搜索</button></div><div class="mysearch-result"><div id="mysearch-menu"></div><div id="mysearch-content"></div></div></div></div></body>
</html>