docker之自动编排,自动发现和自动更新服务

本文介绍了如何利用Docker Compose、Consul和Gliderlabs/Registrator构建一个自动编排、发现和更新的服务框架。通过Docker Compose简化多容器的部署,Consul作为服务发现与配置工具,Registrator自动注册和注销Docker容器,实现服务的动态管理。最后,提到了Consul Template在动态生成配置文件中的作用。
摘要由CSDN通过智能技术生成

概述

众安公司提出一个新需求,使用Docker将Consul、Consul Template、Registrator和Nginx组装成一个值得信任且可扩展的服务框架,可在这个框架中添加和移除服务,不需要重写任何配置,也不需要重启任何服务,一切都能正常运行

compose

  • Docker Compose的前身是Fig,它是一个定义及运行多个Docker容器的工具
  • 使用Docker Compose不再需要使用Shell脚本来启动容器
  • Docker Compose非常适合组合使用多个容器进行开发的场景

YAML是一种标记语言很直观的数据序列化格式
文件格式及编写注意事项
不支持制表符tab键缩进,需要使用空格缩进

  • 通常开头缩进2个空格
  • 字符后缩进1个空格,如冒号、逗号、横杆
  • 用#号注释
  • 如果包含特殊字符用单引号引起来
  • 布尔值必须用引号括起来 ture真:成立 false假:不成立 boolean 要么true要么false

Docker Compose配置常用字段

字段 描述
build dockerfile context 指定Dockerfile文件名构建镜像上下文路径
image 指定镜像
command 执行命令,覆盖默认命令
container name 指定容器名称,由于容器名称是唯一的,如果指定自定义名称,则无法scale
deploy 指定部署和运行服务相关配置,只能在Swarm模式使用
environment 添加环境变量
networks 加入网络
ports 暴露容器端口,与-p相同,但端口不能低于60
volumes 挂载宿主机路径或命令卷
restart 重启策略,默认no,always,no-failure,unless-stoped
hostname 容器主机名

Docker Compose常用命令

字段 描述
build 重新构建服务
ps 列出容器
up 创建和启动容器
exec 在容器里面执行命令
scale 指定一个服务容器启动数量
top 显示容器进程
logs 查看容器输出
down 删除容器、网络、数据卷和镜像
stop/start/restart 停止/启动/重启服务

Compose命令说明
基本的使用格式:
docker-compose [options] [COMMAND][ARGS…]
docker-compose选项:

- -verbose 输出更多调试信息
- -version 打印版本并退出
-f,- -file FILE 使用特定的compose模板文件,默认为docker-compose.yml
-p,- -project-name NAME 指定项目名称,默认使用目录名称

consul

Consul是HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置
Consul的特性
●支持健康检查,允许存储键值对
●基于Golong语言,可移植性强
●支持ACL访问控制
与Docker等轻量级容器可无缝配合
内部网络是docker网桥 docker0相当于交换机
每个提供服务的节点上都要部署和运行Consul的agent
Consul agent有两种运行模式
Server
Client
Server和Client只是Consul集群层面的区分,与搭建在
Cluster之上的应用服务无关

gliderlabs/registrator

  • 检查容器运行状态
  • 自动注册和注销docker容器的服务到服务配置中心

配置

compose

[root@localhost ~]# curl -L https://github.com/docker/compose/releases/download/1.21.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
[root@localhost ~]# mv docker-compose /usr/local/bin/
[root@localhost ~]# chmod +x /usr/local/bin/docker-compose
[root@localhost ~]# mkdir /root/compose_nginx
[root@localhost ~]# cd /root/compose_nginx
[root@localhost compose_nginx]# vim docker-compose.yml
version: '3'
services:
  nginx:
    hostname: nginx
    build:
      context: ./nginx
      dockerfile: Dockerfile
    ports:
      - 1216:80
      - 1217:443
    networks:
      - zhongyi
    volumes:
      - ./wwwroot:/usr/local/nginx/html
networks:
  zhongyi:
##编写nginx的Dockerfile
[root@localhost compose_nginx ~]# mkdir nginx
[root@localhost compose_nginx ~]# cd nginx
[root@localhost nginx ~]# vim Dockerfile
FROM centos:7
MAINTAINER zhongyi
RUN yum -y update
RUN yum -y install gcc gcc-c++ make pcre-devel zlib-devel
RUN useradd -M -s /sbin/nologin nginx
ADD nginx-1.15.9.tar.gz /opt
WORKDIR /opt
WORKDIR nginx-1.15.9  
RUN ./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module && make && make install
ENV PATH /usr/local/nginx/sbin:$PATH
EXPOSE 80
EXPOSE 443
RUN echo "daemon off;" >> /usr/local/nginx/conf/nginx.conf
ADD run.sh /run.sh
RUN chmod 755 /run.sh
CMD ["/run.sh"]
[root@localhost nginx]# vim run.sh 
#!/bin/bash
/usr/local/nginx/sbin/nginx
将ng
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值