docker compose 和 docker-compose 是两个相关但不同的 Docker 编排工具,以下是它们的区别和使用说明:
# v1(旧版)
docker-compose --version
# 输出:docker-compose version 1.29.2, build ...
# v2(新版)
docker compose version
# 输出:Docker Compose version v2.17.2
docker-compose(带连字符)docker compose(空格分隔)# Linux 安装
sudo curl -L "https://github.com/docker/compose/releases/download/1.29.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
# 或使用 pip
pip install docker-compose
# Docker Desktop 自动包含(Windows/Mac)
# Linux 安装
sudo apt-get update
sudo apt-get install docker-compose-plugin
# 或手动安装
DOCKER_CONFIG=${DOCKER_CONFIG:-$HOME/.docker}
mkdir -p $DOCKER_CONFIG/cli-plugins
curl -SL https://github.com/docker/compose/releases/download/v2.17.2/docker-compose-linux-x86_64 -o $DOCKER_CONFIG/cli-plugins/docker-compose
chmod +x $DOCKER_CONFIG/cli-plugins/docker-compose
# v1 格式
docker-compose up -d
docker-compose down
docker-compose ps
# v2 格式
docker compose up -d
docker compose down
docker compose ps
# docker-compose.yml 示例
version: '3.8'
services:
web:
image: nginx:alpine
ports:
- "80:80"
db:
image: mysql:8.0
environment:
MYSQL_ROOT_PASSWORD: example
# 启动服务(两个版本都支持)
docker-compose up -d # v1
docker compose up -d # v2
# 查看状态
docker-compose ps # v1
docker compose ps # v2
# 查看日志
docker-compose logs -f # v1
docker compose logs -f # v2
# 停止服务
docker-compose down # v1
docker compose down # v2
# 1. 卸载旧版
sudo rm /usr/local/bin/docker-compose
# 2. 安装新版(Docker Compose Plugin)
# 对于已安装 Docker Desktop 的用户,v2 已自动包含
# 可以在脚本中创建别名或软链接
sudo ln -s /usr/libexec/docker/cli-plugins/docker-compose /usr/local/bin/docker-compose
# 或使用包装脚本
#!/bin/bash
# 优先使用 v2,回退到 v1
if command -v docker-compose &> /dev/null; then
docker-compose "$@"
elif docker compose version &> /dev/null; then
docker compose "$@"
else
echo "Docker Compose not found"
exit 1
fi
新项目建议使用 v2:
生产环境统一版本:
# 在 Dockerfile 中指定
FROM docker:20.10
RUN apk add --no-cache docker-compose
使用兼容的 Compose 文件:
# 使用最新的 Compose 规范
version: '3.8' # 或使用不带 version 的格式
services:
# 服务配置
命令差异:
docker-compose run --rm 中的某些旧参数文件兼容性:
性能对比:
建议新用户直接使用 docker compose (v2),现有用户逐步迁移到 v2 以获得更好的性能和功能支持。