首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Consul-template,Nginx实现Thrift Consul负载均衡

流程

说明

本例子是进行RPC的负载均衡,RPC是tcp协议,所以Nginx要配置tcp模块,支持tcp负载均衡。

Consul集群

用于服务注册,注册多个服务实例,对外提供RPC服务。

Consul-template

用于实时监测Consul中服务的状态,配合自身一个模板文件,生成Nginx的配置文件。

Nginx

使用自身的配置文件和第二步生成的配置文件,进行负载均衡。

Nginx安装

安装最新版Nginx,保证Nginx版本在1.9.0以上

1.9.0版本以上才支持TCP转发,据说不是默认安装了该模块,安装完成可以查询一下,如果有参数,表示已经支持TCP。如果没有就重新编译增加参数安装。

我的Nginx安装在目录下

安装完成使用监测一下是否成功。

Consul-template

本文旨在负载均衡,Consul集群搭建不作介绍。

下载对应系统版本文件

https://releases.hashicorp.com/consul-template/

解压,并复制到PATH路径下

找个地方新建个文件夹,并创建三个文件

config.hcl 主要用来配置consul-template的启动参数项,包括consul服务器的地址,模板文件的位置,生成的配置文件的位置等等。除了consul和template块,其他参数可选。参考https://github.com/hashicorp/consul-template

Consul块配置Consul服务器地址和端口

template块配置模板的路径和生成文件的位置,以及生成文件后需要执行的命令。在我们这里我们需要nginx重新加载配置文件,所以设置的命令为

template.ctmpl编写,因为这里只需要服务器地址和端口号就可以,所以模板文件如下:

启动consul-template

使用config.hcl配置文件是为了简化命令 consul-template -consul-addr=172.20.132.196:8500 -template=./template.ctmpl:./nginx.conf

初始的nignx.conf文件为空的,在启动后内容为

确保服务已经成功注册到Consul中,即可以看到服务器地址和端口已经配置进去了。

在nginx的安装目录的nginx.conf中引入consul-template生成的配置文件

注意生成的配置文件不能喝nginx本身的配置文件中内容重复!!!

启动一个服务实例,查看生成的nginx.conf文件会发现在upstream cloudsocket{}中会动态增加服务列表,并且随着服务的加入和离开,动态变化。

再启动一个,服务列表变成两个了

thrift客户端在调用的时候只需要配置Nginx的地址和端口就可以了,不需要配置服务的地址和端口了,Nginx会自动做转发。

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180413G1Q4DT00?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券