[发明专利]一种服务器连接方法、计算机可读存储介质及终端设备有效
| 申请号: | 201810341964.0 | 申请日: | 2018-04-17 |
| 公开(公告)号: | CN108769111B | 公开(公告)日: | 2020-01-24 |
| 发明(设计)人: | 王丽 | 申请(专利权)人: | 平安科技(深圳)有限公司 |
| 主分类号: | H04L29/08 | 分类号: | H04L29/08 |
| 代理公司: | 44237 深圳中一专利商标事务所 | 代理人: | 官建红 |
| 地址: | 518000 广东省深*** | 国省代码: | 广东;44 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 终端设备 哈希 基准节点 计算机可读存储介质 服务器连接 优选服务器 身份标识 计算机技术领域 服务器确定 服务器资源 哈希函数 哈希运算 通信连接 消息重发 顺时针 映射 预设 查找 | ||
本发明属于计算机技术领域,尤其涉及一种服务器连接方法、计算机可读存储介质及终端设备。所述方法本发明实施例获取终端设备的身份标识;使用预设的第一哈希函数对所述身份标识进行哈希运算,得到所述终端设备的哈希值;将所述终端设备的哈希值映射至哈希环的第一节点;获取所述哈希环上的各个基准节点;从所述第一节点开始顺时针或者逆时针查找所述基准节点,并将查找到的第一个基准节点所对应的服务器确定为优选服务器;建立所述终端设备与所述优选服务器之间的通信连接。减少了服务器资源的浪费,也大大降低了消息重发的几率。
技术领域
本发明属于计算机技术领域,尤其涉及一种服务器连接方法、计算机可读存储介质及终端设备。
背景技术
消息推送的基础需要保持用户的终端设备与服务器建立的长连接。随着用户的终端设备数量不断增加,长连接服务器也需要随时横向扩容。目前建立长连接的方式是由用户的终端设备随机请求某台服务器来保持长连接。这种情况下,推送消息时就需要将消息分发给每一台服务器,由保持长连接的那一台服务器推送至用户的终端设备,不仅造成服务器资源的浪费,也增大消息重发的几率。
发明内容
有鉴于此,本发明实施例提供了一种服务器连接方法、计算机可读存储介质及终端设备,以解决由用户的终端设备随机请求某台服务器来保持长连接所造成的服务器资源浪费以及消息重发几率增大的问题。
本发明实施例的第一方面提供了一种服务器连接方法,可以包括:
获取终端设备的身份标识;
使用预设的第一哈希函数对所述身份标识进行哈希运算,得到所述终端设备的哈希值;
将所述终端设备的哈希值映射至哈希环的第一节点,所述哈希环为由所述第一哈希函数的所有函数值按照从小到大的顺序顺时针或者逆时针依次连接所构成的圆环,每个节点均为构成所述哈希环的一个函数值,所述第一节点为所述哈希环上的任意一个节点;
获取所述哈希环上的各个基准节点,其中,每个基准节点均为所述哈希环上与一个服务器对应的节点;
从所述第一节点开始顺时针或者逆时针查找所述基准节点,并将查找到的第一个基准节点所对应的服务器确定为优选服务器;
建立所述终端设备与所述优选服务器之间的通信连接。
本发明实施例的第二方面提供了一种计算机可读存储介质,所述计算机可读存储介质存储有计算机可读指令,所述计算机可读指令被处理器执行时实现如下步骤:
获取终端设备的身份标识;
使用预设的第一哈希函数对所述身份标识进行哈希运算,得到所述终端设备的哈希值;
将所述终端设备的哈希值映射至哈希环的第一节点,所述哈希环为由所述第一哈希函数的所有函数值按照从小到大的顺序顺时针或者逆时针依次连接所构成的圆环,每个节点均为构成所述哈希环的一个函数值,所述第一节点为所述哈希环上的任意一个节点;
获取所述哈希环上的各个基准节点,其中,每个基准节点均为所述哈希环上与一个服务器对应的节点;
从所述第一节点开始顺时针或者逆时针查找所述基准节点,并将查找到的第一个基准节点所对应的服务器确定为优选服务器;
建立所述终端设备与所述优选服务器之间的通信连接。
本发明实施例的第三方面提供了一种服务器连接终端设备,包括存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机可读指令,所述处理器执行所述计算机可读指令时实现如下步骤:
获取终端设备的身份标识;
使用预设的第一哈希函数对所述身份标识进行哈希运算,得到所述终端设备的哈希值;
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于平安科技(深圳)有限公司,未经平安科技(深圳)有限公司许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/201810341964.0/2.html,转载请声明来源钻瓜专利网。





