CN103533064A - 不间断网络用户在线状态的服务器程序升级方法 - Google Patents

不间断网络用户在线状态的服务器程序升级方法 Download PDF

Info

Publication number
CN103533064A
CN103533064A CN201310492761.9A CN201310492761A CN103533064A CN 103533064 A CN103533064 A CN 103533064A CN 201310492761 A CN201310492761 A CN 201310492761A CN 103533064 A CN103533064 A CN 103533064A
Authority
CN
China
Prior art keywords
program
server program
network
client
server
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Pending
Application number
CN201310492761.9A
Other languages
English (en)
Inventor
于龙
朱涛
赵西法
李元策
郝林
孙杰
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
JINAN ZHENGHE TECHNOLOGY Co Ltd
Original Assignee
JINAN ZHENGHE TECHNOLOGY Co Ltd
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by JINAN ZHENGHE TECHNOLOGY Co Ltd filed Critical JINAN ZHENGHE TECHNOLOGY Co Ltd
Priority to CN201310492761.9A priority Critical patent/CN103533064A/zh
Publication of CN103533064A publication Critical patent/CN103533064A/zh
Pending legal-status Critical Current

Links

Images

Landscapes

  • Information Transfer Between Computers (AREA)

Abstract

一种不间断网络用户在线状态的服务器程序升级方法,首先,分别建立一个独立的服务器程序A1和一个独立的服务器程序A2,A2只与A1建立一对一的网络连接,A1与所有客户端建立网络连接;关闭A2程序,进行程序替换;A1程序检测到与A2程序的连接断开后,缓存客户端发来的数据;待A2程序升级结束后,启动A2;A2程序与A1程序建立连接;A1程序检测到与A2程序的连接恢复后,将拥有的用户连接、在线状态等恢复信息发送给A2程序;A1程序将缓存的客户端数据转发给A2程序;A1程序开始进行正常的转发处理,A2程序开始正常的业务处理。本发明能在24小时不间断服务的情况下进行服务器程序替换升级,提供不间断的网络用户在线状态,实现简单。

Description

不间断网络用户在线状态的服务器程序升级方法
技术领域
本发明涉及计算机网络信息通信技术领域,具体说是一种基不间断网络用户在线状态的服务器程序升级方法。
背景技术
基于客户端/服务器端架构的网络服务器程序大多采用TCP或UDP协议提供网络应用服务,TCP协议相对于UDP协议具备了消息确认、流量控制机制,简化了应用层的数据传输的复杂度。由于功能增加,软件修改bug 等多方面的原因,需要对正在运行的服务器程序进行替换升级。
 目前,升级方法有两种,一种是关闭程序中断服务的升级方式,它不能满足不中断的业务要求,特别是对于即时通讯、文件传输等网络应用服务会对用户产生明显影响;另一种是不中断服务的升级方式,它通过负载均衡调度器将用户的请求调度到新的服务器程序,在相对用户透明的情况下与新的服务器程序建立连接,实现了不间断网络用户在线状态升级,但现有的网络连接是需要重新建立的,对于实时性要求比较高的网络应用服务会造成延迟、数据包丢失,且实现起来相对复杂,对环境要求较高。 
发明内容
为了克服上述现有技术存在的缺点,本发明的目的在于提供一种对客户端完全透明,始终保持用户在线状态的不间断网络用户在线状态的服务器程序升级方法。
    为了解决上述问题,本发明采用以下技术方案:一种不间断网络用户在线状态的服务器程序升级方法,其特征在于,包括以下步骤:
    S1,分别建立一个独立的服务器程序A1和一个独立的服务器程序A2,A2程序只与A1程序建立一对一的网络连接,A1程序与所有客户端建立网络连接;
    S2,需要对服务器程序A2升级时,关闭A2程序,进行程序替换;
    S3,A1程序检测到与A2程序的连接断开后,开始缓存客户端发来的数据;
    S4,待A2程序升级结束后,启动A2程序;
    S5,A2程序与A1程序建立连接;
    S6,A1程序检测到与A2程序的连接恢复后,将拥有的用户连接、在线状态等恢复信息发送给A2程序;
    S7,A1程序将缓存的客户端数据转发给A2程序;
    S8,A1程序开始在A2程序与客户端之间进行正常的转发处理,A2程序开始正常的业务处理。
    进一步的,在所述的S1步骤中A2程序与A1程序、A1程序与所有客户端建立的均为TCP网络连接。
    更进一步的,在所述的S3步骤中A1程序对客户端发来的数据按时间顺序进行缓存,在所述的S7步骤中A1程序将缓存的客户端数据按时间顺序转发给A2程序。
本发明的有益效果是:它能在24小时不间断服务的情况下进行服务器程序替换升级,提供不间断的网络用户在线状态,实现简单,不需要负责均衡调度器、客户端网络连接透明切换机制等复杂机制;在中间转发程序中加入数据缓存机制,具备了提供不间断业务服务的能力;在获得TCP协议提供的自动确认机制、流量控制机制等可靠性的同时,避免了TCP单向连接带来的局限性。
附图说明
下面结合附图和实施例对发明做进一步的说明:
图1为本发明的服务器升级方法流程图;
图2为本发明的服务器程序升级架构示意图。
具体实施方式
    如图1所示,本发明的一实施方式包括以下步骤:
    S1:分别建立一个独立的服务器程序A1和一个独立的服务器程序A2,A2程序只与A1程序建立一对一的网络连接,A1程序与所有客户端建立网络连接;
    S2:需要对服务器程序A2升级时,关闭A2程序,进行程序替换;
    S3:A1程序检测到与A2程序的连接断开后,开始缓存客户端发来的数据;
    S4:待A2程序升级结束后,启动A2;
    S5:A2程序与A1程序建立连接;
    S6:A1程序检测到与A2程序的连接恢复后,将拥有的用户连接、在线状态等恢复信息发送给A2程序;
    S7:A1程序将缓存的客户端数据转发给A2程序;
    S8:A1程序开始在A2程序与客户端之间进行正常的转发处理,A2程序开始正常的业务处理。
在S1中A2程序与A1程序、A1程序与所有客户端建立的均为TCP网络连接。
在S3中A1程序对客户端发来的数据按时间顺序进行缓存,在S7中A1程序将缓存的客户端数据按时间顺序转发给A2程序。
如图2所示,本发明提供的架构将网络应用服务器程序中的面向客户端的网络连接监听模块拆分为一个独立的服务器程序A1,原有核心处理模块拆分为一个独立的服务器程序A2,A2程序只与A1程序建立一对一的TCP网络连接,A1程序与所有客户端建立TCP网络连接,并在A2程序与客户端之间进行数据转发。通过提供一个相对客户端透明的、具备数据转发功能的A1程序,就能实现在核心处理模块进行替换的同时,不间断A1程序与客户端的连接,维持用户的在线状态。
本发明具有以下三个重要特征:这里有几个重要特征:
      特征一:升级过程对客户端透明。客户端只与A1程序进行TCP协议上的网络连接维护、数据通信,在升级过程中A1与A2程序的连接断开、建立及A2程序的状态变化对客户端完全透明。在不需要其他机制的情况下,用户感觉不出提供服务对象的变化。
特征二:用户在线状态的持续性。在整个升级过程中,客户端与A1程序的TCP连接不会断开,用户在线状态不会丢失,并且在A2程序替换运行后,A2会首先获的A1发来的实时的用户在线状态,进行状态恢复,不会造成在线状态不一致导致的业务处理错误。
特征三:业务不间断性。在A2程序关闭进行替换的过程中,A1程序可不间断的接收客户端发来的数据请求,并在本地进行按时间顺序缓存,在A2程序替换运行后,会按顺序将缓存的数据转发到A2程序,在进行后续的转发操作,保证了替换过程中的业务不间断性。
以上所述只是本发明的优选实施方式,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也被视为本发明的保护范围。

Claims (3)

1. 一种不间断网络用户在线状态的服务器程序升级方法,其特征在于,包括以下步骤:
    S1,分别建立一个独立的服务器程序A1和一个独立的服务器程序A2,A2程序只与A1程序建立一对一的网络连接,A1程序与所有客户端建立网络连接;
    S2,需要对服务器程序A2升级时,关闭A2程序,进行程序替换;
    S3,A1程序检测到与A2程序的连接断开后,开始缓存客户端发来的数据;
    S4,待A2程序升级结束后,启动A2;
    S5,A2程序与A1程序建立连接;
    S6,A1程序检测到与A2程序的连接恢复后,将拥有的用户连接、在线状态等恢复信息发送给A2程序;
    S7,A1程序将缓存的客户端数据转发给A2程序;
    S8,A1程序开始在A2程序与客户端之间进行正常的转发处理,A2程序开始正常的业务处理。
2.根据权利要求1所述的不间断网络用户在线状态的服务器程序升级方法,其特征在于,在所述的S1步骤中A2程序与A1程序、A1程序与所有客户端建立的均为TCP网络连接。
3.根据权利要求1或2所述的不间断网络用户在线状态的服务器程序升级方法,其特征在于,在所述的S3步骤中A1程序对客户端发来的数据按时间顺序进行缓存,在所述的S7步骤中A1程序将缓存的客户端数据按时间顺序转发给A2程序。
CN201310492761.9A 2013-10-21 2013-10-21 不间断网络用户在线状态的服务器程序升级方法 Pending CN103533064A (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201310492761.9A CN103533064A (zh) 2013-10-21 2013-10-21 不间断网络用户在线状态的服务器程序升级方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201310492761.9A CN103533064A (zh) 2013-10-21 2013-10-21 不间断网络用户在线状态的服务器程序升级方法

Publications (1)

Publication Number Publication Date
CN103533064A true CN103533064A (zh) 2014-01-22

Family

ID=49934729

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201310492761.9A Pending CN103533064A (zh) 2013-10-21 2013-10-21 不间断网络用户在线状态的服务器程序升级方法

Country Status (1)

Country Link
CN (1) CN103533064A (zh)

Cited By (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105049478A (zh) * 2015-05-26 2015-11-11 北京中亦安图科技股份有限公司 数据传输系统及利用该系统进行上行数据传输的方法
CN105120005A (zh) * 2015-09-11 2015-12-02 厦门喜鱼网络科技有限公司 一种游戏服务器热更新方法、服务器及系统
CN106301820A (zh) * 2015-05-15 2017-01-04 阿里巴巴集团控股有限公司 一种基于网络连接服务的升级方法和装置
CN106598648A (zh) * 2016-11-10 2017-04-26 北京三快在线科技有限公司 一种服务器程序升级的控制方法及装置
CN106686066A (zh) * 2017-02-10 2017-05-17 上海斐讯数据通信技术有限公司 一种长连接服务器升级方法及系统
CN111431750A (zh) * 2020-03-31 2020-07-17 广东金宇恒软件科技有限公司 一种用于财政预算在线联网监督系统的断网保护装置

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020078170A1 (en) * 2000-12-15 2002-06-20 International Business Machines Corporation Method and system for minimizing network bandwidth bottlenecks
CN101616028A (zh) * 2009-06-25 2009-12-30 中兴通讯股份有限公司 一种通信程序业务不中断升级方法及系统
CN102299940A (zh) * 2010-06-25 2011-12-28 龚华清 一种不间断网络服务的软件升级方法
CN103064711A (zh) * 2012-12-27 2013-04-24 北京思特奇信息技术股份有限公司 一种基于Spread分布式应用系统的热加载方法

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020078170A1 (en) * 2000-12-15 2002-06-20 International Business Machines Corporation Method and system for minimizing network bandwidth bottlenecks
CN101616028A (zh) * 2009-06-25 2009-12-30 中兴通讯股份有限公司 一种通信程序业务不中断升级方法及系统
CN102299940A (zh) * 2010-06-25 2011-12-28 龚华清 一种不间断网络服务的软件升级方法
CN103064711A (zh) * 2012-12-27 2013-04-24 北京思特奇信息技术股份有限公司 一种基于Spread分布式应用系统的热加载方法

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
张敏狄等: "分布式网络设备的业务不中断软件升级系统设计", 《计算机系统应用》, vol. 19, no. 6, 31 December 2010 (2010-12-31), pages 40 - 43 *

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN106301820A (zh) * 2015-05-15 2017-01-04 阿里巴巴集团控股有限公司 一种基于网络连接服务的升级方法和装置
CN105049478A (zh) * 2015-05-26 2015-11-11 北京中亦安图科技股份有限公司 数据传输系统及利用该系统进行上行数据传输的方法
CN105120005A (zh) * 2015-09-11 2015-12-02 厦门喜鱼网络科技有限公司 一种游戏服务器热更新方法、服务器及系统
CN105120005B (zh) * 2015-09-11 2019-01-22 厦门喜鱼网络科技有限公司 一种游戏服务器热更新方法、服务器及系统
CN106598648A (zh) * 2016-11-10 2017-04-26 北京三快在线科技有限公司 一种服务器程序升级的控制方法及装置
CN106686066A (zh) * 2017-02-10 2017-05-17 上海斐讯数据通信技术有限公司 一种长连接服务器升级方法及系统
CN111431750A (zh) * 2020-03-31 2020-07-17 广东金宇恒软件科技有限公司 一种用于财政预算在线联网监督系统的断网保护装置

Similar Documents

Publication Publication Date Title
CN103533064A (zh) 不间断网络用户在线状态的服务器程序升级方法
CN103188653B (zh) 接收数据的方法、发送数据的方法、移动终端和服务器
CN102880475B (zh) 计算机软件系统中基于云计算的实时事件处理系统及方法
US8914449B2 (en) Push messaging platform with high scalability and high availability
CN102395119B (zh) 一种支持应用客户端永久在线的方法、系统及装置
CN111934840A (zh) 客户端和服务端的通信方法、网关、电子设备及存储介质
CN103312766A (zh) 一种支持应用客户端永久在线的方法、系统及装置
CN101969463A (zh) 一种网页上实现白板全屏同步的方法
WO2015078341A1 (zh) 应用程序远程更新的方法和装置
CN102209047A (zh) 一种信息共享的即时通讯系统及方法
CN102196011A (zh) 一种利用推送服务提供应用信息的方法及系统
CN101448004A (zh) 基于即时通信的用户状态发布方法、服务器及系统
CN103138985A (zh) 一种支撑网业务主机进程控制方法和系统
CN101720133A (zh) 一种嵌入式系统软件的远程升级方法及系统
CN104468380A (zh) 一种接入点设备与服务器交互的接口通信方法
CN102611717A (zh) 一种业务数据发送方法、系统、客户端代理及服务器代理
CN107529229A (zh) 数据传输的方法,装置及系统
CN107707689A (zh) 一种dhcp报文处理方法、dhcp服务器及网关设备
CN103001787A (zh) 用于数据处理中心容灾备份的系统及方法
CN102231699B (zh) 分布式系统中路由处理方法和分布式系统
CN102360473A (zh) 一种省地电力调度自动化系统间数据共享方法
WO2024103943A1 (zh) 一种业务处理方法、装置、存储介质及设备
CN116192863B (zh) 微服务流量处理方法、dpu服务网格部署方法及系统
CN109617228B (zh) 一种配网分布式馈线自动化系统
CN106357454A (zh) 日志系统控制装置及其控制方法

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
RJ01 Rejection of invention patent application after publication

Application publication date: 20140122

RJ01 Rejection of invention patent application after publication