docker-compose: Compose可译为组合物,docker-compose 适用于
定义和运行多个Docker容器的工具
。通过docker-compose,你可以使用YAML文件来配置应用程序需要的所有服务,然后通过使用一个命令,就可以创建并启动所有服务。docker-compose 将所管理的容器分为三层,分别是 工程(project),服务(service)以及容器(container)。
官方安装文档:https://docs.docker.com/compose/install/
# 下载
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
# 查看是否安装成功
docker-compose --version
目录分布
|- docker
|- ---- docker-compose.yml
|- ---- eureka-server
|- ---- ---- eureka-server.jar
|- ---- ---- Dockerfile
|- ---- any-gateway
|- ---- ---- any-gateway.jar
|- ---- ---- Dockerfile
Dockerfile:
FROM openjdk:8-jdk-alpine
VOLUME /tmp
ENV LANG en_US.UTF-8
ENV LANGUAGE en_US:en
ENV LC_ALL en_US.UTF-8
ADD eureka-server.jar app.jar
ENTRYPOINT [ "java", "-Djava.security.egd=file:/dev/./urandom", "-jar", "/app.jar" ]
docker-compose.yml
version: "3"
services:
eureka-server:
# 指定容器名称
container_name: myProject-eureka-server
# 指定主机名
hostname: myProject
# 指定镜像
image: myProject/eureka-server:0.0.1
# 指定宿主映射端口
#ports:
#- "6002:6002"
# 绑定宿主机网络
# network_mode: "host"
# 指定容器IP
networks:
mynet:
# 宿主机会自动配置网关IP:172.20.1.1
ipv4_address: 172.20.1.2
# 指定构建
build: ./eureka-server
# 重启机制
restart: always
# 可以创建交互式会话
tty: true
any-gateway:
container_name: myProject-gateway
image: myProject/gateway:0.0.1
build: ./any-gateway
depends_on:
- eureka-server
network_mode: "service:eureka-server"
restart: always
tty: true
networks:
mynet:
driver: bridge
ipam:
# 这里不用配置driver
# driver: default
config:
- subnet: "172.20.1.0/24"
部署步骤:(以 eureka-server.jar 为例)
将jar包放到 docker/eureka-server/ 下;
在 docker/eureka-server/ 执行如下命令,构建镜像
$ docker build -t my/eureka-server:0.0.1 .
查看构建好的镜像:
$ docker images | grep eureka-server
在 docker/ 执行如下命令,创建并后台运行容器:
$ docker-compose up -d
查看运行的容器:
$ docker-compose ps | grep eureka-server
# 创建并后台启动所有容器(-f 指定配置文件)
$ docker-compose up -d
# 创建并后台启动容器(镜像不存在自动build)
$ docker-compose up -d [服务名]
# 查看启动容器列表(-a 查看全部容器列表)
$ docker-compose ps
# 查看日志
$ docker-compose logs -f --tail=20 [服务名]
# 进入容器中
$ docker-compose exec [服务名] bash
# 停止容器
$ docker-compose stop [服务名]
# 删除容器
$ docker-compose rm -f [服务名]
# 构建镜像
$ docker-compose build [服务名]
# 创建并后台启动容器(镜像不存在自动build)
$ docker-compose up -d [服务名]
# 构建镜像
$ docker-compose build [服务名]
# 启动容器
$ docker-compose start [服务名]
# 重启容器
$ docker-compose restart [服务名]
# 停止并删除容器(--rmi all 删除镜像)
$ docker-compose down
整理完毕,完结撒花~