本文首发于我的博客:地址php
Compose 是一个用户定义和运行多个容器的 Docker 应用程序。在 Compose 中你可使用 YAML 文件来配置你的应用服务。而后,只须要一个简单的命令,就能够建立并启动你配置的全部服务。nginx
使用 Compose 基本会有以下三步流程:git
目前有两种主流安装方式,笔者使用了第一种方式。github
下载最新的docker-compose文件web
curl -L https://github.com/docker/compose/releases/download/1.16.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
复制代码
下载完成后须要对/usr/local/bin/docker-compose
目录进行赋权redis
chmod +x /usr/local/bin/docker-compose
复制代码
测试结果docker
docker-compose --version
输出
docker-compose version 1.16.1, build 6d1ac21
复制代码
经过pip方式安装shell
pip install docker-compose
复制代码
前提是须要你的服务器已经装了pip组件api
rm /usr/local/bin/docker-compose
复制代码
pip uninstall docker-compose
复制代码
咱们这里以kafka为例缓存
version: '2'
services:
zoo1:
# 依赖于wurstmeister/zookeeper镜像,本地无则自动下载
image: wurstmeister/zookeeper
restart: unless-stopped
hostname: zoo1
# 映射端口
ports:
- "2181:2181"
# 容器名称
container_name: zookeeper
kafka1:
# 依赖于wurstmeister/kafka镜像
image: wurstmeister/kafka
# 映射端口
ports:
- "9092:9092"
# 目录挂载 【容器目录:宿主机目录】
volumes:
- /var/log/kafka/logs:/var/docker/kafka/logs
# 配置环境变量
environment:
KAFKA_ADVERTISED_HOST_NAME: localhost
KAFKA_ZOOKEEPER_CONNECT: "zoo1:2181"
KAFKA_BROKER_ID: 1
KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
KAFKA_CREATE_TOPICS: "stream-in:1:1,stream-out:1:1"
# 解决服务启动顺序问题,例以下面容器会先肯定zoo1和redis两个服务,最后才启动kafka1服务
depends_on:
- zoo1
- redis(实际无该容器)
# 容器名称
container_name: kafka
复制代码
首先将docker-compos.yml上传至服务器,而后进入目录执行:
docker-compose up -d
复制代码
则开始后台构建服务
若是想单独启动一个服务,你能够:
docker-compose up -d 指定服务名称
例子:docker-compose up -d zoo1
复制代码
version: "3"
services:
# 指定服务名称
#服务注册与发现中心
simonEureka:
image: simon/eureka-server:2.0.1-SNAPSHOT
hostname: simonEureka
ports:
- "8100:8100"
#配置中心
simonConfig:
image: simon/config-server:2.0.1-SNAPSHOT
hostname: simonConfig
ports:
- "8101:8101"
depends_on:
- simonEureka
# always – 无论退出状态码是什么始终重启容器。当指定always时,docker daemon将无限次数地重启容器。容器也会在daemon启动时尝试重启,无论容器当时的状态如何。
# no – 容器退出时不要自动重启。这个是默认值。
# on-failure[:max-retries] – 只在容器以非0状态码退出时重启。可选的,能够退出docker daemon尝试重启容器的次数。
# unless-stopped - 无论退出状态码是什么始终重启容器,不过当daemon启动时,若是容器以前已经为中止状态,不要尝试启动它。
restart: always
#路由网关
apigateway:
image: simon/apigateway:2.0.1-SNAPSHOT
ports:
- "8102:8102"
depends_on:
- simonEureka
- simonConfig
restart: always
#监控平台
admin:
image: simon/admin:2.0.1-SNAPSHOT
ports:
- "8103:8103"
depends_on:
- simonEureka
- simonConfig
restart: always
---------------------
做者:AaronSimon
来源:CSDN
原文:https://blog.csdn.net/aaronsimon/article/details/82711610
版权声明:本文为博主原创文章,转载请附上博文连接!
复制代码
这个时候咱们服务器simon目录的文件应该以下:
apigateway:2.0.1-SNAPSHOT.jar
admin:2.0.1-SNAPSHOT.jar
config-server:2.0.1-SNAPSHOT.jar
eureka-server:2.0.1-SNAPSHOT.jar
docker-compose.yml
复制代码
若是咱们的yml文件不是docker-compose.yml时咱们在进行服务排编是须要指定yml文件名称。
docker-compose -f docker-kafka.yml up -d
复制代码
当咱们遇到服务启动须要前后顺序时,咱们能够对docker-compose.yml根据服务的前后顺序进行拆分。
命令 | 描述 |
---|---|
docker-compose up -d nginx | 构建建启动nignx容器 |
docker-compose exec nginx bash | 登陆到nginx容器中 |
docker-compose down | 删除全部nginx容器,镜像 |
docker-compose ps | 显示全部容器 |
docker-compose restart nginx | 从新启动nginx容器 |
docker-compose run --no-deps --rm php-fpm php -v | 在php-fpm中不启动关联容器,并容器执行php -v 执行完成后删除容器 |
docker-compose build nginx | 构建镜像 |
docker-compose build --no-cache nginx | 不带缓存的构建 |
docker-compose logs nginx | 查看nginx的日志 |
docker-compose logs -f nginx | 验证(docker-compose.yml)文件配置,当配置正确时,不输出任何内容,当文件配置错误,输出错误信息 |
docker-compose pause nginx | 暂停nignx容器 |
docker-compose unpause nginx | 恢复ningx容器 |
docker-compose rm nginx | 删除容器(删除前必须关闭容器) |
docker-compose stop nginx | 中止nignx容器 |
docker-compose start nginx | 启动nignx容器 |