多台服务器负载均衡,怎么选择?

一个公网ip对应一个虚拟ip,这个虚拟ip对应多台负载均衡服务器,那一个请求进来,怎么知道是选择哪一台负载均衡服务器呢?有什么算法吗?求大神!!!

一般用的就用简单的轮询就好了
调度算法
静态方法:仅根据算法本身实现调度;实现起点公平,不管服务器当前处理多少请求,分配的数量一致
动态方法:根据算法及后端RS当前的负载状况实现调度;不管以前分了多少,只看分配的结果是不是公平
静态调度算法(static Schedu)(4种):
(1)rr (Round Robin) :轮叫,轮询
说明:轮询调度算法的原理是每一次把来自用户的请求轮流分配给内部中的服务器,从1开始,直到N(内部服务器个数),然后重新开始循环。算法的优点是其简洁性,它无需记录当前所有连接的状态,所以它是一种无状态调度。缺点:是不考虑每台服务器的处理能力。
(2)wrr (Weight Round Robin) :加权轮询(以权重之间的比例实现在各主机之间进行调度)
说明:由于每台服务器的配置、安装的业务应用等不同,其处理能力会不一样。所以,我们根据服务器的不同处理能力,给每个服务器分配不同的权值,使其能够接受相应权值数的服务请求。
(3)sh (Source Hashing) : 源地址hash实现会话绑定sessionaffinity
说明:简单的说就是有将同一客户端的请求发给同一个real server,源地址散列调度算法正好与目标地址散列调度算法相反,它根据请求的源IP地址,作为散列键(Hash Key)从静态分配的散列表找出对应的服务器,若该服务器是可用的并且没有超负荷,将请求发送到该服务器,否则返回空。它采用的散列函数与目标地址散列调度算法的相同。它的算法流程与目标地址散列调度算法的基本相似,除了将请求的目标IP地址换成请求的源IP地址。
(4)dh : (Destination Hashing) : 目标地址hash
说明:将同样的请求发送给同一个server,一般用于缓存服务器,简单的说,LB集群后面又加了一层,在LB与realserver之间加了一层缓存服务器,当一个客户端请求一个页面时,LB发给cache1,当第二个客户端请求同样的页面时,LB还是发给cache1,这就是我们所说的,将同样的请求发给同一个server,来提高缓存的命中率。目标地址散列调度算法也是针对目标IP地址的负载均衡,它是一种静态映射算法,通过一个散列(Hash)函数将一个目标IP地址映射到一台服务器。目标地址散列调度算法先根据请求的目标IP地址,作为散列键(Hash Key)从静态分配的散列表找出对应的服务器,若该服务器是可用的且未超载,将请求发送到该服务器,否则返回空。
动态调度算法(dynamic Schedu)(6种):
(1)lc (Least-Connection Scheduling): 最少连接
说明:最少连接调度算法是把新的连接请求分配到当前连接数最小的服务器,最小连接调度是一种动态调度短算法,它通过服务器当前所活跃的连接数来估计服务器的负载均衡,调度器需要记录各个服务器已建立连接的数目,当一个请求被调度到某台服务器,其连接数加1,当连接中止或超时,其连接数减一,在系统实现时,我们也引入当服务器的权值为0时,表示该服务器不可用而不被调度。此算法忽略了服务器的性能问题,有的服务器性能好,有的服务器性能差,通过加权重来区分性能,所以有了下面算法wlc。
简单算法:active*256+inactive (谁的小,挑谁)
(2)wlc (Weighted Least-Connection Scheduling):加权最少连接
加权最小连接调度算法是最小连接调度的超集,各个服务器用相应的权值表示其处理性能。服务器的缺省权值为1,系统管理员可以动态地设置服务器的权限,加权最小连接调度在调度新连接时尽可能使服务器的已建立连接数和其权值成比例。由于服务器的性能不同,我们给性能相对好的服务器,加大权重,即会接收到更多的请求。
简单算法:(active*256+inactive)/weight(谁的小,挑谁)
(3)sed (shortest expected delay scheduling):最少期望延迟
说明:不考虑非活动连接,谁的权重大,我们优先选择权重大的服务器来接收请求,但会出现问题,就是权重比较大的服务器会很忙,但权重相对较小的服务器很闲,甚至会接收不到请求,所以便有了下面的算法nq。
基于wlc算法,简单算法:(active+1)*256/weight (谁的小选谁)
(4).nq (Never Queue Scheduling): 永不排队
说明:在上面我们说明了,由于某台服务器的权重较小,比较空闲,甚至接收不到请求,而权重大的服务器会很忙,所此算法是sed改进,就是说不管你的权重多大都会被分配到请求。简单说,无需队列,如果有台real server的连接数为0就直接分配过去,不需要在进行sed运算。
(5).LBLC(Locality-Based Least Connections) :基于局部性的最少连接
说明:基于局部性的最少连接算法是针对请求报文的目标IP地址的负载均衡调度,主要用于Cache集群系统,因为Cache集群中客户请求报文的目标IP地址是变化的,这里假设任何后端服务器都可以处理任何请求,算法的设计目标在服务器的负载基本平衡的情况下,将相同的目标IP地址的请求调度到同一个台服务器,来提高服务器的访问局部性和主存Cache命中率,从而调整整个集群系统的处理能力。
(6).LBLCR(Locality-Based Least Connections with Replication) :基于局部性的带复制功能的最少连接
说明:基于局部性的带复制功能的最少连接调度算法也是针对目标IP地址的负载均衡,该算法根据请求的目标IP地址找出该目标IP地 址对应的服务器组,按“最小连接”原则从服务器组中选出一台服务器,若服务器没有超载,将请求发送到该服务器;若服务器超载,则按“最小连接”原则从这个集群中选出一台服务器,将该服务器加入到服务器组中,将请求发送到该服务器。同时,当该服务器组有一段时间没有被修改,将最忙的服务器从服务器组中删除, 以降低复制的程度。
温馨提示:内容为网友见解,仅供参考
无其他回答

多台服务器负载均衡,怎么选择?
说明:基于局部性的带复制功能的最少连接调度算法也是针对目标IP地址的负载均衡,该算法根据请求的目标IP地址找出该目标IP地 址对应的服务器组,按“最小连接”原则从服务器组中选出一台服务器,若服务器没有超载,将请求发送到该服务器;若服务器超载,则按“最小连接”原则从这个集群中选出一台服务...

什么是负载均衡原理及其作用
轮询算法是较简单的负载均衡算法,其规则是按照请求到达的顺序依次将请求分配到不同的服务器上。这种算法可以平均分配请求流量,但如果服务器的配置不同,则可能导致一些服务器的能损失。2. 随机算法 随机算法会根据请求的随机度分发到多台服务器上,分配请求的算法与轮询算法相近,但能不同。随机分配不会...

cpu负载均衡怎么设置
服务器用shared IP Address这个命令当作网关,然后在两台F5上分别配置对应的Mac Masquerade,这样做的目的是保证不间断。第六步对于pool的配置重点:我们在相关Web操作页面当中选择“Pools”中的“Pools”相应标签,然后点“ADD”就可以进行添加。然后在池属性“Load Balancing Method”相应列表上选负载均衡策...

双路网络宽带负载怎么设置多线负载?
c. 调整负载均衡算法:负载均衡器通常会使用一种算法来决定如何分配流量。根据你的需求,你可以选择合适的算法。常见的算法包括轮询、加权轮询、最小连接等。d. 配置其他参数:根据设备的要求,你可能需要进行其他相关的配置,例如连接超时时间、故障转移设置等。测试和监控:完成配置后,进行测试以确保负载...

U8服务器参数配置中负载均衡如何设置
网络的负载均衡是一种动态均衡技术,通过一些工具实时地分析数据包,掌握网络中的数据流量状况,把任务合理均衡地分配出去。这种技术基于现有网络结构,提供了一种扩展服务器带宽和增加服务器吞吐量的廉价有效的方法,加强了网络数据处理能力,提高了网络的灵活性和可用性。

DNS循环复用四台服务器的负载均衡实例
打开DNS控制台,创建正向搜索区域,选择标准主要区域类型。对172.28.20.2、172.28.20.3、172.28.20.4进行顺序应答设置,每次请求会轮询,确保负载均衡。为了验证负载均衡效果,建议使用多台电脑或在ping测试后刷新DNS缓存,确保每次查询都能得到不同的IP响应。需要注意的是,当服务器不在同一网段时,...

多台服务器负载均衡的压力测试要怎么做
负载均衡是算法上的问题,按常规软件测试的方式来。如果负载没问题,那理论上压力测试只要测单个服务就行了。

N台电脑做负载均衡集群后,此时就像一台电脑,举例,三个服务器集群,那该...
上图为百度中资料截图,个人理解应该有一个主、从关系。应该是在安装集群软件的服务器或PC电脑上操作。无论多少台服务器做集群,对外的IP地址,应该也只有一个主IP,通过一些软件可以通过此IP对集群进行操作。

多台服务器负载均衡,各位做过吗
1、DNS负载均衡 最早的负载均衡技术是通过DNS来实现的,在DNS中为多个地址配置同一个名字,因而查询这个名字的客户机将得到其中一个地址,从而使得不同的客户访问不同的服务器,达到负载均衡的目的。DNS负载均衡是一种简单而有效的方法,但是它不能区分服务器的差异,也不能反映服务器的当前运行状态。2、...

怎么实现服务器的负载均衡?
1.硬件方面,可以用F5做负载,内置几十种算法。2.软件方面,可以使用反向代理服务器,例如apache,Nginx等高可用反向代理服务器。利用DNSPOD智能解析的功能,就可以实现多台机器负载均衡.首先你用一台高配置的机器来当数据库服务器.然后把网站的前端页面复制成多份,分别放在其他的几台机器上面.再用DNSPOD做...

相似回答