docker-compose-语法使用安装说明

首先安装docker

关闭防火墙

systemctl stop firewalld

yum安装依赖

yum install -y yum-utils device-mapper-persistent-data lvm2

下载docker-ce.repo源

wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo

安装docker

yum install -y docker-ce docker-ce-cli containerd.io

启动

systemctl start docker.service

systemctl enable docker.service

编辑/etc/docker/daemon.json

tee /etc/docker/daemon.json <<-'EOF'

{

"registry-mirrors": [

"http://hub-mirror.c.163.com",

"https://mirrors.tuna.tsinghua.edu.cn",

"http://mirrors.sohu.com",

"https://ustc-edu-cn.mirror.aliyuncs.com",

"https://ccr.ccs.tencentyun.com",

"https://docker.m.daocloud.io",

"https://docker.awsl9527.cn"

]

}

EOF

重启docker

systemctl restart docker.service

然后安装docker-compose

sudo curl -L "https://github.com/docker/compose/releases/latest/download/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

设置权限

sudo chmod +x /usr/local/bin/docker-compose 查看版本 docker-compose -version 启动 docker-compose start -d或者docker-compose up -d

如果你想利用docker-compose安装mysql等内容 你需要了解语法规则

docker-compose.yml 配置文件语法

注意:如果在compose中配置nework请注意几个参数,默认配置network bridge的时候执行compose会自动创建

如果有已存容器内网络,需要增加参数,具体如下

网络优先于容器

Docker Compose 会自动处理依赖关系,但需显式声明网络。网络必须在容器启动前存在(Compose 会自动创建网络,若需使用外部网络则需提前创建)

networks: # 顶层网络声明

my-bridge:

driver: bridge # 指定桥接驱动

name: my-custom-bridge # 可选:自定义网络名称(否则自动生成)

attachable: true # 允许其他容器后期加入

  1. 启动顺序逻辑

Compose 自动处理顺序:

运行 docker-compose up 时,Compose 按以下顺序执行:

创建网络(如 my-bridge)

启动容器(web 和 db 同时加入该网络)

验证顺序:

查看网络和容器状态:

docker network ls | grep my-custom-bridge # 网络已存在

docker inspect my-container-id | grep NetworkMode # 容器使用该网络

关键场景处理

场景1:依赖外部预创建网络

若需使用已存在的桥接网络(非 Compose 自动创建):

networks:

external-bridge:

external: true # 声明外部网络

name: existing-bridge # 必须与已存在网络名称一致

docker-compose配置文件

version:'3.8' #指定compose版本

services: #服务

web: #服务名称

image: nginx:latest #使用docker hub上的nginx镜像

ports:- "80:80" #将容器的80端口映射到宿主机的80端口上

volumes:

- ./html:/usr/share/nginx/html #挂载宿主机 html目录到容器的/usr/share/nginx/html

network:

- mynet1 #使用自定义网络桥接网络

depends_on:

- db  #web 依赖于db服务

db: #服务名称

image: mysql:latest #使用docker hub上的mysql镜像

environment:

POSTGRES_PASSWORD: 123456 #设置环境变量 可以多设置

volume:

- db-data: /var/lib/mysql/data #挂载数据卷

network:

- mynet1 #使用自定义网络mynet1

restart: always #容器异常总重启

#---------------------------------------以下为全局变量设置

volumes

db-data: #定义数据卷 db-data

networks:

mynet1 #自定义网络mynet1

driver: bridge # 使用bridge驱动

version:指定 Compose 文件格式的版本,确保与你的 Docker Compose 版本兼容。

services:每个服务都定义了一个容器,可以包含镜像、端口映射、卷挂载、网络配置、环境变量等。

ports:将容器端口映射到宿主机的端口。格式为 "宿主端口:容器端口"。

volumes:挂载卷到容器,可以是宿主机路径或命名卷。格式为 "宿主机路径:容器路径" 或 "卷名:容器路径"。

networks:定义容器间的网络,可以是自定义网络或使用默认的网络。

depends_on:指定服务间的依赖关系,确保依赖的服务先启动。

environment:设置环境变量。

restart:设置容器的重启策略,如 always 表示在退出时总是重启容器。

volumes 和 networks 部分在顶层定义全局卷和网络,也可以在服务内部单独定义。

通过这样的配置文件,你可以轻松地启动和管理多容器的 Docker 应用程序。

其他具体案例

docker-compose命令

相关推荐
..Move...1 小时前
Docker镜像制作
运维·docker·容器
码龄3年 审核中6 小时前
说说SSH的端口转发
大数据·运维·ssh
盛世隐者6 小时前
【Linux】定制Linux系统
linux·运维·服务器
行思理7 小时前
Docker 应该如何学习 分四个阶段
学习·docker·容器
..Move...8 小时前
Docker应用部署tomcat和nginx
nginx·docker·tomcat
Lxt.星翊9 小时前
MySQL(安装和卸载、数据库存储原理图)
linux·运维·windows
苹果醋39 小时前
JAVA面试汇总(二)多线程(五)
运维·vue.js·spring boot·nginx·课程设计
JustNow_Man10 小时前
Cline中模型识别任务与clinerules相关性的实现逻辑
linux·运维·ubuntu
小白银子10 小时前
零基础从头教学Linux(Day 56)
linux·运维·python
你想考研啊10 小时前
Linux下搭建Activemq的Master-Slave(共享文件模式)
linux·运维·activemq