[发明专利]一种负载均衡实现方法、装置、设备及可读存储介质在审
申请号: | 201811513270.7 | 申请日: | 2018-12-11 |
公开(公告)号: | CN109639796A | 公开(公告)日: | 2019-04-16 |
发明(设计)人: | 张帅 | 申请(专利权)人: | 浪潮电子信息产业股份有限公司 |
主分类号: | H04L29/08 | 分类号: | H04L29/08;H04L29/12;H04L12/24 |
代理公司: | 北京集佳知识产权代理有限公司 11227 | 代理人: | 罗满 |
地址: | 250101 山东*** | 国省代码: | 山东;37 |
权利要求书: | 查看更多 | 说明书: | 查看更多 |
摘要: | |||
搜索关键词: | 负载均衡 带宽使用率 服务端 客户端 可读存储介质 虚拟IP地址 域名访问请求 计算机资源 客户端访问 最大化利用 访问目标 服务性能 获取目标 技术效果 节点确定 均衡策略 目标节点 实现装置 服务 带宽 发送 返回 配置 | ||
本发明公开了一种负载均衡实现方法,包括:当接收到客户端发送的域名访问请求时,判断当前服务端是否配置有带宽使用率均衡策略;若是,则在当前服务端中确定带宽使用率最小的节点,并将带宽使用率最小的节点确定为目标节点;获取目标节点的MAC地址,并将MAC地址对应的虚拟IP地址返回客户端,以使客户端通过虚拟IP地址访问目标节点,实现当前服务端的负载均衡。该方法可以使客户端访问当前服务端中带宽使用率最小的节点,能够最大化利用该节点的带宽,既不会浪费计算机资源,又实现了服务端的负载均衡,提高了服务端的服务性能。相应地,本发明公开的一种负载均衡实现装置、设备及可读存储介质,也同样具有上述技术效果。
技术领域
本发明涉及分布式存储技术领域,更具体地说,涉及一种负载均衡实现方法、装置、设备及可读存储介质。
背景技术
在分布式文件系统中,基于开源DNS服务组件Power DNS可以提供可控的轮询策略和连接数策略。
轮询策略需要根据域名解析顺序依次返回列表中的IP地址,会损耗较多的计算机资源,且此策略只能保证客户端访问均衡在各个节点上,但实际应用过程中各个节点的负载仍然是不均衡的。连接策略是将所有节点中连接数最少的节点确定为当前客户端要访问的节点,但由于存在连接并不意味着存在访问业务,所以连接数最小的节点并非是负载最小的节点。因此轮询策略和连接数策略并无法使服务端的负载均衡至各个节点,会降低服务端的服务性能。
因此,如何实现服务端的负载均衡,是本领域技术人员需要解决的问题。
发明内容
本发明的目的在于提供一种负载均衡实现方法、装置、设备及可读存储介质,以实现服务端的负载均衡。
为实现上述目的,本发明实施例提供了如下技术方案:
一种负载均衡实现方法,包括:
当接收到客户端发送的域名访问请求时,判断当前服务端是否配置有带宽使用率均衡策略;
若是,则在所述当前服务端中确定带宽使用率最小的节点,并将所述带宽使用率最小的节点确定为目标节点;
获取所述目标节点的MAC地址,并将所述MAC地址对应的虚拟IP地址返回所述客户端,以使所述客户端通过所述虚拟IP地址访问所述目标节点,实现所述当前服务端的负载均衡。
其中,所述在所述当前服务端中确定带宽使用率最小的节点,包括:
通过SNMP接收所述当前服务端中的各个节点发送的自身带宽使用率,并将每个节点的MAC地址与每个节点的带宽使用率对应记录,确定所述带宽使用率最小的节点。
其中,带宽使用率的计算步骤包括:
分别计算当前节点的接收网速和发送网速,并将当前节点的接收网速和发送网速之和确定为当前节点的带宽使用率。
其中,所述在所述当前服务端中确定带宽使用率最小的节点,包括:
获取所述当前服务端中的每个节点的数据包收发信息,并根据每个节点的数据包收发信息分别计算每个节点的带宽使用率;
将所有节点的带宽使用率降序或升序排列,并将每个节点的MAC地址与每个节点的带宽使用率对应记录;
在排列得到的序列中确定所述带宽使用率最小的节点。
其中,所述获取所述当前服务端中的每个节点的数据包收发信息,包括:
从所述当前服务端的系统文件中解析得到每个节点的网卡名称,并根据每个节点的网卡名称获取所述当前服务端中的每个节点的数据包收发信息。
其中,所述根据每个节点的网卡名称获取所述当前服务端中的每个节点的数据包收发信息,包括:
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于浪潮电子信息产业股份有限公司,未经浪潮电子信息产业股份有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201811513270.7/2.html,转载请声明来源钻瓜专利网。