一种服务下线方法、装置及存储介质制造方法及图纸

技术编号:39254022 阅读:11 留言:0更新日期:2023-10-30 12:05
本发明专利技术实施例公开一种服务下线方法、装置、电子设备及存储介质,涉及计算机软件技术领域,能够提高服务的高可用性,降低因服务直接下线带来的服务异常概率。所述方法包括:向注册中心或流量均衡服务器发送服务下线请求,以使所述注册中心或流量均衡服务器注销所述服务;响应于所述注册中心或流量均衡服务器发送的停机设置请求,将所述服务的服务状态标志设置为停机;判断所述服务是否满足下线条件;若所述服务满足下线条件,则下线所述服务。本发明专利技术可用于服务的安全下线的场合。发明专利技术可用于服务的安全下线的场合。发明专利技术可用于服务的安全下线的场合。

【技术实现步骤摘要】
一种服务下线方法、装置及存储介质


[0001]本专利技术涉及计算机软件
,尤其涉及一种服务下线方法、装置、电子设备及存储介质。

技术介绍

[0002]服务请求通过负载均衡策略路由到实际的服务中进行业务处理,当线上服务需要停机下线时,持续的业务流量会被路由到正在执行停机的服务上,如果强制执行停机,服务会拒绝进行业务处理,会导致用户请求得不到正确响应,影响用户体验。导致该问题存在的根本原因是注册中心与服务会对依赖的服务信息进行缓存,服务虽然开始下线,但缓存更新依然存在时间差,导致错误调用执行停机的服务造成,同时缓存为了平衡性能和时间问题,还无法做到实时更新。
[0003]目前业内主流的解决方案是通过注册中心下线服务完成后主动通知服务可以执行下线,并调整缩短缓存更新时间的方案,但仍然存在因缓存更新时间差而导致的服务异常概率高的问题。

技术实现思路

[0004]有鉴于此,本专利技术实施例提供一种服务下线方法、装置、电子设备及存储介质,能够提高服务的高可用性,降低因服务直接下线带来的服务异常概率。
[0005]在第一方面,本专利技术实施例提供一种服务下线方法,应用于服务提供方,包括:
[0006]向注册中心或流量均衡服务器发送服务下线请求,以使所述注册中心或流量均衡服务器注销所述服务;
[0007]响应于所述注册中心或流量均衡服务器发送的停机设置请求,将所述服务的服务状态标志设置为停机;
[0008]判断所述服务是否满足下线条件;
[0009]若所述服务满足下线条件,则下线所述服务。
[0010]结合第一方面,在第一方面的第一种实施方式中,所述判断所述服务是否满足下线条件,包括:
[0011]判断将所述服务的服务状态标志设置为停机后,经过的时间长度是否满足预设时长阈值;
[0012]若将所述服务的服务状态标志设置为停机后,经过的时间长度满足预设时长阈值,则确定所述服务满足下线条件。
[0013]结合第一方面,在第一方面的第二种实施方式中,所述判断所述服务是否满足下线条件,包括:
[0014]将所述服务的服务状态标志设置为停机后,开始记录进入所述服务的流量的时间戳;
[0015]基于所述时间戳,判断预设时间窗口内进入所述服务的流量是否小于预设流量阈
值;
[0016]若预设时间窗口内进入所述服务的流量小于预设流量阈值,则确定所述服务满足下线条件。
[0017]结合第一方面的第二种实施方式,在第一方面的第三种实施方式中,所述记录进入所述服务的流量的时间戳,包括:
[0018]将进入所述服务的流量的时间戳,放入时间戳链表的时间戳节点中;其中,每个时间戳节点包括存放的时间戳、指向前一个时间戳节点的指针地址和指向后一个时间戳节点的指针地址。
[0019]结合第一方面的第三种实施方式,在第一方面的第四种实施方式中,所述将进入所述服务的流量的时间戳,放入时间戳链表的时间戳节点中,包括:
[0020]将最新进入所述服务的流量的时间戳,放入时间戳链表中处于队首的一时间戳节点中。
[0021]结合第一方面的第二种实施方式,在第一方面的第五种实施方式中,所述基于所述时间戳,判断预设时间窗口内进入所述服务的流量是否小于预设流量阈值,包括:
[0022]基于所述时间戳,判断预设固定时间窗口内或预设滑动时间窗口内进入所述服务的流量是否小于预设流量阈值;
[0023]其中,所述若预设时间窗口内进入所述服务的流量小于预设流量阈值,则确定所述服务满足下线条件,包括:
[0024]若预设固定时间窗口内或预设滑动时间窗口内进入所述服务的流量小于预设流量阈值,则确定所述服务满足下线条件。
[0025]在第二方面,本专利技术实施例提供一种服务下线装置,应用于服务提供方,包括:
[0026]下线请求模块,用于向注册中心或流量均衡服务器发送服务下线请求,以使所述注册中心或流量均衡服务器注销所述服务;
[0027]停机标志设置模块,用于响应于所述注册中心或流量均衡服务器发送的停机设置请求,将所述服务的服务状态标志设置为停机;
[0028]下线判断模块,用于判断所述服务是否满足下线条件;
[0029]下线执行模块,用于若所述服务满足下线条件,则下线所述服务。
[0030]结合第二方面,在第二方面的第一种实施方式中,所述下线判断模块,包括:
[0031]时长判断单元,用于判断将所述服务的服务状态标志设置为停机后,经过的时间长度是否满足预设时长阈值;若将所述服务的服务状态标志设置为停机后,经过的时间长度满足预设时长阈值,则确定所述服务满足下线条件。
[0032]结合第二方面,在第二方面的第二种实施方式中,所述下线判断模块,包括:
[0033]流量记录单元,用于将所述服务的服务状态标志设置为停机后,开始记录进入所述服务的流量的时间戳;
[0034]流量判断单元,用于基于所述时间戳,判断预设时间窗口内进入所述服务的流量是否小于预设流量阈值;若预设时间窗口内进入所述服务的流量小于预设流量阈值,则确定所述服务满足下线条件。
[0035]结合第二方面的第二种实施方式,在第二方面的第三种实施方式中,所述流量记录单元用于将进入所述服务的流量的时间戳,放入时间戳链表的时间戳节点中;其中,每个
时间戳节点包括存放的时间戳、指向前一个时间戳节点的指针地址和指向后一个时间戳节点的指针地址。
[0036]结合第二方面的第三种实施方式,在第二方面的第四种实施方式中,所述将进入所述服务的流量的时间戳,放入时间戳链表的时间戳节点中,包括:
[0037]将最新进入所述服务的流量的时间戳,放入时间戳链表中处于队首的一时间戳节点中。
[0038]结合第二方面的第二种实施方式,在第二方面的第五种实施方式中,所述流量判断单元,包括:
[0039]基于所述时间戳,判断预设固定时间窗口内或预设滑动时间窗口内进入所述服务的流量是否小于预设流量阈值;
[0040]其中,所述若预设时间窗口内进入所述服务的流量小于预设流量阈值,则确定所述服务满足下线条件,包括:
[0041]若预设固定时间窗口内或预设滑动时间窗口内进入所述服务的流量小于预设流量阈值,则确定所述服务满足下线条件。
[0042]在第三方面,本专利技术实施例提供一种电子设备,所述电子设备包括:壳体、处理器、存储器、电路板和电源电路,其中,电路板安置在壳体围成的空间内部,处理器和存储器设置在电路板上;电源电路,用于为上述电子设备的各个电路或器件供电;存储器用于存储可执行程序代码;处理器通过读取存储器中存储的可执行程序代码来运行与可执行程序代码对应的程序,用于执行本专利技术的前述任一实施例提供的服务下线方法。
[0043]在第二方面,本专利技术实施例提供一种计算机可读存储介质,所述计算机可读存储介质存储有一个或者多个程序,所述一个或者多个程序可被一个或者多个处理器执行,以实现本专利技术本文档来自技高网
...

【技术保护点】

【技术特征摘要】
1.一种服务下线方法,其特征在于,应用于服务提供方,所述服务下线方法包括:向注册中心或流量均衡服务器发送服务下线请求,以使所述注册中心或流量均衡服务器注销所述服务;响应于所述注册中心或流量均衡服务器发送的停机设置请求,将所述服务的服务状态标志设置为停机;判断所述服务是否满足下线条件;若所述服务满足下线条件,则下线所述服务。2.根据权利要求1所述的服务下线方法,其特征在于,所述判断所述服务是否满足下线条件,包括:判断将所述服务的服务状态标志设置为停机后,经过的时间长度是否满足预设时长阈值;若将所述服务的服务状态标志设置为停机后,经过的时间长度满足预设时长阈值,则确定所述服务满足下线条件。3.根据权利要求1所述的服务下线方法,其特征在于,所述判断所述服务是否满足下线条件,包括:将所述服务的服务状态标志设置为停机后,开始记录进入所述服务的流量的时间戳;基于所述时间戳,判断预设时间窗口内进入所述服务的流量是否小于预设流量阈值;若预设时间窗口内进入所述服务的流量小于预设流量阈值,则确定所述服务满足下线条件。4.根据权利要求3所述的服务下线方法,其特征在于,所述记录进入所述服务的流量的时间戳,包括:将进入所述服务的流量的时间戳,放入时间戳链表的时间戳节点中;其中,每个时间戳节点包括存放的时间戳、指向前一个时间戳节点的指针地址和指向后一个时间戳节点的指针地址。5.根据权利要求4所述的服务下线方法,其特征在于,所述将进入所述服务的流量的时间戳,放入时间戳链表的时间戳节点中,包括:将最新进入所述服务的流量的时间戳,放入时间戳链表中处于队首的一时间戳节点中。6.根据权利要求3所述的服务下线方法,其特征在于,所述基于所述时间戳,判断预设时间窗口内进入所述服务的流量是否小于预设流量阈值,包括:基于所述时间戳,判断预设固定时间窗口...

【专利技术属性】
技术研发人员:梁贵川董凡东毕迎迎贾朝辉
申请(专利权)人:鼎道智联北京科技有限公司
类型:发明
国别省市:

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1