设为首页 收藏本站
查看: 12340|回复: 0

[经验分享] HaProxy实现动态修改Haproty配置文件

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-7-20 10:35:45 | 显示全部楼层 |阅读模式
                        Registrator+Consul+Consul-template+HaProxy实现动态修改Haproty配置文件
实现需求:
用Haproxy做负载均衡,手动方式在配置文件中添加或删除节点服务器信息,比较麻烦。
通过Registrator收集需要注册到Consul作为Haproxy节点服务器的信息,然后注册到Consul key/value。
Consul-template去Consul key/value中读取信息,然后自动修改Haproxy配置文件,并重载Haproxy。不需要修改haproxy.cfg。
集群环境:
wKiom1eN1r3Rgw-PAAA8YyDm0b0809.jpg
Postil:Mesos集群搭建过程此处省略

关闭selinux和防火墙
1
2
3
setenforce 0
sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config
systemctl stop firewalld && systemctl disable firewalld




ZK-server
1
2
3
4
5
容器来做consul:
获取Consul-server镜像
[iyunv@zk-server ~]# docker pull docker.io/gliderlabs/consul-server
启动Consul-server
[iyunv@zk-server ~]# docker run -d --name=consul --net=host docker.io/gliderlabs/consul-server -bootstrap -bind=192.168.200.8




宿主机来做consul
下载consul包,并解压
1
2
3
[iyunv@zk-server ~]# wget https://releases.hashicorp.com/c ... 0.6.4_linux_386.zip
[iyunv@zk-server ~]# unzip consul_0.6.4_linux_386.zip
[iyunv@zk-server ~]# mv consul /usr/bin/





下载consul-template包,并解压
1
2
3
[iyunv@zk-server ~]# wget https://releases.hashicorp.com/c ... .15.0_linux_386.zip
[iyunv@zk-server ~]# unzip consul-template_0.15.0_linux_386.zip
[iyunv@zk-server ~]# mv consul-template /usr/bin/




安装HaProxy并启动

1
2
[iyunv@zk-server ~]# yum -y install haproxy
[iyunv@zk-server ~]# systemctl start haproxy




创建consul服务器配置目录
1
[iyunv@zk-server ~]# mkdir /config




编写agent和server的json文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
[iyunv@zk-server ~]# vi /config/agent.json
添加内容如下:
{
        "client_addr": "0.0.0.0",
        "data_dir": "/data",
        "leave_on_terminate": true,
        "dns_config": {
                "allow_stale": true,
                "max_stale": "1s"
        }
}
[iyunv@zk-server ~]# vi /config/server.json
添加内容如下:
{
        "ui": true,
        "dns_config": {
                "allow_stale": false
        }
}




启动consul单节点服务器,当然,你consul服务器节点多的话也可以做consul集群。

1
[iyunv@zk-server ~]# consul agent -server -config-dir=/config -bootstrap -bind=192.168.200.8 &



Postil:可用consul members 查看consul集群节点

Slave1-server

获取Registrator镜像
1
[iyunv@slave1 ~]# docker pull gliderlabs/registrator:latest



启动Registrator
Postil:这种启动方式是注册到Consul的key/value
1
[iyunv@slave1 ~]# docker run -d --restart=always --name=registrator --net=host --volume=/var/run/docker.sock:/tmp/docker.sock docker.io/gliderlabs/registrator -ip 192.168.200.10 consulkv://192.168.200.8:8500/hello



Postil:-ip后面跟registration 所属的主机 IP, 一定要设置此属性, 否则服务IP会显示为127.0.0.1

测试Registrator是否把本机容器注册到Consul key/value

启动个容器
1
[iyunv@slave1 ~]# docker run -d -P --name=test --net=bridge image/nginx




进入Consul UI界面查看
http://192.168.200.8:8500/ui/#/dc1/kv/
wKioL1eN2n-BKahmAAAlbgipA10864.jpg


ZK-server
创建consul配置目录
1
2
3
4
5
6
7
8
9
10
[iyunv@zk-server ~]# mkdir -p /data/cfg/consul
[iyunv@zk-server ~]# vi /data/cfg/consul/tmpl.json
添加内容如下:
consul = "127.0.0.1:8500"

template {
  source = "/etc/haproxy/haproxy.ctmpl"
  destination = "/etc/haproxy/haproxy.cfg"
  command = "systemctl reload haproxy"
}




编写haproxy模版

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
[iyunv@zk-server ~]# vi /etc/haproxy/haproxy.ctmpl
添加内容如下:
global
    log         127.0.0.1 local2

    chroot      /var/lib/haproxy
    pidfile     /var/run/haproxy.pid
    maxconn     4000
    user        haproxy
    group       haproxy
    daemon

    # turn on stats unix socket
    stats socket /var/lib/haproxy/stats
defaults
    mode                    http
    log                     global
    option                  httplog
    option                  dontlognull
    option http-server-close
    option forwardfor       except 127.0.0.0/8
    option                  redispatch
    retries                 3
    timeout http-request    10s
    timeout queue           1m
    timeout connect         10s
    timeout client          1m
    timeout server          1m
    timeout http-keep-alive 10s
    timeout check           10s
    maxconn                 3000

frontend  main *:80
    acl url_static       path_beg       -i /static /images /javascript /stylesheets
    acl url_static       path_end       -i .jpg .gif .png .css .js

    use_backend static          if url_static
    default_backend             app

backend static
    balance     roundrobin
    server      static 127.0.0.1:4331 check

backend app
    balance     roundrobin
     {{range $key, $pairs := tree "hello/" | byKey}}{{range $serverid, $pair := $pairs}}
     server app {{.Value}} check inter 2000 fall 3 weight 1 {{end}}{{end}}




启动consul-template

1
[iyunv@zk-server ~]#consul-template -config /data/cfg/consul/tmpl.json > consul-template.out 2>&1 &




用marathon启动一个nginx容器,看registrator是否注册到consul,然后看consul-template是否自动添加了这个后端服务器到/etc/haproxy/haproxy.cfg
wKiom1eN29Ch92f1AAAn-FZu8sk782.jpg
wKioL1eN29DSwwZMAABEjcHBKnE132.jpg
wKiom1eN29HBhfyIAAFS6Sq96qE500.jpg

访问HaProxy_IP
wKioL1eN2_DwH-usAABMZxBsa6s864.jpg





运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-246820-1-1.html 上篇帖子: haproxy实现mysql的读负载均衡 下篇帖子: HAproxy编译安装 配置文件 动态
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表