您的位置:首页 > 运维架构 > Nginx

基于软件的负载均衡(Nginx与ZooKeeper解析)

2017-10-19 11:18 330 查看


什么是负载均衡

负载均衡(Load Balance)是分布式系统架构设计中必须考虑的因素之一,它通常是指,将请求/数据【均匀】分摊到多个操作单元上执行,负载均衡的关键在于【均匀】。常见互联网分布式架构如上,分为客户端层、反向代理nginx层、站点层、服务层、数据层。

现在使用最多的基于软件的负载均衡是Nginx和ZooKeeper: 

Nginx是著名的反向代理服务器,也被广泛的作为负载均衡服务器 

ZooKeeper是分布式协调服务框架,有时也被用来做负载均衡

那么它们有什么区别?我们还怎么选择

Nginx 



Nginx的负载均衡配置 

(1)把多个web server配置到nginx中,用户访问Nginx时,就会自动被分配到某个web server。 

(2)当网站规模变大,通常会进行服务拆分,各个服务独立部署,通过远程调用方式协同工作。 

(3)为了保证稳定性,每个服务不会只使用一台服务器,也会作为一个集群存在,那么子集群也可以使用Nginx负载均衡。

ZooKeeper 



ZooKeeper的负载均衡模式 

(1)ZooKeeper作为一个服务的注册中心,每个服务在其注册中心登记,每台服务器知道自己是属于哪个服务,在服务器启动时,自己向所属服务进行登记 

(2)服务的调用者到注册中心里面查找:能提供所需服务的服务器列表,然后自己根据负载均衡算法,从中选取一台服务器进行连接。 

(3)调用者取到服务器列表后,就可以缓存到自己内部,省得下次再取,当服务器列表发生变化,例如某台服务器宕机下线,或者新加了服务器,ZooKeeper会自动通知调用者重新获取服务器列表


使用场景

使用Nginx,随着整个系统的演进, 服务 的数量会 增加 、每个服务集群中的 服务器 数量会 增加 

这时就会有一些小麻烦,例如 

(1)配置维护的成本变高,因为节点太多 

(2)单点故障的风险增加了,因为热点服务的访问量很高,如果这个服务集群内的负载均衡服务出现问题,这个服务将失效 

第一个问题,可以通过自己开发程序解决,但只是降低复杂度,并没有实际解决 

第二个问题,可以通过双机高可用部署方案,使用另一台nginx负载均衡服务器随时待命,只是成本较高

而ZooKeeper作为服务的注册和变更通知中心,解决了Nginx负载均衡方案带来的问题。 

但是ZooKeeper并没有内置负载均衡策略,需要调用者自己实现,这个方案只是利用了ZooKeeper的树形数据结构、watcher机制等特性。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: