Confd+Etcd+endpoint+haproxy

一:规则说明:
通过confd关联etcd构建haproxy模板,并重启haproxy过程,在默认的namespace上。
二:安装confd:
wget https://github.com/kelseyhightower/confd/releases/download/v0.11.0/confd-0.11.0-linux-amd64
[root@201 data]# mv confd-0.11.0-linux-amd64 /usr/local/bin/confd
[root@201 data]# chmod +x /usr/local/bin/confd
[root@201 data]# confd -version
confd 0.11.0
confd要与haproxy安装在同一台主机上,以便能生成给Haproxy用的配置。创建confd的默认配置存放路径,confd会根据该文件找到要修改的haproxy文件路径
mkdirp/etc/confd/templates vim /etc/confd/conf.d/haproxy.toml
[template]
src = “haproxy.cfg.tmpl”
dest = “/etc/haproxy/haproxy.cfg”
keys = [
#”/services/zookeeper/”,
#”/services/web”
#以此key值为默认的根路径,可以设置多个路径
“/registry/services/endpoints/default/”
]
reload_cmd = “/etc/init.d/haproxy reload” #可以填写你自己的重启haproxy的命令
三:示例:
1.创建两个service:

 {
    "kind": "Service",
    "apiVersion": "v1",
    "metadata": {
        "name": "tomcat1",
        "labels": {
            "name": "tomcat1",
            "haproxyport":"15246",
            "type":"APP"
        }
    },
    "spec": {
        "ports": [
            {
                "name": "tomcat1",
                "protocol": "TCP",
                "port": 8080,
                "targetPort": 8080,

            }
        ],
        "selector": {
            "name": "tomcat1"
        },
        "clusterIP": "172.17.78.85",
        "type": "ClusterIP"
     },
    "status": {
        "loadBalancer": {}
    }
}

b.

{
    "kind": "Service",
    "apiVersion": "v1",
    "metadata": {
        "name": "ipaas1",
        "labels": {
            "name": "ipaas1",
            "haproxyport":"15246",
            "type":"IPAAS"
        }
    },
    "spec": {
        "ports": [
            {
                "name": "ipaas1",
                "protocol": "TCP",
                "port": 8081,
                "targetPort": 9090
            }
        ],
        "selector": {
            "name": "ipaas1"
        }
     },
    "status": {
        "loadBalancer": {}
    }
}

2.创建RC(省略)这里必须要有Service所关联的label相对应运行的pod,才能生成endpoints对应的关系数据。
创建haproxy.cfg的模板文件,以便confd能根据模板生成配置:
vim /etc/confd/templates/haproxy.cfg.tmpl
global
log 127.0.0.1 local3
maxconn 5000
uid 99
gid 99
daemon

defaults
log 127.0.0.1 local3
mode http
option dontlognull
retries 3
option redispatch
maxconn 2000
timeout connect 5000
timeout client 50000
timeout server 50000
这里写图片描述
说明:上面定义的规则首先通过range循环所有在default命令空间下的Service,获取每个Service在label中定义的Type值来判断是生成ipaas的还是APP的haproxy配置,因为这里用了两套haproxy基于Ipaas,Iaas,然后在循环获取这个Service下所关联的pod并生成对应的配置
启动confd:
confd -interval 5 -node ‘etcd:2379’ -confdir /etc/confd > /var/log/confd.log &
–注 interval 为设置多个秒检查一次
生成的配置(只截取动态生成的数据):
这里写图片描述
这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值