CN105282245A - Server-crossing message pushing system and method - Google Patents

Server-crossing message pushing system and method Download PDF

Info

Publication number
CN105282245A
CN105282245A CN201510634511.3A CN201510634511A CN105282245A CN 105282245 A CN105282245 A CN 105282245A CN 201510634511 A CN201510634511 A CN 201510634511A CN 105282245 A CN105282245 A CN 105282245A
Authority
CN
China
Prior art keywords
push
message
server
queue
producer
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.)
Granted
Application number
CN201510634511.3A
Other languages
Chinese (zh)
Other versions
CN105282245B (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.)
Nubia Technology Co Ltd
Original Assignee
Nubia 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 Nubia Technology Co Ltd filed Critical Nubia Technology Co Ltd
Priority to CN201510634511.3A priority Critical patent/CN105282245B/en
Publication of CN105282245A publication Critical patent/CN105282245A/en
Application granted granted Critical
Publication of CN105282245B publication Critical patent/CN105282245B/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/55Push-based network services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W4/00Services specially adapted for wireless communication networks; Facilities therefor
    • H04W4/12Messaging; Mailboxes; Announcements

Abstract

The invention discloses a server-crossing message pushing system, and the system comprises a production module which is used for enabling a to-be-pushed message to be added to a producer queue, and enabling the to-be-pushed message to be distributed to a corresponding consumer queue through the producer queue; a consumer module which is used for informing corresponding push servers of the to-be-pushed message in the consumer queue; and a push module which is used for transmitting the to-be-pushed message to a target client through the push server, so that the target client carries out message pushing. The invention also provides a server-crossing message pushing method. The system and method enable the to-be-pushed message to be shared, and solve a problem that a part of servers cannot receive the corresponding pushed messages during server-crossing message pushing. The system and method can achieve the lateral extension of servers when the pressure of servers is increased, so as to alleviate the pressure of the servers.

Description

Cross-server message push system and method
Technical field
The present invention relates to field, particularly relate to a kind of cross-server message push system and method.
Background technology
Message push mode traditional is at present all send a request to service end by client according to predetermined period, then by service end when receiving described request return data to this client, carry out in this way in message push process, need ceaselessly to send request to service end, a large amount of bandwidth can be taken, consume a large amount of server resources.Therefore the mode of being carried out message push by push server is created, carry out in this way in message push process, although avoid the problem not stopping to send request to service end, but along with the continuous expansion of user base number, need in good time expansion push server, due to expansion server between message can not share, make cross-server carry out in message push process, often cause part server cannot receive the problem of corresponding PUSH message.
Foregoing, only for auxiliary understanding technical scheme of the present invention, does not represent and admits that foregoing is prior art.
Summary of the invention
Main purpose of the present invention is that solving cross-server carries out in message push process, and because message can not be shared between push server, the part server caused cannot receive the problem of corresponding PUSH message.
For achieving the above object, a kind of cross-server message push system provided by the invention, described cross-server message push system comprises:
Producer's module, for PUSH message to be pushed is added into producer's queue, and is distributed to corresponding consumer queue by described producer's queue by described PUSH message;
Consumer module, for informing to corresponding push server by the described PUSH message in described consumer queue;
Pushing module, for described PUSH message being sent to destination client by described push server, carries out message push for described destination client.
Preferably, described producer's module comprises receiving element, determining unit and Dispatching Unit;
Described receiving element, for receiving the PUSH message that service end sends, and is added into described producer's queue by described PUSH message;
Described determining unit, for determining corresponding consumer queue according to described PUSH message;
Described Dispatching Unit, for being distributed to determined consumer queue by the described PUSH message in described producer's queue.
Preferably, described pushing module, also for being inquired about the client in the IP address field residing for this push server by described push server, and determines corresponding destination client according to described PUSH message;
Described pushing module, also for described PUSH message being sent to determined destination client by two-way long connection the between described push server with determined destination client.
Preferably, described cross-server message push system also comprises link block;
Described link block, for when receiving the connection request of destination client, the two-way length set up between described destination client and corresponding push server connects.
Preferably, described consumer module, also for the described PUSH message in described consumer queue being informed to the push server that described consumer queue is bound.
In addition, for achieving the above object, the present invention also provides a kind of cross-server information push method, and described cross-server information push method comprises the following steps:
PUSH message to be pushed is added into producer's queue, and by described producer's queue, described PUSH message is distributed to corresponding consumer queue;
Described PUSH message in described consumer queue is informed to corresponding push server;
By described push server, described PUSH message is sent to destination client, carries out message push for described destination client.
Preferably, described PUSH message to be pushed is added into producer's queue, and is comprised by the step that described PUSH message to be distributed to corresponding consumer queue by described producer's queue:
Receive the PUSH message that service end sends, and described PUSH message is added into described producer's queue;
Corresponding consumer queue is determined according to described PUSH message;
Described PUSH message in described producer's queue is distributed to determined consumer queue.
Preferably, describedly by described push server, the step that described PUSH message is sent to destination client to be comprised:
Client in the IP address field inquiring about residing for this push server by described push server, and determine corresponding destination client according to described PUSH message;
By two-way long connection the between described push server with determined destination client, described PUSH message is sent to determined destination client.
Preferably, the described PUSH message by the generation of producer's program also comprises before being added into the step of producer's queue:
When receiving the connection request of destination client, the two-way length set up between described destination client and corresponding push server connects.
Preferably, the described step described PUSH message in described consumer queue being informed to corresponding push server comprises:
Described PUSH message in described consumer queue is informed to the push server that described consumer queue is bound.
The present invention, by the consumer queue distribution PUSH message of producer's queue to each push server, makes PUSH message to share, avoids part server when cross-server carries out message push and cannot receive the problem of corresponding PUSH message.Make when server stress increases, can server extending transversely, to alleviate server stress.
Accompanying drawing explanation
Fig. 1 is the hardware configuration signal of the mobile terminal realizing each embodiment of the present invention;
Fig. 2 is the wireless communication system schematic diagram of mobile terminal as shown in Figure 1;
Fig. 3 is the high-level schematic functional block diagram of the first embodiment of cross-server message push system of the present invention;
Fig. 4 is the software architecture schematic diagram of the preferred embodiment of cross-server message push system of the present invention;
Fig. 5 is the hardware configuration schematic diagram of the preferred embodiment of cross-server message push system of the present invention;
Fig. 6 is the high-level schematic functional block diagram of the second embodiment of cross-server message push system of the present invention;
Fig. 7 is the schematic diagram of the preferred embodiment that the present invention is based on Websocket connection cross-server message push system;
Fig. 8 is the schematic flow sheet of the first embodiment of cross-server information push method of the present invention;
Fig. 9 is the schematic flow sheet of the second embodiment of cross-server information push method of the present invention;
Figure 10 is the schematic flow sheet of the 3rd embodiment of cross-server information push method of the present invention.
The realization of the object of the invention, functional characteristics and advantage will in conjunction with the embodiments, are described further with reference to accompanying drawing.
Embodiment
Should be appreciated that specific embodiment described herein only in order to explain the present invention, be not intended to limit the present invention.
The mobile terminal realizing each embodiment of the present invention is described referring now to accompanying drawing.In follow-up description, use the suffix of such as " module ", " parts " or " unit " for representing element only in order to be conducive to explanation of the present invention, itself is specific meaning not.Therefore, " module " and " parts " can mixedly use.
Mobile terminal can be implemented in a variety of manners.Such as, the terminal described in the present invention can comprise the such as mobile terminal of mobile phone, smart phone, notebook computer, digit broadcasting receiver, PDA (personal digital assistant), PAD (panel computer), PMP (portable media player), guider etc. and the fixed terminal of such as digital TV, desktop computer etc.Below, suppose that terminal is mobile terminal.But it will be appreciated by those skilled in the art that except the element except being used in particular for mobile object, structure according to the embodiment of the present invention also can be applied to the terminal of fixed type.
Fig. 1 is the hardware configuration signal of the mobile terminal realizing each embodiment of the present invention.
Mobile terminal 100 can comprise wireless communication unit 110, A/V (audio/video) input unit 120, user input unit 130, sensing cell 140, output unit 150, memory 160, interface unit 170, controller 180 and power subsystem 190 etc.Fig. 1 shows the mobile terminal with various assembly, it should be understood that, does not require to implement all assemblies illustrated.Can alternatively implement more or less assembly.Will be discussed in more detail below the element of mobile terminal.
Wireless communication unit 110 generally includes one or more assembly, and it allows the radio communication between mobile terminal 100 and wireless communication system or network.Such as, wireless communication unit can comprise at least one in broadcast reception module 111, mobile communication module 112, wireless Internet module 113, short range communication module 114 and positional information module 115.
Broadcast reception module 111 via broadcast channel from external broadcasting management server receiving broadcast signal and/or broadcast related information.Broadcast channel can comprise satellite channel and/or terrestrial channel.Broadcast management server can be generate and send the server of broadcast singal and/or broadcast related information or the broadcast singal generated before receiving and/or broadcast related information and send it to the server of terminal.Broadcast singal can comprise TV broadcast singal, radio signals, data broadcasting signal etc.And broadcast singal may further include the broadcast singal combined with TV or radio signals.Broadcast related information also can provide via mobile communications network, and in this case, broadcast related information can be received by mobile communication module 112.Broadcast singal can exist in a variety of manners, such as, it can exist with the form of the electronic service guidebooks (ESG) of the electronic program guides of DMB (DMB) (EPG), digital video broadcast-handheld (DVB-H) etc.Broadcast reception module 111 can by using the broadcast of various types of broadcast system Received signal strength.Especially, broadcast reception module 111 can by using such as multimedia broadcasting-ground (DMB-T), DMB-satellite (DMB-S), digital video broadcasting-hand-held (DVB-H), forward link media (MediaFLO ) the digit broadcasting system receiving digital broadcast of Radio Data System, received terrestrial digital broadcasting integrated service (ISDB-T) etc.Broadcast reception module 111 can be constructed to be applicable to providing the various broadcast system of broadcast singal and above-mentioned digit broadcasting system.The broadcast singal received via broadcast reception module 111 and/or broadcast related information can be stored in memory 160 (or storage medium of other type).
Radio signal is sent at least one in base station (such as, access point, Node B etc.), exterior terminal and server and/or receives radio signals from it by mobile communication module 112.Various types of data that such radio signal can comprise voice call signal, video calling signal or send according to text and/or Multimedia Message and/or receive.
Wireless Internet module 113 supports the Wi-Fi (Wireless Internet Access) of mobile terminal.This module can be inner or be externally couple to terminal.Wi-Fi (Wireless Internet Access) technology involved by this module can comprise WLAN (WLAN) (Wi-Fi), Wibro (WiMAX), Wimax (worldwide interoperability for microwave access), HSDPA (high-speed downlink packet access) etc.
Short range communication module 114 is the modules for supporting junction service.Some examples of short-range communication technology comprise bluetooth tM, radio-frequency (RF) identification (RFID), Infrared Data Association (IrDA), ultra broadband (UWB), purple honeybee tMetc..
Positional information module 115 is the modules of positional information for checking or obtain mobile terminal.The typical case of positional information module is GPS (global positioning system).According to current technology, GPS module 115 calculates from the range information of three or more satellite and correct time information and for the Information application triangulation calculated, thus calculates three-dimensional current location information according to longitude, latitude and pin-point accuracy.Current, the method for calculating location and temporal information uses three satellites and by the error of the position that uses an other satellite correction calculation to go out and temporal information.In addition, GPS module 115 can carry out computational speed information by Continuous plus current location information in real time.
A/V input unit 120 is for audio reception or vision signal.A/V input unit 120 can comprise camera 121 and microphone 122, and the view data of camera 121 to the static images obtained by image capture apparatus in Video Capture pattern or image capture mode or video processes.Picture frame after process may be displayed on display unit 151.Picture frame after camera 121 processes can be stored in memory 160 (or other storage medium) or via wireless communication unit 110 and send, and can provide two or more cameras 121 according to the structure of mobile terminal.Such acoustic processing can via microphones sound (voice data) in telephone calling model, logging mode, speech recognition mode etc. operational mode, and can be voice data by microphone 122.Audio frequency (voice) data after process can be converted to the formatted output that can be sent to mobile communication base station via mobile communication module 112 when telephone calling model.Microphone 122 can be implemented various types of noise and eliminate (or suppress) algorithm and receiving and sending to eliminate (or suppression) noise or interference that produce in the process of audio signal.
User input unit 130 can generate key input data to control the various operations of mobile terminal according to the order of user's input.User input unit 130 allows user to input various types of information, and keyboard, the young sheet of pot, touch pad (such as, detecting the touch-sensitive assembly of the change of the resistance, pressure, electric capacity etc. that cause owing to being touched), roller, rocking bar etc. can be comprised.Especially, when touch pad is superimposed upon on display unit 151 as a layer, touch-screen can be formed.
Sensing cell 140 detects the current state of mobile terminal 100, (such as, mobile terminal 100 open or close state), the position of mobile terminal 100, user for mobile terminal 100 contact (namely, touch input) presence or absence, the orientation of mobile terminal 100, the acceleration or deceleration of mobile terminal 100 move and direction etc., and generate order or the signal of the operation for controlling mobile terminal 100.Such as, when mobile terminal 100 is embodied as sliding-type mobile phone, sensing cell 140 can sense this sliding-type phone and open or close.In addition, whether whether sensing cell 140 can detect power subsystem 190 provides electric power or interface unit 170 to couple with external device (ED).Sensing cell 140 can comprise proximity transducer 141 and will be described this in conjunction with touch-screen below.
Interface unit 170 is used as at least one external device (ED) and is connected the interface that can pass through with mobile terminal 100.Such as, external device (ED) can comprise wired or wireless head-band earphone port, external power source (or battery charger) port, wired or wireless FPDP, memory card port, for connecting the port, audio frequency I/O (I/O) port, video i/o port, ear port etc. of the device with identification module.Identification module can be that storage uses the various information of mobile terminal 100 for authentication of users and can comprise subscriber identification module (UIM), client identification module (SIM), Universal Subscriber identification module (USIM) etc.In addition, the device (hereinafter referred to " recognition device ") with identification module can take the form of smart card, and therefore, recognition device can be connected with mobile terminal 100 via port or other jockey.Interface unit 170 may be used for receive from external device (ED) input (such as, data message, electric power etc.) and the input received be transferred to the one or more element in mobile terminal 100 or may be used for transmitting data between mobile terminal and external device (ED).
In addition, when mobile terminal 100 is connected with external base, interface unit 170 can be used as to allow by it electric power to be provided to the path of mobile terminal 100 from base or can be used as the path that allows to be transferred to mobile terminal by it from the various command signals of base input.The various command signal inputted from base or electric power can be used as and identify whether mobile terminal is arranged on the signal base exactly.Output unit 150 is constructed to provide output signal (such as, audio signal, vision signal, alarm signal, vibration signal etc.) with vision, audio frequency and/or tactile manner.Output unit 150 can comprise display unit 151, dio Output Modules 152, alarm unit 153 etc.
Display unit 151 may be displayed on the information of process in mobile terminal 100.Such as, when mobile terminal 100 is in telephone calling model, display unit 151 can show with call or other communicate (such as, text messaging, multimedia file are downloaded etc.) be correlated with user interface (UI) or graphic user interface (GUI).When mobile terminal 100 is in video calling pattern or image capture mode, display unit 151 can the image of display capture and/or the image of reception, UI or GUI that video or image and correlation function are shown etc.
Meanwhile, when display unit 151 and touch pad as a layer superposed on one another to form touch-screen time, display unit 151 can be used as input unit and output device.Display unit 151 can comprise at least one in liquid crystal display (LCD), thin-film transistor LCD (TFT-LCD), Organic Light Emitting Diode (OLED) display, flexible display, three-dimensional (3D) display etc.Some in these displays can be constructed to transparence and watch from outside to allow user, and this can be called transparent display, and typical transparent display can be such as TOLED (transparent organic light emitting diode) display etc.According to the specific execution mode wanted, mobile terminal 100 can comprise two or more display units (or other display unit), such as, mobile terminal can comprise outernal display unit (not shown) and inner display unit (not shown).Touch-screen can be used for detecting touch input pressure and touch input position and touch and inputs area.
When dio Output Modules 152 can be under the isotypes such as call signal receiving mode, call mode, logging mode, speech recognition mode, broadcast reception mode at mobile terminal, voice data convert audio signals that is that wireless communication unit 110 is received or that store in memory 160 and exporting as sound.And dio Output Modules 152 can provide the audio frequency relevant to the specific function that mobile terminal 100 performs to export (such as, call signal receives sound, message sink sound etc.).Dio Output Modules 152 can comprise loud speaker, buzzer etc.
Alarm unit 153 can provide and export that event informed to mobile terminal 100.Typical event can comprise calling reception, message sink, key signals input, touch input etc.Except audio or video exports, alarm unit 153 can provide in a different manner and export with the generation of notification event.Such as, alarm unit 153 can provide output with the form of vibration, when receive calling, message or some other enter communication (incomingcommunication) time, alarm unit 153 can provide sense of touch to export (that is, vibrating) to notify to user.By providing such sense of touch to export, even if when the mobile phone of user is in the pocket of user, user also can identify the generation of various event.Alarm unit 153 also can provide the output of the generation of notification event via display unit 151 or dio Output Modules 152.
Memory 160 software program that can store process and the control operation performed by controller 180 etc., or temporarily can store oneself through exporting the data (such as, telephone directory, message, still image, video etc.) that maybe will export.And, memory 160 can store about when touch be applied to touch-screen time the vibration of various modes that exports and the data of audio signal.
Memory 160 can comprise the storage medium of at least one type, described storage medium comprises flash memory, hard disk, multimedia card, card-type memory (such as, SD or DX memory etc.), random access storage device (RAM), static random-access memory (SRAM), read-only memory (ROM), Electrically Erasable Read Only Memory (EEPROM), programmable read only memory (PROM), magnetic storage, disk, CD etc.And mobile terminal 100 can be connected the memory function of execute store 160 network storage device with by network cooperates.
Controller 180 controls the overall operation of mobile terminal usually.Such as, controller 180 performs the control relevant to voice call, data communication, video calling etc. and process.In addition, controller 180 can comprise the multi-media module 181 for reproducing (or playback) multi-medium data, and multi-media module 181 can be configured in controller 180, or can be configured to be separated with controller 180.Controller 180 can pattern recognition process, is identified as character or image so that input is drawn in the handwriting input performed on the touchscreen or picture.
Power subsystem 190 receives external power or internal power and provides each element of operation and the suitable electric power needed for assembly under the control of controller 180.
Various execution mode described herein can to use such as computer software, the computer-readable medium of hardware or its any combination implements.For hardware implementation, execution mode described herein can by using application-specific IC (ASIC), digital signal processor (DSP), digital signal processing device (DSPD), programmable logic device (PLD), field programmable gate array (FPGA), processor, controller, microcontroller, microprocessor, being designed at least one performed in the electronic unit of function described herein and implementing, in some cases, such execution mode can be implemented in controller 180.For implement software, the execution mode of such as process or function can be implemented with allowing the independent software module performing at least one function or operation.Software code can be implemented by the software application (or program) write with any suitable programming language, and software code can be stored in memory 160 and to be performed by controller 180.
So far, oneself is through the mobile terminal according to its functional description.Below, for the sake of brevity, by the slide type mobile terminal that describes in various types of mobile terminals of such as folded form, board-type, oscillating-type, slide type mobile terminal etc. exemplarily.Therefore, the present invention can be applied to the mobile terminal of any type, and is not limited to slide type mobile terminal.
Mobile terminal 100 as shown in Figure 1 can be constructed to utilize and send the such as wired and wireless communication system of data via frame or grouping and satellite-based communication system operates.
Describe wherein according to the communication system that mobile terminal of the present invention can operate referring now to Fig. 2.
Such communication system can use different air interfaces and/or physical layer.Such as, the air interface used by communication system comprises such as frequency division multiple access (FDMA), time division multiple access (TDMA), code division multiple access (CDMA) and universal mobile telecommunications system (UMTS) (especially, Long Term Evolution (LTE)), global system for mobile communications (GSM) etc.As non-limiting example, description below relates to cdma communication system, but such instruction is equally applicable to the system of other type.
With reference to figure 2, cdma wireless communication system can comprise multiple mobile terminal 100, multiple base station (BS) 270, base station controller (BSC) 275 and mobile switching centre (MSC) 280MSC280 and be constructed to form interface with Public Switched Telephony Network (PSTN) 290.MSC280 is also constructed to form interface with the BSC275 that can be couple to base station 270 via back haul link.Back haul link can construct according to any one in some interfaces that oneself knows, described interface comprises such as E1/T1, ATM, IP, PPP, frame relay, HDSL, ADSL or xDSL.Will be appreciated that system as shown in Figure 2 can comprise multiple BSC275.
Each BS270 can serve one or more subregion (or region), by multidirectional antenna or point to specific direction each subregion of antenna cover radially away from BS270.Or each subregion can by two or more antenna covers for diversity reception.Each BS270 can be constructed to support multiple parallel compensate, and each parallel compensate has specific frequency spectrum (such as, 1.25MHz, 5MHz etc.).
Subregion can be called as CDMA Channel with intersecting of parallel compensate.BS270 also can be called as base station transceiver subsystem (BTS) or other equivalent terms.Under these circumstances, term " base station " may be used for broadly representing single BSC275 and at least one BS270.Base station also can be called as " cellular station ".Or each subregion of particular B S270 can be called as multiple cellular station.
As shown in Figure 2, broadcast singal is sent to the mobile terminal 100 at operate within systems by broadcsting transmitter (BT) 295.Broadcast reception module 111 as shown in Figure 1 is arranged on mobile terminal 100 and sentences the broadcast singal receiving and sent by BT295.In fig. 2, several global positioning system (GPS) satellite 300 is shown.Satellite 300 helps at least one in the multiple mobile terminal 100 in location.
In fig. 2, depict multiple satellite 300, but be understandable that, the satellite of any number can be utilized to obtain useful locating information.GPS module 115 as shown in Figure 1 is constructed to coordinate to obtain the locating information wanted with satellite 300 usually.Substitute GPS tracking technique or outside GPS tracking technique, can use can other technology of position of tracking mobile terminal.In addition, at least one gps satellite 300 optionally or extraly can process satellite dmb transmission.
As a typical operation of wireless communication system, BS270 receives the reverse link signal from various mobile terminal 100.Mobile terminal 100 participates in call usually, information receiving and transmitting communicates with other type.Each reverse link signal that certain base station 270 receives is processed by particular B S270.The data obtained are forwarded to relevant BSC275.BSC provides call Resourse Distribute and comprises the mobile management function of coordination of the soft switching process between BS270.The data received also are routed to MSC280 by BSC275, and it is provided for the extra route service forming interface with PSTN290.Similarly, PSTN290 and MSC280 forms interface, and MSC and BSC275 forms interface, and BSC275 correspondingly control BS270 so that forward link signals is sent to mobile terminal 100.
Based on above-mentioned mobile terminal hardware configuration and communication system, propose each embodiment of cross-server message push system of the present invention, described cross-server message push system is used for the above-mentioned mobile terminal pushed to by PUSH message, to realize the propelling movement of message.
With reference to the high-level schematic functional block diagram that Fig. 3, Fig. 3 are the first embodiment of cross-server message push system of the present invention.
In the present embodiment, described cross-server message push system comprises producer's module 10, consumer module 20 and pushing module 30.
Described producer's module 10, for PUSH message to be pushed is added into producer's queue, and is distributed to corresponding consumer queue by described producer's queue by described PUSH message;
By described producer's module 10, PUSH message to be pushed can be added into producer's queue, and described PUSH message is distributed to corresponding consumer queue by described producer's queue, described PUSH message informed to by each consumer queue the push server that each consumer queue binds.
Described PUSH message can be that the producer's program in described cross-server message push system produces, to be realized generation and the propelling movement of PUSH message by described cross-server message push system.Described producer's program can be one, also can be multiple, when described producer's program is multiple, can store list of application, to preserve application message in described cross-server message push system.Described list of application can be kept in the database of described cross-server message push system, and described application message can comprise the key of described application bag name and checking.Or, producer's program of described PUSH message also can be arranged on service end, to produce PUSH message by service end and to be realized the propelling movement of message by described cross-server message push system, concrete, with reference to the software architecture schematic diagram that Fig. 4, Fig. 4 are the preferred embodiment of cross-server message push system of the present invention.
Described producer's queue can corresponding multiple consumer queue, and each consumer queue binds a push server.Described producer's queue can be arranged on provides in the service end main frame of described PUSH message, described producer's queue is arranged in the push server main frame with its binding; Or, also can described producer's queue and described consumer queue be arranged in independent message queue main frame, described message queue main frame is connected with each push server main frame, concrete, with reference to the hardware configuration schematic diagram that Fig. 5, Fig. 5 are the preferred embodiment of cross-server message push system of the present invention.
Described producer's queue and described consumer queue can be RabbitMQ (message system developed on AMQP basis) message queues.
Described consumer module 20, for informing to corresponding push server by the described PUSH message in described consumer queue;
Described consumer module can comprise multiple consumer queue.Described PUSH message in described consumer queue is informed to push server corresponding to described consumer queue by described cross-server message push system, for described push server, described PUSH message is sent to destination client.Described push server is for operating on push server main frame for providing the computer software of message push service.Described cross-server message push system can comprise multiple consumer queue and multiple push server, and each consumer queue is bound with corresponding push server.Such as: can when each push server opens Push Service, open corresponding consumer's message queue simultaneously, corresponding 2 consumer queues of each push server, one of them accepts PUSH message as mark name as point-to-point using server, another queue is the queue of a binding specific trigger, for broadcasting the transmission with the PUSH message of one-to-many.
Described pushing module 30, for described PUSH message being sent to destination client by described push server, carries out message push for described destination client.
Described pushing module can comprise multiple push server.PUSH message is sent to destination client corresponding to described PUSH message by each push server by described cross-server message push system, carries out message push for described destination client.Described destination client is the recipient of described PUSH message.Point-to-point message push can be realized by the recipient's mark in described PUSH message; Or one-to-many or broadcast propelling movement also can be realized by the label in described PUSH message.
Such as: described cross-server message push system can according to the recipient's identified query user mapping table in described PUSH message, determine that described recipient identifies IP address corresponding to corresponding destination client according to described user's mapping table, carry out point-to-point message push according to described IP address; Or described cross-server message push system also according to the tag queries label list in described PUSH message, can determine according to described label list the destination client that described label is corresponding, and described PUSH message is pushed to corresponding destination client.
Further, described cross-server message push system can also comprise database, described database is for preserving the data such as application message, user profile, such as: described database can comprise application table, user's mapping table and label list, described application table for preserving the information of application, as the key of bag name and checking; Described user's mapping table, for preserving the user profile that all connections come up, described user profile comprises whether online and residing server 2 fields; Described label list, for preserving user ID corresponding to each label, to realize the transmission of one-to-many.
The present embodiment, by the consumer queue distribution PUSH message of producer's queue to each push server, makes PUSH message to share, avoids part server when cross-server carries out message push and cannot receive the problem of corresponding PUSH message.Make when server stress increases, can server extending transversely, to alleviate server stress.
With reference to the high-level schematic functional block diagram that Fig. 6, Fig. 6 are the second embodiment of cross-server message push system of the present invention.Based on the first embodiment of above-mentioned cross-server message push system, described producer's module comprises receiving element 11, determining unit 12 and Dispatching Unit 13;
Described receiving element 11, for receiving the PUSH message that service end sends, and is added into described producer's queue by described PUSH message;
Described determining unit 12, for determining corresponding consumer queue according to described PUSH message;
Described Dispatching Unit 13, for being distributed to determined consumer queue by the described PUSH message in described producer's queue.
Described cross-server message push system receives the PUSH message that service end sends, and described PUSH message is added into described producer's queue; Described cross-server message push system determines according to described PUSH message the consumer queue that described PUSH message is corresponding; And the described PUSH message in described producer's queue is distributed to determined consumer queue.Such as: when point-to-point message push, described cross-server message push system can according to the user ID in described PUSH message, search the IP address field that described user ID is corresponding in a database, determine according to described IP address field the consumer queue that described PUSH message is corresponding; When one-to-many message push, described cross-server message push system can according to the label in described PUSH message, search the IP address field of destination client corresponding to described label and correspondence in a database, determine according to described IP address field the consumer queue that described PUSH message is corresponding.
The present embodiment, by the consumer queue distribution PUSH message of producer's queue to each push server, makes PUSH message to share, avoids part server when cross-server carries out message push and cannot receive the problem of corresponding PUSH message.Make when server stress increases, can server extending transversely, to alleviate server stress.
Further, based on the first embodiment of above-mentioned cross-server message push system, described pushing module 30, also for being inquired about the client in the IP address field residing for this push server by described push server, and determines corresponding destination client according to described PUSH message;
Described pushing module 30, also for described PUSH message being sent to determined destination client by two-way long connection the between described push server with determined destination client.
Described cross-server message push system comprises push server, client in the IP address field inquiring about residing for this push server by described push server, and determine corresponding destination client according to described PUSH message, by the client in the IP address field at push server inquiry book server place, share the pressure of all clients of inquiry equally each push server, achieve the load balancing of each push server; By two-way long connection the between described push server with determined destination client, described PUSH message is sent to determined destination client, achieves server initiatively to client push message.
Further, described cross-server message push system also comprises link block; Described link block, for when receiving the connection request of destination client, the two-way length set up between described destination client and corresponding push server connects.
It is the schematic diagram of the preferred embodiment that the present invention is based on Websocket connection cross-server message push system with reference to Fig. 7, Fig. 7.Described two-way long connection can be that Websocket (a kind of HTML5 agreement achieves browser and server full-duplex communication) is connected.Described Websocket connection only needs once to shake hands and can ensure that the long of both sides connects, and all needs three-way handshake, could send message without the need to each as HTTP.Decrease server request time and request number of times, greatly reduce the pressure of server.
Further, by data query, described cross-server message push system can also determine that whether corresponding destination client is online, if described destination client is online, then described PUSH message is sent to described destination client; If described destination client is not online, then described PUSH message is preserved as deferred information, when detecting that described destination client is online, more described deferred information being sent to described destination client.
The present embodiment is by the client in the IP address field at push server inquiry book server place, share the pressure of all clients of inquiry equally each push server, achieve the load balancing of each push server, and by two-way long connection the between described push server with determined destination client, described PUSH message is sent to determined destination client, achieves server initiatively to client push message.
The present invention further provides a kind of cross-server information push method.
With reference to the schematic flow sheet that Fig. 8, Fig. 8 are the first embodiment of cross-server information push method of the present invention.
In the present embodiment, described cross-server information push method comprises the following steps:
Step S10, is added into producer's queue by PUSH message to be pushed, and by described producer's queue, described PUSH message is distributed to corresponding consumer queue;
By described cross-server message push system, PUSH message to be pushed can be added into producer's queue, and described PUSH message is distributed to corresponding consumer queue by described producer's queue, described PUSH message informed to by each consumer queue the push server that each consumer queue binds.
Described PUSH message can be that the producer's program in described cross-server message push system produces, to be realized generation and the propelling movement of PUSH message by described cross-server message push system.Described producer's program can be one, also can be multiple, when described producer's program is multiple, can store list of application, to preserve application message in described cross-server message push system.Described list of application can be kept in the database of described cross-server message push system, and described application message can comprise the key of described application bag name and checking.Or, producer's program of described PUSH message also can be arranged on service end, to produce PUSH message by service end and to be realized the propelling movement of message by described cross-server message push system, concrete, with reference to the software architecture schematic diagram that Fig. 4, Fig. 4 are the preferred embodiment of cross-server message push system of the present invention.
Described producer's queue can corresponding multiple consumer queue, and each consumer queue binds a push server.Described producer's queue can be arranged on provides in the service end main frame of described PUSH message, described producer's queue is arranged in the push server main frame with its binding; Or, also can described producer's queue and described consumer queue be arranged in independent message queue main frame, described message queue main frame is connected with each push server main frame, concrete, with reference to the hardware configuration schematic diagram that Fig. 5, Fig. 5 are the preferred embodiment of cross-server message push system of the present invention.
Described producer's queue and described consumer queue can be RabbitMQ (message system developed on AMQP basis) message queues.
Step S20, informs to corresponding push server by the described PUSH message in described consumer queue;
Described PUSH message in described consumer queue is informed to push server corresponding to described consumer queue by described cross-server message push system, for described push server, described PUSH message is sent to destination client.Described push server can be operate on push server main frame for providing the computer software of message push service.Described cross-server message push system can comprise multiple consumer queue and multiple push server, and each consumer queue is bound with corresponding push server.Such as: can when each push server opens Push Service, open corresponding consumer's message queue simultaneously, corresponding 2 consumer queues of each push server, one of them accepts PUSH message as mark name as point-to-point using server, another queue is the queue of a binding specific trigger, for broadcasting the transmission with the PUSH message of one-to-many.
Step S30, is sent to destination client by described push server by described PUSH message, carries out message push for described destination client.
Described pushing module can comprise multiple push server.PUSH message is sent to destination client corresponding to described PUSH message by each push server by described cross-server message push system, carries out message push for described destination client.Described destination client is the recipient of described PUSH message.Point-to-point message push can be realized by the recipient's mark in described PUSH message; Or one-to-many or broadcast propelling movement also can be realized by the label in described PUSH message.
Such as: described cross-server message push system can according to the recipient's identified query user mapping table in described PUSH message, determine that described recipient identifies IP address corresponding to corresponding destination client according to described user's mapping table, carry out point-to-point message push according to described IP address; Or described cross-server message push system also according to the tag queries label list in described PUSH message, can determine according to described label list the destination client that described label is corresponding, and described PUSH message is pushed to corresponding destination client.
Further, described cross-server message push system can also comprise database, described database is for preserving the data such as application message, user profile, such as: described database can comprise application table, user's mapping table and label list, described application table for preserving the information of application, as the key of bag name and checking; Described user's mapping table, for preserving the user profile that all connections come up, described user profile comprises whether online and residing server 2 fields; Described label list, for preserving user ID corresponding to each label, to realize the transmission of one-to-many.
The present embodiment, by the consumer queue distribution PUSH message of producer's queue to each push server, makes PUSH message to share, avoids part server when cross-server carries out message push and cannot receive the problem of corresponding PUSH message.Make when server stress increases, can server extending transversely, to alleviate server stress.
With reference to the schematic flow sheet that Fig. 9, Fig. 9 are the second embodiment of cross-server information push method of the present invention.Based on the first embodiment of above-mentioned cross-server information push method, described step S10 comprises:
Step S11, receives the PUSH message that service end sends, and described PUSH message is added into described producer's queue;
Step S12, determines corresponding consumer queue according to described PUSH message;
Step S13, is distributed to determined consumer queue by the described PUSH message in described producer's queue.
Described cross-server message push system receives the PUSH message that service end sends, and described PUSH message is added into described producer's queue; Described cross-server message push system determines according to described PUSH message the consumer queue that described PUSH message is corresponding; And the described PUSH message in described producer's queue is distributed to determined consumer queue.Such as: when point-to-point message push, described cross-server message push system can according to the user ID in described PUSH message, search the IP address field that described user ID is corresponding in a database, determine according to described IP address field the consumer queue that described PUSH message is corresponding; When one-to-many message push, described cross-server message push system can according to the label in described PUSH message, search the IP address field of destination client corresponding to described label and correspondence in a database, determine according to described IP address field the consumer queue that described PUSH message is corresponding.
The present embodiment, by the consumer queue distribution PUSH message of producer's queue to each push server, makes PUSH message to share, avoids part server when cross-server carries out message push and cannot receive the problem of corresponding PUSH message.Make when server stress increases, can server extending transversely, to alleviate server stress.
With reference to the schematic flow sheet that Figure 10, Figure 10 are the 3rd embodiment of cross-server information push method of the present invention.Based on the first embodiment of above-mentioned cross-server information push method, described step S30 comprises:
Step S31, the client in the IP address field inquiring about residing for this push server by described push server, and determine corresponding destination client according to described PUSH message;
Step S32, is sent to determined destination client by two-way long connection the between described push server with determined destination client by described PUSH message.
Described cross-server message push system comprises push server, client in the IP address field inquiring about residing for this push server by described push server, and determine corresponding destination client according to described PUSH message, by the client in the IP address field at push server inquiry book server place, share the pressure of all clients of inquiry equally each push server, achieve the load balancing of each push server; By two-way long connection the between described push server with determined destination client, described PUSH message is sent to determined destination client, achieves server initiatively to client push message.
Further, before the described PUSH message by the generation of producer's program is added into the step of producer's queue, described cross-server message push system can also when receiving the connection request of destination client, and the two-way length set up between described destination client and corresponding push server connects.
It is the schematic diagram of the preferred embodiment that the present invention is based on Websocket connection cross-server message push system with reference to Fig. 7, Fig. 7.Described two-way long connection can be that Websocket (a kind of HTML5 agreement achieves browser and server full-duplex communication) is connected.Described Websocket connection only needs once to shake hands and can ensure that the long of both sides connects, and all needs three-way handshake, could send message without the need to each as HTTP.Decrease server request time and request number of times, greatly reduce the pressure of server.
Further, by data query, described cross-server message push system can also determine that whether corresponding destination client is online, if described destination client is online, then described PUSH message is sent to described destination client; If described destination client is not online, then described PUSH message is preserved as deferred information, when detecting that described destination client is online, more described deferred information being sent to described destination client.
The present embodiment is by the client in the IP address field at push server inquiry book server place, share the pressure of all clients of inquiry equally each push server, achieve the load balancing of each push server, and by two-way long connection the between described push server with determined destination client, described PUSH message is sent to determined destination client, achieves server initiatively to client push message.
It should be noted that, in this article, term " comprises ", " comprising " or its any other variant are intended to contain comprising of nonexcludability, thus make to comprise the process of a series of key element, method, article or device and not only comprise those key elements, but also comprise other key elements clearly do not listed, or also comprise by the intrinsic key element of this process, method, article or device.When not more restrictions, the key element limited by statement " comprising ... ", and be not precluded within process, method, article or the device comprising this key element and also there is other identical element.
The invention described above embodiment sequence number, just to describing, does not represent the quality of embodiment.
Through the above description of the embodiments, those skilled in the art can be well understood to the mode that above-described embodiment method can add required general hardware platform by software and realize, hardware can certainly be passed through, but in a lot of situation, the former is better execution mode.Based on such understanding, technical scheme of the present invention can embody with the form of software product the part that prior art contributes in essence in other words, this computer software product is stored in a storage medium (as ROM/RAM, magnetic disc, CD), comprising some instructions in order to make a station terminal equipment (can be mobile phone, computer, server, air conditioner, or the network equipment etc.) perform method described in each embodiment of the present invention.
These are only the preferred embodiments of the present invention; not thereby the scope of the claims of the present invention is limited; every utilize specification of the present invention and accompanying drawing content to do equivalent structure or equivalent flow process conversion; or be directly or indirectly used in other relevant technical fields, be all in like manner included in scope of patent protection of the present invention.

Claims (10)

1. a cross-server message push system, is characterized in that, described cross-server message push system comprises:
Producer's module, for PUSH message to be pushed is added into producer's queue, and is distributed to corresponding consumer queue by described producer's queue by described PUSH message;
Consumer module, for informing to corresponding push server by the described PUSH message in described consumer queue;
Pushing module, for described PUSH message being sent to destination client by described push server, carries out message push for described destination client.
2. cross-server message push system as claimed in claim 1, it is characterized in that, described producer's module comprises receiving element, determining unit and Dispatching Unit;
Described receiving element, for receiving the PUSH message that service end sends, and is added into described producer's queue by described PUSH message;
Described determining unit, for determining corresponding consumer queue according to described PUSH message;
Described Dispatching Unit, for being distributed to determined consumer queue by the described PUSH message in described producer's queue.
3. cross-server message push system as claimed in claim 1, it is characterized in that, described pushing module, also for being inquired about the client in the IP address field residing for this push server by described push server, and determines corresponding destination client according to described PUSH message;
Described pushing module, also for described PUSH message being sent to determined destination client by two-way long connection the between described push server with determined destination client.
4. cross-server message push system as claimed in claim 3, it is characterized in that, described cross-server message push system also comprises link block;
Described link block, for when receiving the connection request of destination client, the two-way length set up between described destination client and corresponding push server connects.
5. the cross-server message push system as described in any one of Claims 1-4, is characterized in that, described consumer module, also for the described PUSH message in described consumer queue being informed to the push server that described consumer queue is bound.
6. a cross-server information push method, is characterized in that, described cross-server information push method comprises the following steps:
PUSH message to be pushed is added into producer's queue, and by described producer's queue, described PUSH message is distributed to corresponding consumer queue;
Described PUSH message in described consumer queue is informed to corresponding push server;
By described push server, described PUSH message is sent to destination client, carries out message push for described destination client.
7. cross-server information push method as claimed in claim 6, is characterized in that, described PUSH message to be pushed is added into producer's queue, and is comprised by the step that described PUSH message to be distributed to corresponding consumer queue by described producer's queue:
Receive the PUSH message that service end sends, and described PUSH message is added into described producer's queue;
Corresponding consumer queue is determined according to described PUSH message;
Described PUSH message in described producer's queue is distributed to determined consumer queue.
8. cross-server information push method as claimed in claim 6, is characterized in that, describedly the step that described PUSH message is sent to destination client is comprised by described push server:
Client in the IP address field inquiring about residing for this push server by described push server, and determine corresponding destination client according to described PUSH message;
By two-way long connection the between described push server with determined destination client, described PUSH message is sent to determined destination client.
9. cross-server information push method as claimed in claim 8, is characterized in that, the described PUSH message by the generation of producer's program also comprises before being added into the step of producer's queue:
When receiving the connection request of destination client, the two-way length set up between described destination client and corresponding push server connects.
10. the cross-server information push method as described in any one of claim 6 to 9, is characterized in that, the described step described PUSH message in described consumer queue being informed to corresponding push server comprises:
Described PUSH message in described consumer queue is informed to the push server that described consumer queue is bound.
CN201510634511.3A 2015-09-29 2015-09-29 Cross-server message push system and method Active CN105282245B (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510634511.3A CN105282245B (en) 2015-09-29 2015-09-29 Cross-server message push system and method

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510634511.3A CN105282245B (en) 2015-09-29 2015-09-29 Cross-server message push system and method

Publications (2)

Publication Number Publication Date
CN105282245A true CN105282245A (en) 2016-01-27
CN105282245B CN105282245B (en) 2019-03-08

Family

ID=55150550

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510634511.3A Active CN105282245B (en) 2015-09-29 2015-09-29 Cross-server message push system and method

Country Status (1)

Country Link
CN (1) CN105282245B (en)

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105939379A (en) * 2016-05-20 2016-09-14 天津海量信息技术股份有限公司 Real-time monitoring and early warning system and real-time monitoring and early warning method based on internet data
CN106549857A (en) * 2016-11-30 2017-03-29 济南中维世纪科技有限公司 A kind of method and system of trans-regional PUSH message
CN106685915A (en) * 2016-10-28 2017-05-17 努比亚技术有限公司 Method of safety communication of mobile terminal and server, server and mobile terminal
CN106911486A (en) * 2017-04-27 2017-06-30 努比亚技术有限公司 A kind of message push processing method, apparatus and system
CN107911462A (en) * 2017-11-27 2018-04-13 南京信通科技有限责任公司 High-volume method of data synchronization based on ActiveMQ
CN109361770A (en) * 2018-12-11 2019-02-19 苏州创旅天下信息技术有限公司 The system and method for bidirectional real-time is realized based on WebSocket and message queue
CN109639795A (en) * 2018-12-11 2019-04-16 广东亿迅科技有限公司 A kind of service management and device based on AcitveMQ message queue
CN110224933A (en) * 2019-06-18 2019-09-10 成都品果科技有限公司 A kind of message distributing system
CN112887397A (en) * 2021-01-22 2021-06-01 山东众阳健康科技集团有限公司 Message pushing method and system based on interface

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103491170A (en) * 2013-09-24 2014-01-01 新浪网技术(中国)有限公司 E-mail arrival message reminding method and system
CN103731476A (en) * 2013-12-10 2014-04-16 乐视网信息技术(北京)股份有限公司 Method and device for improving information push speed
CN104243285A (en) * 2014-09-19 2014-12-24 广州华多网络科技有限公司 Message pushing method and server

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN103491170A (en) * 2013-09-24 2014-01-01 新浪网技术(中国)有限公司 E-mail arrival message reminding method and system
CN103731476A (en) * 2013-12-10 2014-04-16 乐视网信息技术(北京)股份有限公司 Method and device for improving information push speed
CN104243285A (en) * 2014-09-19 2014-12-24 广州华多网络科技有限公司 Message pushing method and server

Cited By (11)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN105939379A (en) * 2016-05-20 2016-09-14 天津海量信息技术股份有限公司 Real-time monitoring and early warning system and real-time monitoring and early warning method based on internet data
CN106685915A (en) * 2016-10-28 2017-05-17 努比亚技术有限公司 Method of safety communication of mobile terminal and server, server and mobile terminal
CN106549857A (en) * 2016-11-30 2017-03-29 济南中维世纪科技有限公司 A kind of method and system of trans-regional PUSH message
CN106911486A (en) * 2017-04-27 2017-06-30 努比亚技术有限公司 A kind of message push processing method, apparatus and system
CN106911486B (en) * 2017-04-27 2019-11-15 努比亚技术有限公司 A kind of message push processing method, apparatus and system
CN107911462A (en) * 2017-11-27 2018-04-13 南京信通科技有限责任公司 High-volume method of data synchronization based on ActiveMQ
CN109361770A (en) * 2018-12-11 2019-02-19 苏州创旅天下信息技术有限公司 The system and method for bidirectional real-time is realized based on WebSocket and message queue
CN109639795A (en) * 2018-12-11 2019-04-16 广东亿迅科技有限公司 A kind of service management and device based on AcitveMQ message queue
CN109639795B (en) * 2018-12-11 2021-12-24 广东亿迅科技有限公司 Service management method and device based on AcitveMQ message queue
CN110224933A (en) * 2019-06-18 2019-09-10 成都品果科技有限公司 A kind of message distributing system
CN112887397A (en) * 2021-01-22 2021-06-01 山东众阳健康科技集团有限公司 Message pushing method and system based on interface

Also Published As

Publication number Publication date
CN105282245B (en) 2019-03-08

Similar Documents

Publication Publication Date Title
CN105282245A (en) Server-crossing message pushing system and method
CN104850259A (en) Combination operation method, combination operation apparatus, touch screen operating method and electronic device
CN105119825A (en) Data transmission device and data transmission method
CN105101052A (en) Method, system and mobile terminal for transferring SIM card
CN104731512A (en) Method, device and terminal for sharing pictures
CN104735255A (en) Split screen display method and system
CN105159700A (en) Application self-start control apparatus and method
CN104883658A (en) Virtual card information processing method and system
CN105227892A (en) Video call system, apparatus and method
CN105187521A (en) Service processing device and method
CN105101294A (en) Data transmission device and method
CN105262819A (en) Mobile terminal and method thereof for achieving push
CN105100673A (en) Voice over long term evolution (VoLTE) based desktop sharing method and device
CN104898940A (en) Picture processing method and device
CN105262821A (en) Interface management apparatus and method
CN104951229A (en) Screen capturing method and device
CN105306457A (en) Data caching device and method
CN104679890A (en) Image pushing method and device
CN105162987A (en) Memo reminding method and terminal device
CN104917873A (en) Method and device for sharing information during call
CN105430042A (en) Method, service terminal, and mobile terminal for realizing data transmission
CN105278995A (en) Management method of application, system, server and mobile terminal
CN105100212A (en) Session message acquisition method and device
CN104731455A (en) Application identification display method and device
CN104657484A (en) Method, device and system for downloading application software

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant