目录
Consul是HashiCorp公司推出的开源工具,Consul由Go语言开发,部署起来非常容易,只需要极少的可执行程序和配置文件,具有绿色、轻量级的特点。
Consul是分布式的、高可用的、可横向扩展的用于实现分布式系统的服务发现与配置。
Consul的作用
Consul-Template是一个守护进程,用于实时查询Consul集群信息
Consul-Template可以更新文件系统上任意数量的指定模板,生成配置文件
更新完成以后,可以选择运行shell命令执行更新操作,重新加载Nginx。
Consul-Template可以查询Consul中的服务目录、Key、Key-values等。
这种强大的抽象功能和查询语言模板可以使Consul-Template特别适合动态的创建配置文件。
例如:创建Apache/Nginx Proxy Balancers、Haproxy Backends
一个由Go语言编写的,针对docker使用的,可以用于检测容器状态,自动注册和注销docker容器的服务到服务配置中心。目前支持Consul、Etcd和SkyDNS2。
(1)consul主机
ip地址:192.168.222.10 Docker 、Consul、Consul-template
(2)registrator
ip地址:192.168.222.100 Docker、registrator
- mkdir /root/consul
- cd /root/consul
- //放入安装包
- unzip consul_0.9.2_linux_amd64.zip
- mv consul /usr/bin
-
- consul agent \
- -server \
- -bootstrap \
- -ui \
- -data-dir=/var/lib/consul-data \
- -bind=192.168.222.10 \
- -client=0.0.0.0 \
- -node=consul-server01 &> /var/log/consul.log &

查看集群信息
- consul members
-
- consul info | grep leader
- 这里查询到的8300端口用于集群内数据的读写和复制

(1)安装Gliderlabs/Registrator
- docker run -d \
- --name=registrator \
- --net=host \
- -v /var/run/docker.sock:/tmp/docker.sock \
- --restart=always \
- gliderlabs/registrator:latest \
- -ip=192.168.222.100 \
- consul://192.168.222.10:8500

(2) 测试服务
- docker run -itd -p:81:80 --name test-01 -h test01 nginx
- docker run -itd -p:82:80 --name test-02 -h test02 nginx
- docker run -itd -p:91:80 --name test-03 -h test03 httpd
- docker run -itd -p:92:80 --name test-04 -h test04 httpd

- unzip consul-template_0.19.3_linux_amd64.zip
- mv consul-template /usr/bin/

consul:192.168.22210
- vim /root/consul/nginx.ctmpl
-
- upstream http_backend {
- {{range service "nginx"}}
- server {{.Address}}:{{.Port}};
- {{end}}
- }
-
- server {
- listen 81;
- server_name localhost 192.168.222.10;
- access_log /var/log/nginx/nginx01-access.log;
- index index.html index.php;
- location / {
- proxy_set_header HOST $host;
- proxy_set_header X-Real-IP $remote_addr;
- proxy_set_header Client-IP $remote_addr;
- proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
- proxy_pass http://http_backend;
- }
- }

consul:192.168.222.10
- yum install -y gcc pcre-devel zlib-devel
- cd /opt
- tar zxvf nginx-1.12.0.tar.gz
- cd nginx-1.12.0/
- ./configure --prefix=/usr/local/nginx
- make && make install
配置 nginx
- vim /usr/local/nginx/conf/nginx.conf
- http {
- include mime.types;
- include vhost/*.conf;
- default_type application/octet-stream;
-
- //创建虚拟主机目录
- mkdir /usr/local/nginx/conf/vhost
- //创建日志文件目录
- mkdir /var/log/nginx
-
- //启动nginx
- /usr/local/nginx/sbin/nginx

- consul-template -consul-addr 192.168.222.10:8500 \
- -template "/root/consul/nginx.ctmpl:/usr/local/nginx/conf/vhost/nginx01.conf:/usr/local/nginx/sbin/nginx -s reload" \
- --log-level=info


在registrator服务端注册
docker run -itd -p:83:80 --name test-05 -h test05 nginx


- mkdir /root/consul
- cd /root/consul
- //放入安装包
- unzip consul_0.9.2_linux_amd64.zip
- mv consul /usr/bin
-
- consul agent \
- -server \
- -bootstrap \
- -ui \
- -data-dir=/var/lib/consul-data \
- -bind=192.168.222.50 \
- -client=0.0.0.0 \
- -node=consul-server02 \
- -enable-script-checks=true \
- -datacenter=dc1 \
- -join 192.168.222.10 &> /var/log/consul.log &
-
- #--------参数解释--------------------------------
- -enable-script-checks=true:设置检查服务为可用
- -datacenter:数据中心名称
- -join:加入到已有的集群中

