微服务架构的应用系统中一般包含若干个微服务,每个微服务一般都会部署多个实例,如果每个微服务都要手动启停,维护的工作量会很大。
  ·要从Dockerfile buildimage或者去dockerhub拉取image  
  ·要创建多个container
  ·要管理这些container(启动停止删除)

服务编排:按照一定的业务规则批量管理容器

 

Docker Compose是一个编排多容器分布式部署的工具,提供命令集管理容器化应用的完整开发周期,包括服务构建,启动和停止。使用步骤:
  1.利用Dockerfile定义运行环境镜像  
  2.使用docker-compose.yml定义组成应用的各服务。
  3.运行docker-composeup启动应用

安装Docker Compose

# Compose目前已经完全支持Linux、Mac OS和Windows,在我们安装Compose之前,需要先安装Docker。下面我 们以编译好的二进制包方式安装在Linux系统中。 
curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose    安装会很慢,安装包有几个G
# 设置文件可执行权限 
chmod +x /usr/local/bin/docker-compose
# 查看版本信息 
docker-compose -version

卸载Docker Compose


# 二进制包方式安装的,删除二进制文件即可
rm /usr/local/bin/docker-compose

使用docker compose编排nginx+springboot项目 通过nginx反向代理springboot,外部通过访问nginx来间接访问springboot

   1 创建docker-compose目录

  mkdir ~/docker-compose   
  cd ~/docker-compose
2 编写 docker-compose.yml 文件 必须叫这个
version: '3'
services:
  nginx:
   image: nginx
   ports:
    - 80:80
   links:
    - app                                       #将app(springboot项目的镜像,如何制作参考上一节)反向代理
   volumes:
    - ./nginx/conf.d:/etc/nginx/conf.d
  app:
    image: app
    expose:
      - "8080"
  3 创建./nginx/conf.d目录
    mkdir -p ./nginx/conf.d                    //这个目录的作用是为nginx的数据卷提供数据源
  4 在./nginx/conf.d目录下 编写itheima.conf文件
server {
    listen 80;
    access_log off;

    location / {
        proxy_pass http://app:8080;
    }
   
}
   5 在~/docker-compose 目录下 使用docker-compose 启动容器
     docker-compose up  (-d)  加上-d为后台启动 

   6 测试访问  

    http://192.168.149.135/hello


 

 

posted on 2020-12-31 16:43  wuzi2333  阅读(87)  评论(0)    收藏  举报