US20090240820A1 - Quality of Service for Network Connected Clients - Google Patents
Quality of Service for Network Connected Clients Download PDFInfo
- Publication number
- US20090240820A1 US20090240820A1 US12/409,844 US40984409A US2009240820A1 US 20090240820 A1 US20090240820 A1 US 20090240820A1 US 40984409 A US40984409 A US 40984409A US 2009240820 A1 US2009240820 A1 US 2009240820A1
- Authority
- US
- United States
- Prior art keywords
- network
- server
- configuration
- client
- parameters
- 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.)
- Abandoned
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/80—Responding to QoS
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/1066—Session management
- H04L65/1101—Session protocols
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L65/00—Network arrangements, protocols or services for supporting real-time applications in data packet communication
- H04L65/60—Network streaming of media packets
- H04L65/75—Media network packet handling
- H04L65/762—Media network packet handling at the source
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/60—Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources
- H04L67/61—Scheduling or organising the servicing of application requests, e.g. requests for application data transmissions using the analysis and optimisation of the required network resources taking into account QoS or priority requirements
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/24—Negotiation of communication capabilities
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L69/00—Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
- H04L69/30—Definitions, standards or architectural aspects of layered protocol stacks
- H04L69/32—Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
- H04L69/322—Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
- H04L69/329—Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]
Definitions
- This invention relates to connection-oriented network connections between network clients and a network server.
- it relates to disconnecting network clients with an incompatible client configuration when a server configuration is changed.
- Network applications employ network protocols for communication between a network client and a network server.
- Network protocols can be classified into two main categories: connectionless protocols; and connection-oriented protocols.
- a connectionless protocol is an asynchronous protocol without a persistent connection between the network client and the network server.
- HTTP hypertext transport protocol
- the web browser client can make requests of the web server, such as a request for a particular web page.
- the web server receives each request as a distinct request which is independent of all other requests, and responds to each request independently.
- a connection exists between the web browser client and the web server for only as long as it takes to send a request and receive a response. Thus, there is no persistent connection between the web browser client and the web server for multiple requests and responses, and HTTP is therefore considered to be a connectionless protocol.
- connection-oriented protocol provides a persistent connection for the transmission of data between a network client and a network server.
- Connection-oriented protocols also usually include facilities for error, sequence and flow control. Error control refers to a combination of error detection, correction and acknowledgement sufficient to compensate for any unreliability inherent to the network. Sequence control ensures that the network client and the network server are able to reconstruct data received over the network in the proper order in which they were intended to be received, and is essential in the transmission of large volumes of data. Flow control ensures that network clients and network servers do not overrun each other with too much data.
- TCP transmission control protocol
- An application of TCP is video streaming over a network where a streaming video client can create a persistent connection with a streaming video server for the receipt of streaming video data using TCP.
- the TCP connection is used by the streaming video server to send large streams of video data for receipt by the streaming video client.
- Other applications of connection-oriented communications include mobile telephone connections to cellular base stations, digital set-top box connections to a digital television service provider and connections between network chat clients such as Lotus Sametime Connect (Lotus is a registered trade mark of International Business Machines Corp.) and AOL Instant Messenger (a registered trade mark of America Online Inc.).
- Connection-oriented protocols offer effective and reliable communication between network clients and network servers, and support applications requiring long lived connections or connections over which large quantities of data can be transferred.
- a technique for creating a connection-oriented connection between a network client and a network server is outlined below.
- a network server will include a server configuration comprising one or more server parameters.
- a network client will include a client configuration comprising one or more client parameters.
- a streaming video server may include a server configuration with a video frame rate parameter corresponding to the frame rate of video data streamed from the server.
- a streaming video client may include a client configuration with a maximum frame rate parameter corresponding to a maximum frame rate of video data the client is able to receive.
- a network client requests a new connection to a network server using the connection-oriented protocol. This can involve an initial message being sent from the network client to the network server with an indication that a new connection is requested.
- the network server responds to the initial message with a connection acceptance message, including details of the network server configuration.
- the network client receives the network server configuration and determines if the client configuration is compatible with the server configuration. For example, the server configuration may include a frame rate which exceeds a maximum frame rate of the client configuration, and the network server configuration is therefore incompatible with the network client configuration. If the client configuration is compatible with the server configuration, a connection is created between the network client and the network server. If the client configuration is not compatible with the server configuration, the network client may abandon the request to create a connection.
- a server configuration can also be changed during a connection-oriented network connection, and such a change can affect connected network clients.
- one or more connected network clients may be incompatible with a new server configuration, such as a new value of a frame rate parameter of a streaming video server.
- the network server When a server configuration is changed, the network server must determine a course of action for connected network clients.
- One technique for changing a server configuration involves disconnecting all connected network clients before the server configuration is changed. Network clients are then able to reconnect and determine if the client configuration is compatible with the new server configuration. This technique has the disadvantage that connected network clients which are compatible with a new server configuration are disconnected unnecessarily, and the quality of service provided by the network client is consequently reduced.
- An alternative technique for changing a server configuration involves only introducing a new server configuration for new connections. Existing connections continue to operate under the original server configuration (i.e. prior to a change to the configuration).
- This alternative technique has the advantage that existing connected network clients are not disconnected.
- this alternative technique has the disadvantage that the server must support both an original server configuration for existing connected network clients, and a new server configuration for new network client connections. This can increase the processing requirements of the network server and reduce the performance of the network server.
- existing connected network clients which support the new server configuration continue to communicate with the server using the original server configuration. This is a particular disadvantage where the new server configuration offers advantages over the original configuration which are to the benefit of existing connected network clients (such as an increase in communications speed).
- the present invention accordingly provides, in a first aspect, a method for network communication controlled by a network server over a network using a connection-oriented protocol with a network client, wherein the network server has a first server configuration and the network client has a client configuration, the method comprising the steps of: detecting the network client configuration; replacing said first server configuration with a second server configuration; responsive to a determination that the client configuration is incompatible with the second server configuration, disconnecting the network client.
- the network client is only disconnected from the network server if the client configuration is incompatible with the second server configuration. If the client configuration is compatible with the second server configuration the network connection between the network client and the network server persists using the second server configuration. In this way the server configuration can be changed (from the first server configuration to the second server configuration) without disconnecting the network client when the client configuration is compatible with the new server configuration, and without the need for the network server to support multiple server configurations.
- the present invention accordingly provides, in a second aspect, a network server for communicating with a network client over a network comprising: a client configuration detector for detecting a configuration of the network client; a server configurator for changing the configuration of the network server; a comparator for determining if the configuration of the network client is compatible with the configuration of the network server; and a server communications component for connecting with the network client using a connection-oriented protocol, wherein the server communications component is operable to disconnect the network client responsive to said comparator.
- the present invention accordingly provides, in a third aspect, a computer program product comprising computer program code stored on a computer readable storage medium which, when executed on a data processing system, instructs the data processing system to carry out the method as described above.
- FIG. 1 is a schematic diagram illustrating a network client connected to a network server using a connection-oriented protocol in the prior art
- FIG. 2 is a schematic diagram illustrating a network client connected to a network server using a connection-oriented protocol in a preferred embodiment of the present invention
- FIG. 3 is a schematic diagram illustrating a client computer system including a streaming video client connected to a server computer system including a streaming video server using the TCP connection-oriented protocol in a preferred embodiment of the present invention
- FIG. 4 is a flowchart illustrating a method of communication between a network client and a network server over a network in a preferred embodiment of the present invention.
- FIG. 1 is a schematic diagram illustrating a network client connected to a network server using a connection-oriented protocol in the prior art.
- Network client 102 is a hardware or software implementation of a client component of a network application.
- the network client 102 is a streaming video network client intended to receive streaming video data.
- the network client 102 can be a mobile telephone or other wireless communications device, a digital set top box, a computer system including a network interface card (NIC) or any other network connected device.
- NIC network interface card
- the network client 102 includes a client communications component 104 .
- the client communications component 104 is a software or hardware component of the network client 102 which provides connection-oriented network connections between the network client 102 and other network devices.
- the client communications component 104 is a TCP software library, or a software library providing a proprietary connection-oriented network protocol.
- Network client 102 further includes a client configuration 106 .
- the client configuration 106 is a set of client parameters specific to a particular network application of the network client 102 .
- the client configuration 106 can include a maximum frame rate parameter corresponding to a maximum frame rate of video data which can be received by the network client 102 .
- the client configuration 106 can include parameters relating to data compression standards, data encryption standards, signal strength requirements, data communications speeds, data communications rates, media encoding standards such as audio or video encoding standards or any other parameter required by the network client 102 .
- the client configuration 106 can include parameters specific to a particular business application, such as financial details (including financial limits), authorisation details (such as access control lists) and business rules.
- the client configuration 106 is stored in a memory of the network client 102 , such as a volatile random access memory, a non-volatile memory or a disk storage device.
- the network client 102 is connected to a network server 108 over a network connection 110 .
- the network server 108 is a hardware or software implementation of a server component of a network application.
- the network server 108 is a streaming video network server for sending streaming video data.
- the network server 108 can be a mobile telephone or other wireless communications access point, a digital set top box service provider, a computer system including a network interface card (NIC) or any other network connected server device.
- the network connection 110 is a connection-oriented network connection between the client communications component 104 of the network client 102 and a server communications component 112 of the network server 108 .
- the network connection 110 is implemented using a connection-oriented network protocol.
- the network connection 110 can be a connection-oriented network connection which operates on a connectionless protocol, with connection-oriented services provided jointly by the client communications component 104 and the server communications component 112 .
- An example of a connection-oriented protocol used by network connection 110 is TCP.
- the server communications component 112 is a software or hardware component of the network server 108 which provides connection-oriented network connections between the network server 108 and other network devices.
- the network server 108 further includes a server configuration 114 .
- the server configuration 114 is a set of server parameters specific to a particular network application of the network server 108 . For example, if the network server 108 is a streaming video network server, the server configuration 114 can include a frame rate parameter corresponding to a frame rate of video data stream distributed by the network server 108 .
- the server configuration 114 can include any of the parameters described above with respect to the client configuration 106 .
- the server configuration 114 is stored in a memory of the network server 108 , such as a volatile random access memory, a non-volatile memory or a magnetic or non-magnetic storage device.
- the network server 108 further includes a server configurator 116 for changing the server configuration 114 .
- the server configurator 116 can be a hardware or software component of the network server 108 , such as a software application providing a user interface for a user to specify a new server configuration 114 .
- the network client 102 creates the network connection 110 to the network server 108 using a connection-oriented network protocol.
- the creation of the network connection 110 can involve the client communications component 104 sending an initialisation message to the server communications component 112 requesting the creation of a new network connection.
- the server communications component 112 provides a response message to the client communications component 104 with details of the server configuration 114 .
- the client communications component 104 receives the details of the server configuration 114 and determines if the client configuration 106 is compatible with the server configuration 114 . If the client configuration 106 is compatible with the server configuration 114 , the network connection 110 is created between the network client 102 and the network server 108 .
- the network client 102 may abandon the request to create the network connection 110 . Subsequently, if the network connection 110 is successfully created, the network client 102 is able to send data to, and receive data from, the network server 108 over the network connection 110 using the connection-oriented protocol. Subsequently, when the server configurator 116 changes the server configuration 114 , the network client 102 is disconnected by the server communications component 112 which closes the network connection 110 . Subsequently, the network client 102 is able to attempt to re-create the network connection 110 .
- FIG. 2 is a schematic diagram illustrating a network client connected to a network server using a connection-oriented protocol in a preferred embodiment of the present invention. Many elements of FIG. 2 are identical to those described with respect to FIG. 1 and these will not be further described here in the description of FIG. 2 .
- the network server 208 of FIG. 2 further includes a client configuration detector 218 which detects the client configuration 206 and generates a copy of the client configuration 220 .
- the client configuration detector 218 is a software module operable to communicate with the server communications component 212 using an application programming interface (API), such as a TCP API.
- API application programming interface
- the client configuration detector 218 can be a component of the server communications component 212 .
- the copy of the client configuration 220 is stored in a memory of the network server 208 , such as a volatile random access memory, a non-volatile memory or a magnetic or non-magnetic storage device.
- the copy of the client configuration 220 can be a complete copy of the client configuration 206 , or alternatively can be a partial copy of only relevant parameters of client configuration 206 .
- the network server 208 is a streaming video server
- the client configuration detector 218 may only copy parameters of the client configuration 206 which pertain to streaming video.
- the network server 208 further includes a comparator 222 for comparing the copy of the client configuration 220 and the server configuration 214 .
- the comparator 222 is a software module.
- the comparator 222 determines if the copy of the client configuration 220 is compatible with the server configuration 214 . The results of this determination made by the comparator 222 are used by the server communications component 212 .
- the network client 202 creates the network connection 210 to the network server 208 using the method of the prior art described with respect to FIG. 1 above.
- the client configuration detector 218 detects the client configuration 206 . This detection can be achieved using an API, such as a TCP API, which requests that the server communications component 212 sends a network message to the client communications component 204 requesting details of the client configuration 206 . The client communications component 204 subsequently sends details of the client configuration 206 to the server communications component over the network connection 210 .
- the client configuration detector 218 can detect the client configuration 206 by requesting that the server communications component 212 sends “sampling” network messages to the client communications component 204 .
- a response received by the server communications component 212 from the client communications component 204 following these sampling network messages can be used by the client configuration detector 218 to determine the client configuration 206 .
- the client configuration detector 218 can request that the server communications component 212 sends a sampling message to the client communications component 204 , and that the server communications component 212 determines the data transfer speed of a response message sent by the client communications component 204 . In this way, the client configuration detector 218 can determine the data transfer speed specified in the client configuration 206 .
- the client configuration detector 218 then creates a copy of the client configuration 220 in a memory of the network server.
- the server configurator 216 changes the server configuration 214 .
- a value of a parameter in the server configuration 214 is changed to a new value.
- the comparator 222 determines if the copy of the client configuration 220 is compatible with the changed server configuration 214 .
- the server communications component 212 disconnects the network client 202 only if the comparator 222 determines that the copy of the client configuration 220 is not compatible with the server configuration 214 .
- the network client 202 is only disconnected from the network server 208 if the client configuration 206 is incompatible with a changed server configuration 214 .
- FIG. 3 is a schematic diagram illustrating a client computer system including a streaming video client connected to a server computer system including a streaming video server using the TCP connection-oriented protocol in a preferred embodiment of the present invention.
- the elements of FIG. 3 are specific examples of the elements described with respect to FIG. 2 .
- FIG. 3 includes three client computer systems 302 a , 302 b and 302 c connected to a server computer system 308 using a TCP network connection 310 .
- Each computer system includes a streaming video client 304 , and a maximum frame rate parameter 306 .
- the streaming video client 304 is a communications software module configured to receive a data stream of video data for use by a presentation module (not shown) for displaying the video data on a screen.
- the streaming video client 304 offers facilities for error, sequence and flow control to ensure the video data arrives without error and in a correct sequence.
- the streaming video client 304 is Microsoft Media Player (Microsoft is a registered trademark of Microsoft Corporation).
- the maximum frame rate parameter 306 is a parameter which is assigned a numeric value corresponding to a maximum frame rate of video data which the client computer systems 302 are capable of receiving and displaying. Thus, video data with a frame rate exceeding the maximum frame rate parameter 306 a for computer system 302 a is incompatible with computer system 302 a.
- Server computer system 308 includes video data 324 which is recorded on a storage device of the server computer system, such as a fixed disk storage device.
- the video data 324 is encoded using a video encoding standard such as one of the Motion Picture Experts Group standards (MPEG) or QuickTime (MPEG is a registered trademark of the Motion Picture Experts Group, Inc. and QuickTime is a registered trademark of Apple Computer Inc.).
- the server computer system 308 further includes a streaming video server 312 which is a communications software module configured to send a data stream of the video data 324 for receipt by each of the client computers 302 .
- the streaming video server 312 offers facilities for error, sequence and flow control to ensure the video data 324 arrives without error and in a correct sequence.
- the streaming video server 312 is the Unreal Media Server developed by the Unreal Streaming Technologies group.
- the server computer system 308 also includes a server frame rate parameter 314 which is assigned a numeric value corresponding to a frame rate of the video data 324 .
- the value of the server frame rate parameter 314 can be changed by the streaming video server configurator 316 .
- the server computer system 308 also includes a client frame rate detector 318 which detects the maximum frame rate 306 of each of the client computer systems 302 and stores the maximum frame rates in a memory of the server computer system 308 as a copy of the client frame rates 320 .
- this detection can be achieved using an API, such as a TCP API, which requests that the streaming video server 312 sends a network message to the streaming video clients 304 requesting details of the client configurations 306 .
- the streaming video clients 304 subsequently send details of the client configurations 306 to the streaming video server 312 over the TCP network connection 310 .
- the copy of the client frame rates 320 is organised in a table data structure in the memory of the server computer system 308 , and each frame rate in the copy of the client frame rates 320 includes an indicator of which of the clients 302 a , 302 b or 302 c the frame rate corresponds to.
- the copy of the client frame rates 320 can be stored in a file, a database or in any other data structure in the memory of the server computer system 308 .
- a comparator 322 determines if each of the frame rates in the copy of the client frame rates 320 is compatible with the server frame rate 314 .
- a client frame rate in the copy of the client frame rates 320 is considered incompatible if it has a numerical value which is lower than the server frame rate 314 .
- the streaming video server 312 disconnects the client 302 corresponding to the incompatible frame rate. In this way, changes to the server frame rate 314 result in the disconnection of only those client computer systems 302 with a maximum frame rate parameter 306 which is incompatible with the changed server frame rate 314 .
- FIG. 4 is a flowchart illustrating a method of communication between a network client and a network server over a network in a preferred embodiment of the present invention.
- the method of FIG. 4 will be explained with respect to the configuration of the client computer systems 302 and the server computer system 308 of FIG. 3 .
- the client computer systems 302 connect to the server computer system 308 using a connection-oriented protocol such as TCP. These connections can be made using the method to create a connection in the prior art described above with respect to FIG. 1 .
- the client frame rate detector 318 detects the maximum frame rate 306 of each of the clients 302 and generates a copy of the client frame rates 320 in the memory of the server computer system 308 .
- the streaming video server configurator 316 changes the value of the server frame rate 314 to a new value.
- a loop is initiated through each client frame rate for each client computer system 302 in the copy of the client frame rates 320 .
- a determination is made by the comparator 322 as to whether the client frame rate satisfies the new value of the server frame rate 314 . If the comparator 322 determines that the frame rate is not compatible with the new value of the server frame rate 314 , the streaming video server 312 disconnects the client computer system 302 corresponding to the incompatible frame rate at step 412 .
- Step 416 repeats the loop of step 408 until all frame rates in the copy of client frame rates 320 has been processed.
- changes to the server frame rate 314 result in the disconnection of only those client computer systems 302 with a maximum frame rate parameter 314 which is incompatible with the new value of the server frame rate 314 . Consequently, those client computer systems 302 with a maximum frame rate parameter 306 which is compatible with the new value of the server frame rate parameter 306 continue to be connected to the server computer system 308 .
Abstract
A mechanism is provided for network communication. The mechanism establishes a connection between a network server and a network client. The connection is established using a connection-oriented protocol. The network server has a first server configuration stored in a memory of the network server. The first server configuration comprises a set of server parameters specific to a network application that the network server provides to the network client. The mechanism identifies the network client configuration. The mechanism replaces, in the memory of the network server, the first server configuration with a second server configuration. Responsive to a determination that the client configuration is incompatible with the second server configuration, the mechanism disconnects the network client.
Description
- This invention relates to connection-oriented network connections between network clients and a network server. In particular it relates to disconnecting network clients with an incompatible client configuration when a server configuration is changed.
- Network applications employ network protocols for communication between a network client and a network server. Network protocols can be classified into two main categories: connectionless protocols; and connection-oriented protocols. A connectionless protocol is an asynchronous protocol without a persistent connection between the network client and the network server. For example, a web browser client communicates with a web server using a connectionless protocol known as the hypertext transport protocol (HTTP). Using HTTP, the web browser client can make requests of the web server, such as a request for a particular web page. The web server receives each request as a distinct request which is independent of all other requests, and responds to each request independently. A connection exists between the web browser client and the web server for only as long as it takes to send a request and receive a response. Thus, there is no persistent connection between the web browser client and the web server for multiple requests and responses, and HTTP is therefore considered to be a connectionless protocol.
- In contrast, a connection-oriented protocol provides a persistent connection for the transmission of data between a network client and a network server. Connection-oriented protocols also usually include facilities for error, sequence and flow control. Error control refers to a combination of error detection, correction and acknowledgement sufficient to compensate for any unreliability inherent to the network. Sequence control ensures that the network client and the network server are able to reconstruct data received over the network in the proper order in which they were intended to be received, and is essential in the transmission of large volumes of data. Flow control ensures that network clients and network servers do not overrun each other with too much data. An example of a connection-oriented protocol is the transmission control protocol (TCP) which provides these facilities. An application of TCP is video streaming over a network where a streaming video client can create a persistent connection with a streaming video server for the receipt of streaming video data using TCP. The TCP connection is used by the streaming video server to send large streams of video data for receipt by the streaming video client. Other applications of connection-oriented communications include mobile telephone connections to cellular base stations, digital set-top box connections to a digital television service provider and connections between network chat clients such as Lotus Sametime Connect (Lotus is a registered trade mark of International Business Machines Corp.) and AOL Instant Messenger (a registered trade mark of America Online Inc.).
- Connection-oriented protocols offer effective and reliable communication between network clients and network servers, and support applications requiring long lived connections or connections over which large quantities of data can be transferred. A technique for creating a connection-oriented connection between a network client and a network server is outlined below. A network server will include a server configuration comprising one or more server parameters. Similarly, a network client will include a client configuration comprising one or more client parameters. For example, in a streaming video application, a streaming video server may include a server configuration with a video frame rate parameter corresponding to the frame rate of video data streamed from the server. Similarly, a streaming video client may include a client configuration with a maximum frame rate parameter corresponding to a maximum frame rate of video data the client is able to receive. A network client requests a new connection to a network server using the connection-oriented protocol. This can involve an initial message being sent from the network client to the network server with an indication that a new connection is requested. The network server responds to the initial message with a connection acceptance message, including details of the network server configuration. The network client receives the network server configuration and determines if the client configuration is compatible with the server configuration. For example, the server configuration may include a frame rate which exceeds a maximum frame rate of the client configuration, and the network server configuration is therefore incompatible with the network client configuration. If the client configuration is compatible with the server configuration, a connection is created between the network client and the network server. If the client configuration is not compatible with the server configuration, the network client may abandon the request to create a connection.
- A server configuration can also be changed during a connection-oriented network connection, and such a change can affect connected network clients. For example, one or more connected network clients may be incompatible with a new server configuration, such as a new value of a frame rate parameter of a streaming video server. When a server configuration is changed, the network server must determine a course of action for connected network clients. One technique for changing a server configuration involves disconnecting all connected network clients before the server configuration is changed. Network clients are then able to reconnect and determine if the client configuration is compatible with the new server configuration. This technique has the disadvantage that connected network clients which are compatible with a new server configuration are disconnected unnecessarily, and the quality of service provided by the network client is consequently reduced. An alternative technique for changing a server configuration involves only introducing a new server configuration for new connections. Existing connections continue to operate under the original server configuration (i.e. prior to a change to the configuration). This alternative technique has the advantage that existing connected network clients are not disconnected. However, this alternative technique has the disadvantage that the server must support both an original server configuration for existing connected network clients, and a new server configuration for new network client connections. This can increase the processing requirements of the network server and reduce the performance of the network server. Furthermore, existing connected network clients which support the new server configuration continue to communicate with the server using the original server configuration. This is a particular disadvantage where the new server configuration offers advantages over the original configuration which are to the benefit of existing connected network clients (such as an increase in communications speed).
- It would be desirable to provide a way to change a server configuration of a network server with connected network clients without disconnecting the connected network clients which are compatible with the changed server configuration, and without the need for the network server to support multiple server configurations.
- The present invention accordingly provides, in a first aspect, a method for network communication controlled by a network server over a network using a connection-oriented protocol with a network client, wherein the network server has a first server configuration and the network client has a client configuration, the method comprising the steps of: detecting the network client configuration; replacing said first server configuration with a second server configuration; responsive to a determination that the client configuration is incompatible with the second server configuration, disconnecting the network client.
- Thus, the network client is only disconnected from the network server if the client configuration is incompatible with the second server configuration. If the client configuration is compatible with the second server configuration the network connection between the network client and the network server persists using the second server configuration. In this way the server configuration can be changed (from the first server configuration to the second server configuration) without disconnecting the network client when the client configuration is compatible with the new server configuration, and without the need for the network server to support multiple server configurations.
- The present invention accordingly provides, in a second aspect, a network server for communicating with a network client over a network comprising: a client configuration detector for detecting a configuration of the network client; a server configurator for changing the configuration of the network server; a comparator for determining if the configuration of the network client is compatible with the configuration of the network server; and a server communications component for connecting with the network client using a connection-oriented protocol, wherein the server communications component is operable to disconnect the network client responsive to said comparator.
- The present invention accordingly provides, in a third aspect, a computer program product comprising computer program code stored on a computer readable storage medium which, when executed on a data processing system, instructs the data processing system to carry out the method as described above.
- A preferred embodiment of the present invention will now be described, by way of example only, with reference to the accompanying drawings, in which:
-
FIG. 1 is a schematic diagram illustrating a network client connected to a network server using a connection-oriented protocol in the prior art; -
FIG. 2 is a schematic diagram illustrating a network client connected to a network server using a connection-oriented protocol in a preferred embodiment of the present invention; -
FIG. 3 is a schematic diagram illustrating a client computer system including a streaming video client connected to a server computer system including a streaming video server using the TCP connection-oriented protocol in a preferred embodiment of the present invention; and -
FIG. 4 is a flowchart illustrating a method of communication between a network client and a network server over a network in a preferred embodiment of the present invention. -
FIG. 1 is a schematic diagram illustrating a network client connected to a network server using a connection-oriented protocol in the prior art.Network client 102 is a hardware or software implementation of a client component of a network application. For example, thenetwork client 102 is a streaming video network client intended to receive streaming video data. Alternatively, thenetwork client 102 can be a mobile telephone or other wireless communications device, a digital set top box, a computer system including a network interface card (NIC) or any other network connected device. - The
network client 102 includes aclient communications component 104. Theclient communications component 104 is a software or hardware component of thenetwork client 102 which provides connection-oriented network connections between thenetwork client 102 and other network devices. For example, theclient communications component 104 is a TCP software library, or a software library providing a proprietary connection-oriented network protocol.Network client 102 further includes aclient configuration 106. Theclient configuration 106 is a set of client parameters specific to a particular network application of thenetwork client 102. For example, if thenetwork client 102 is a streaming video network client, theclient configuration 106 can include a maximum frame rate parameter corresponding to a maximum frame rate of video data which can be received by thenetwork client 102. Alternatively, theclient configuration 106 can include parameters relating to data compression standards, data encryption standards, signal strength requirements, data communications speeds, data communications rates, media encoding standards such as audio or video encoding standards or any other parameter required by thenetwork client 102. Furthermore, theclient configuration 106 can include parameters specific to a particular business application, such as financial details (including financial limits), authorisation details (such as access control lists) and business rules. Theclient configuration 106 is stored in a memory of thenetwork client 102, such as a volatile random access memory, a non-volatile memory or a disk storage device. - The
network client 102 is connected to anetwork server 108 over anetwork connection 110. Thenetwork server 108 is a hardware or software implementation of a server component of a network application. For example, thenetwork server 108 is a streaming video network server for sending streaming video data. Alternatively, thenetwork server 108 can be a mobile telephone or other wireless communications access point, a digital set top box service provider, a computer system including a network interface card (NIC) or any other network connected server device. Thenetwork connection 110 is a connection-oriented network connection between theclient communications component 104 of thenetwork client 102 and aserver communications component 112 of thenetwork server 108. Thenetwork connection 110 is implemented using a connection-oriented network protocol. Thenetwork connection 110 can be a connection-oriented network connection which operates on a connectionless protocol, with connection-oriented services provided jointly by theclient communications component 104 and theserver communications component 112. An example of a connection-oriented protocol used bynetwork connection 110 is TCP. Theserver communications component 112 is a software or hardware component of thenetwork server 108 which provides connection-oriented network connections between thenetwork server 108 and other network devices. Thenetwork server 108 further includes aserver configuration 114. Theserver configuration 114 is a set of server parameters specific to a particular network application of thenetwork server 108. For example, if thenetwork server 108 is a streaming video network server, theserver configuration 114 can include a frame rate parameter corresponding to a frame rate of video data stream distributed by thenetwork server 108. Alternatively, theserver configuration 114 can include any of the parameters described above with respect to theclient configuration 106. Theserver configuration 114 is stored in a memory of thenetwork server 108, such as a volatile random access memory, a non-volatile memory or a magnetic or non-magnetic storage device. Thenetwork server 108 further includes aserver configurator 116 for changing theserver configuration 114. Theserver configurator 116 can be a hardware or software component of thenetwork server 108, such as a software application providing a user interface for a user to specify anew server configuration 114. - In use, the
network client 102 creates thenetwork connection 110 to thenetwork server 108 using a connection-oriented network protocol. The creation of thenetwork connection 110 can involve theclient communications component 104 sending an initialisation message to theserver communications component 112 requesting the creation of a new network connection. In response to the initialisation message, theserver communications component 112 provides a response message to theclient communications component 104 with details of theserver configuration 114. Theclient communications component 104 receives the details of theserver configuration 114 and determines if theclient configuration 106 is compatible with theserver configuration 114. If theclient configuration 106 is compatible with theserver configuration 114, thenetwork connection 110 is created between thenetwork client 102 and thenetwork server 108. If theclient configuration 106 is not compatible with theserver configuration 114, thenetwork client 102 may abandon the request to create thenetwork connection 110. Subsequently, if thenetwork connection 110 is successfully created, thenetwork client 102 is able to send data to, and receive data from, thenetwork server 108 over thenetwork connection 110 using the connection-oriented protocol. Subsequently, when theserver configurator 116 changes theserver configuration 114, thenetwork client 102 is disconnected by theserver communications component 112 which closes thenetwork connection 110. Subsequently, thenetwork client 102 is able to attempt to re-create thenetwork connection 110. -
FIG. 2 is a schematic diagram illustrating a network client connected to a network server using a connection-oriented protocol in a preferred embodiment of the present invention. Many elements ofFIG. 2 are identical to those described with respect toFIG. 1 and these will not be further described here in the description ofFIG. 2 . Thenetwork server 208 ofFIG. 2 further includes aclient configuration detector 218 which detects theclient configuration 206 and generates a copy of theclient configuration 220. In the preferred embodiment, theclient configuration detector 218 is a software module operable to communicate with theserver communications component 212 using an application programming interface (API), such as a TCP API. Alternatively, theclient configuration detector 218 can be a component of theserver communications component 212. The copy of theclient configuration 220 is stored in a memory of thenetwork server 208, such as a volatile random access memory, a non-volatile memory or a magnetic or non-magnetic storage device. The copy of theclient configuration 220 can be a complete copy of theclient configuration 206, or alternatively can be a partial copy of only relevant parameters ofclient configuration 206. For example, if thenetwork server 208 is a streaming video server, theclient configuration detector 218 may only copy parameters of theclient configuration 206 which pertain to streaming video. Thenetwork server 208 further includes acomparator 222 for comparing the copy of theclient configuration 220 and theserver configuration 214. In the preferred embodiment thecomparator 222 is a software module. Thecomparator 222 determines if the copy of theclient configuration 220 is compatible with theserver configuration 214. The results of this determination made by thecomparator 222 are used by theserver communications component 212. - In use, the
network client 202 creates thenetwork connection 210 to thenetwork server 208 using the method of the prior art described with respect toFIG. 1 above. On creation of thenetwork connection 210, theclient configuration detector 218 detects theclient configuration 206. This detection can be achieved using an API, such as a TCP API, which requests that theserver communications component 212 sends a network message to theclient communications component 204 requesting details of theclient configuration 206. Theclient communications component 204 subsequently sends details of theclient configuration 206 to the server communications component over thenetwork connection 210. Alternatively, theclient configuration detector 218 can detect theclient configuration 206 by requesting that theserver communications component 212 sends “sampling” network messages to theclient communications component 204. A response received by theserver communications component 212 from theclient communications component 204 following these sampling network messages can be used by theclient configuration detector 218 to determine theclient configuration 206. For example, if theclient configuration 206 includes a parameter for a data transfer speed for messages sent by theclient communications component 204, theclient configuration detector 218 can request that theserver communications component 212 sends a sampling message to theclient communications component 204, and that theserver communications component 212 determines the data transfer speed of a response message sent by theclient communications component 204. In this way, theclient configuration detector 218 can determine the data transfer speed specified in theclient configuration 206. Theclient configuration detector 218 then creates a copy of theclient configuration 220 in a memory of the network server. Subsequently, theserver configurator 216 changes theserver configuration 214. For example, a value of a parameter in theserver configuration 214 is changed to a new value. Thecomparator 222 then determines if the copy of theclient configuration 220 is compatible with the changedserver configuration 214. Subsequently, theserver communications component 212 disconnects thenetwork client 202 only if thecomparator 222 determines that the copy of theclient configuration 220 is not compatible with theserver configuration 214. Thus, in this way, thenetwork client 202 is only disconnected from thenetwork server 208 if theclient configuration 206 is incompatible with a changedserver configuration 214. - The preferred embodiment will now be described in use for a streaming video application with reference to
FIGS. 3 and 4 .FIG. 3 is a schematic diagram illustrating a client computer system including a streaming video client connected to a server computer system including a streaming video server using the TCP connection-oriented protocol in a preferred embodiment of the present invention. The elements ofFIG. 3 are specific examples of the elements described with respect toFIG. 2 . In particular,FIG. 3 includes threeclient computer systems server computer system 308 using aTCP network connection 310. Each computer system includes a streaming video client 304, and a maximum frame rate parameter 306. The streaming video client 304 is a communications software module configured to receive a data stream of video data for use by a presentation module (not shown) for displaying the video data on a screen. The streaming video client 304 offers facilities for error, sequence and flow control to ensure the video data arrives without error and in a correct sequence. For example, the streaming video client 304 is Microsoft Media Player (Microsoft is a registered trademark of Microsoft Corporation). The maximum frame rate parameter 306 is a parameter which is assigned a numeric value corresponding to a maximum frame rate of video data which the client computer systems 302 are capable of receiving and displaying. Thus, video data with a frame rate exceeding the maximumframe rate parameter 306 a forcomputer system 302 a is incompatible withcomputer system 302 a. -
Server computer system 308 includesvideo data 324 which is recorded on a storage device of the server computer system, such as a fixed disk storage device. Thevideo data 324 is encoded using a video encoding standard such as one of the Motion Picture Experts Group standards (MPEG) or QuickTime (MPEG is a registered trademark of the Motion Picture Experts Group, Inc. and QuickTime is a registered trademark of Apple Computer Inc.). Theserver computer system 308 further includes astreaming video server 312 which is a communications software module configured to send a data stream of thevideo data 324 for receipt by each of the client computers 302. Thestreaming video server 312 offers facilities for error, sequence and flow control to ensure thevideo data 324 arrives without error and in a correct sequence. For example, thestreaming video server 312 is the Unreal Media Server developed by the Unreal Streaming Technologies group. Theserver computer system 308 also includes a serverframe rate parameter 314 which is assigned a numeric value corresponding to a frame rate of thevideo data 324. The value of the serverframe rate parameter 314 can be changed by the streamingvideo server configurator 316. Theserver computer system 308 also includes a clientframe rate detector 318 which detects the maximum frame rate 306 of each of the client computer systems 302 and stores the maximum frame rates in a memory of theserver computer system 308 as a copy of theclient frame rates 320. For example, this detection can be achieved using an API, such as a TCP API, which requests that thestreaming video server 312 sends a network message to the streaming video clients 304 requesting details of the client configurations 306. The streaming video clients 304 subsequently send details of the client configurations 306 to thestreaming video server 312 over theTCP network connection 310. The copy of theclient frame rates 320 is organised in a table data structure in the memory of theserver computer system 308, and each frame rate in the copy of theclient frame rates 320 includes an indicator of which of theclients client frame rates 320 can be stored in a file, a database or in any other data structure in the memory of theserver computer system 308. When the value of theserver frame rate 314 is changed by the streamingvideo server configurator 316, acomparator 322 determines if each of the frame rates in the copy of theclient frame rates 320 is compatible with theserver frame rate 314. A client frame rate in the copy of theclient frame rates 320 is considered incompatible if it has a numerical value which is lower than theserver frame rate 314. If thecomparator 322 determines that a client frame rate in the copy of theclient frame rates 320 is incompatible with the changedserver frame rate 314, thestreaming video server 312 disconnects the client 302 corresponding to the incompatible frame rate. In this way, changes to theserver frame rate 314 result in the disconnection of only those client computer systems 302 with a maximum frame rate parameter 306 which is incompatible with the changedserver frame rate 314. -
FIG. 4 is a flowchart illustrating a method of communication between a network client and a network server over a network in a preferred embodiment of the present invention. The method ofFIG. 4 will be explained with respect to the configuration of the client computer systems 302 and theserver computer system 308 ofFIG. 3 . Atstep 402, the client computer systems 302 connect to theserver computer system 308 using a connection-oriented protocol such as TCP. These connections can be made using the method to create a connection in the prior art described above with respect toFIG. 1 . Atstep 404, the clientframe rate detector 318 detects the maximum frame rate 306 of each of the clients 302 and generates a copy of theclient frame rates 320 in the memory of theserver computer system 308. Subsequently, at step 406, the streamingvideo server configurator 316 changes the value of theserver frame rate 314 to a new value. At step 408 a loop is initiated through each client frame rate for each client computer system 302 in the copy of theclient frame rates 320. Atstep 410, for each client frame rate for each client computer system 302 in the copy of theclient frame rates 320, a determination is made by thecomparator 322 as to whether the client frame rate satisfies the new value of theserver frame rate 314. If thecomparator 322 determines that the frame rate is not compatible with the new value of theserver frame rate 314, thestreaming video server 312 disconnects the client computer system 302 corresponding to the incompatible frame rate atstep 412. Step 416 repeats the loop ofstep 408 until all frame rates in the copy ofclient frame rates 320 has been processed. In this way, changes to theserver frame rate 314 result in the disconnection of only those client computer systems 302 with a maximumframe rate parameter 314 which is incompatible with the new value of theserver frame rate 314. Consequently, those client computer systems 302 with a maximum frame rate parameter 306 which is compatible with the new value of the server frame rate parameter 306 continue to be connected to theserver computer system 308.
Claims (21)
1. A method for network communication, the method comprising the steps of:
establishing a connection between a network server and a network client, wherein the connection is established using a connection-oriented protocol, wherein the network server has a first server configuration stored in a memory of the network server, and wherein the first server configuration comprises a set of server parameters specific to a network application that the network server provides to the network client;
identifying the network client configuration;
replacing, in the memory of the network server, said first server configuration with a second server configuration;
responsive to a determination that the client configuration is incompatible with the second server configuration, disconnecting the network client.
2. The method of claim 1 wherein the connection-oriented protocol is provided over a network connection using a connectionless protocol.
3. The method of claim 1 wherein the determination that the client configuration is incompatible with the second server configuration is determined by the network server.
4. The method of claim 1 , wherein the network client has a network client configuration stored in a memory of the network client, and wherein the network client configuration comprises a set of client parameters specific to the network application for the corresponding network client, and wherein identifying the network client configuration further comprises receiving a message at the network server, wherein the message includes the network client configuration.
5. The method of claim 1 wherein the client configuration, the first server configuration and the second server configuration include data compression parameters.
6. The method of claim 1 wherein the client configuration, the first server configuration and the second server configuration include data encryption parameters.
7. The method of claim 1 wherein the client configuration, the first server configuration and the second server configuration include signal strength parameters.
8. The method of claim 1 wherein the client configuration, the first server configuration and the second server configuration include data communication speed parameters.
9. The method of claim 1 wherein the client configuration, the first server configuration and the second server configuration include media encoding parameters.
10. The method of claim 1 wherein the client configuration, the first server configuration and the second server configuration include business application parameters.
11-13. (canceled)
14. The method of claim 1 , wherein identifying the network client configuration comprises:
sending sampling network messages from the network server to the network client;
receiving responses from the network client, wherein the responses are responsive to the sampling network messages; and
determining the network configuration based on the responses.
15. An apparatus in a network server, comprising:
a processor; and
a memory coupled to the processor, wherein the memory comprises instructions which, when executed by the processor, cause the processor to:
establish a connection between a network server and a network client, wherein the connection is established using a connection-oriented protocol, wherein the network server has a first server configuration stored in a memory of the network server, and wherein the first server configuration comprises a set of server parameters specific to a network application that the network server provides to the network client;
identify the network client configuration;
replace, in the memory of the network server, said first server configuration with a second server configuration;
responsive to a determination that the client configuration is incompatible with the second server configuration, disconnect the network client.
16. The apparatus of claim 15 , wherein the determination that the client configuration is incompatible with the second server configuration is determined by the network server.
17. The apparatus of claim 15 , wherein the network client has a network client configuration stored in a memory of the network client, and wherein the network client configuration comprises a set of client parameters specific to the network application for the corresponding network client, and wherein identifying the network client configuration further comprises receiving a message at the network server, wherein the message includes the network client configuration.
18. The apparatus of claim 15 , wherein the client configuration, the first server configuration and the second server configuration include at least one of data compression parameters, data encryption parameters, signal strength parameters, data communication speed parameters, media encoding parameters, or business application parameters.
19. The apparatus of claim 15 , wherein identifying the network client configuration comprises:
sending sampling network messages from the network server to the network client;
receiving responses from the network client, wherein the responses are responsive to the sampling network messages; and
determining the network configuration based on the responses.
20. A computer program product comprising a computer recordable medium having a computer readable program recorded thereon, wherein the computer readable program, when executed on a network server, causes the network server to:
establish a connection between a network server and a network client, wherein the connection is established using a connection-oriented protocol, wherein the network server has a first server configuration stored in a memory of the network server, and wherein the first server configuration comprises a set of server parameters specific to a network application that the network server provides to the network client;
identify the network client configuration;
replace, in the memory of the network server, said first server configuration with a second server configuration;
responsive to a determination that the client configuration is incompatible with the second server configuration, disconnect the network client.
21. The computer program product of claim 20 , wherein the network client has a network client configuration stored in a memory of the network client, and wherein the network client configuration comprises a set of client parameters specific to the network application for the corresponding network client, and wherein identifying the network client configuration further comprises receiving a message at the network server, wherein the message includes the network client configuration.
22. The computer program product of claim 20 , wherein the client configuration, the first server configuration and the second server configuration include at least one of data compression parameters, data encryption parameters, signal strength parameters, data communication speed parameters, media encoding parameters, or business application parameters.
23. The computer program product of claim 20 , wherein identifying the network client configuration comprises:
sending sampling network messages from the network server to the network client;
receiving responses from the network client, wherein the responses are responsive to the sampling network messages; and
determining the network configuration based on the responses.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/409,844 US20090240820A1 (en) | 2003-12-06 | 2009-03-24 | Quality of Service for Network Connected Clients |
Applications Claiming Priority (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
GB0328383.5 | 2003-12-06 | ||
GBGB0328383.5A GB0328383D0 (en) | 2003-12-06 | 2003-12-06 | Improved quality of service for network connected clients |
US59622006A | 2006-06-05 | 2006-06-05 | |
US12/409,844 US20090240820A1 (en) | 2003-12-06 | 2009-03-24 | Quality of Service for Network Connected Clients |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US59622006A Continuation | 2003-12-06 | 2006-06-05 |
Publications (1)
Publication Number | Publication Date |
---|---|
US20090240820A1 true US20090240820A1 (en) | 2009-09-24 |
Family
ID=30129795
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/596,220 Expired - Fee Related US7519717B2 (en) | 2003-12-06 | 2004-12-02 | Quality of service for network connected clients |
US12/409,844 Abandoned US20090240820A1 (en) | 2003-12-06 | 2009-03-24 | Quality of Service for Network Connected Clients |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/596,220 Expired - Fee Related US7519717B2 (en) | 2003-12-06 | 2004-12-02 | Quality of service for network connected clients |
Country Status (5)
Country | Link |
---|---|
US (2) | US7519717B2 (en) |
JP (1) | JP4538465B2 (en) |
CN (1) | CN1879387B (en) |
GB (1) | GB0328383D0 (en) |
WO (1) | WO2005055554A1 (en) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120215841A1 (en) * | 2010-03-18 | 2012-08-23 | Tencent Technology (Shenzhen) Company Limited | Method and system for synchronizing operations of multiple groups |
US20140317181A1 (en) * | 2011-12-31 | 2014-10-23 | Hangzhou H3C Technologies Co., Ltd. | Establishing dynamic connection |
Families Citing this family (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6832245B1 (en) | 1999-12-01 | 2004-12-14 | At&T Corp. | System and method for analyzing communications of user messages to rank users and contacts based on message content |
US7774711B2 (en) | 2001-09-28 | 2010-08-10 | Aol Inc. | Automatic categorization of entries in a contact list |
US7263614B2 (en) | 2002-12-31 | 2007-08-28 | Aol Llc | Implicit access for communications pathway |
US7945674B2 (en) | 2003-04-02 | 2011-05-17 | Aol Inc. | Degrees of separation for handling communications |
US7613776B1 (en) | 2003-03-26 | 2009-11-03 | Aol Llc | Identifying and using identities deemed to be known to a user |
US8898239B2 (en) * | 2004-03-05 | 2014-11-25 | Aol Inc. | Passively populating a participant list with known contacts |
US8285809B2 (en) * | 2005-12-13 | 2012-10-09 | Audio Pod Inc. | Segmentation and transmission of audio streams |
US8234397B2 (en) * | 2006-01-06 | 2012-07-31 | Google Inc. | Media article adaptation to client device |
US8214516B2 (en) * | 2006-01-06 | 2012-07-03 | Google Inc. | Dynamic media serving infrastructure |
US8838797B2 (en) * | 2009-07-10 | 2014-09-16 | Empire Technology Development Llc | Dynamic computation allocation |
US8805970B2 (en) | 2010-10-25 | 2014-08-12 | International Business Machines Corporation | Automatic management of configuration parameters and parameter management engine |
WO2012158956A2 (en) * | 2011-05-17 | 2012-11-22 | Archion, Inc. | Virtualized workspaces for standardization of access to data |
CN104168174A (en) * | 2013-05-16 | 2014-11-26 | 阿里巴巴集团控股有限公司 | Method and apparatus for information transmission |
CN106487864B (en) * | 2015-09-02 | 2019-09-27 | 华为终端有限公司 | Method for building up, server-side and the mobile terminal of data connection |
Citations (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5638412A (en) * | 1994-06-15 | 1997-06-10 | Qualcomm Incorporated | Method for providing service and rate negotiation in a mobile communication system |
US5926636A (en) * | 1996-02-21 | 1999-07-20 | Adaptec, Inc. | Remote procedural call component management method for a heterogeneous computer network |
US6052720A (en) * | 1998-05-14 | 2000-04-18 | Sun Microsystems, Inc. | Generic schema for storing configuration information on a server computer |
US6098098A (en) * | 1997-11-14 | 2000-08-01 | Enhanced Messaging Systems, Inc. | System for managing the configuration of multiple computer devices |
US6341291B1 (en) * | 1998-09-28 | 2002-01-22 | Bentley Systems, Inc. | System for collaborative engineering using component and file-oriented tools |
US20020046243A1 (en) * | 1997-05-20 | 2002-04-18 | America Online, Inc. | Self-policing, rate limiting online forums |
US6469991B1 (en) * | 1997-10-14 | 2002-10-22 | Lucent Technologies Inc. | Method for overload control in a multiple access system for communication networks |
US6487596B1 (en) * | 1998-07-15 | 2002-11-26 | At&T Corp. | Adaptive modem connection lifetimes |
US20020177413A1 (en) * | 2001-03-14 | 2002-11-28 | Jarkko Jouppi | Method for selecting a quality of service in a wireless communication system |
US6519767B1 (en) * | 1995-06-07 | 2003-02-11 | Microsoft Corporation | Compiler and method for automatically building version compatible object applications |
US6560604B1 (en) * | 2000-03-10 | 2003-05-06 | Aether Systems, Inc. | System, method, and apparatus for automatically and dynamically updating options, features, and/or services available to a client device |
US20030145315A1 (en) * | 2002-01-23 | 2003-07-31 | Tuomo Aro | Exchange of data between components of distributed software having different versions of software |
US20030172270A1 (en) * | 2001-12-12 | 2003-09-11 | Newcombe Christopher Richard | Method and system for enabling content security in a distributed system |
US20040064563A1 (en) * | 2000-08-31 | 2004-04-01 | Kauhanen Timo Heikki | Change of bandwidth in a cellular communications system |
US20040203593A1 (en) * | 2002-08-09 | 2004-10-14 | Robert Whelan | Mobile unit configuration management for WLANs |
US20050005025A1 (en) * | 2003-07-04 | 2005-01-06 | Michael Harville | Method for managing a streaming media service |
US6947535B2 (en) * | 1998-10-19 | 2005-09-20 | Nokia Corporation | Service control in a telecommunications network |
US6968184B2 (en) * | 1996-08-07 | 2005-11-22 | Symbol Technologies, Inc. | Wireless software upgrades with version control |
US7047527B1 (en) * | 2002-07-18 | 2006-05-16 | Unisys Corporation | Method for identification of version levels of components across heterogeneous systems while eliminating mis-matched versions |
US7047308B2 (en) * | 2001-08-31 | 2006-05-16 | Sharp Laboratories Of America, Inc. | System and method for simultaneous media playout |
US7089548B2 (en) * | 2003-01-13 | 2006-08-08 | Taiwan Semiconductor Manufacturing Company, Ltd. | Method and system for nondisruptive deployment during upgrading of enterprise systems |
US7103650B1 (en) * | 2000-09-26 | 2006-09-05 | Microsoft Corporation | Client computer configuration based on server computer update |
US7169050B1 (en) * | 2002-08-28 | 2007-01-30 | Matthew George Tyler | Online gaming cheating prevention system and method |
US7190957B2 (en) * | 2002-08-01 | 2007-03-13 | Ntt Docomo, Inc. | Base station connection method, radio network controller, and mobile station |
US7263610B2 (en) * | 2002-07-30 | 2007-08-28 | Imagictv, Inc. | Secure multicast flow |
US7287082B1 (en) * | 2003-03-03 | 2007-10-23 | Cisco Technology, Inc. | System using idle connection metric indicating a value based on connection characteristic for performing connection drop sequence |
US7318101B2 (en) * | 2003-11-24 | 2008-01-08 | Cisco Technology, Inc. | Methods and apparatus supporting configuration in a network |
US7574217B1 (en) * | 2003-09-02 | 2009-08-11 | Cisco Technology, Inc. | Method for dynamic configuration of a mobile access point |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB9414951D0 (en) * | 1994-07-25 | 1994-09-14 | British Telecomm | Computer system having client-server architecture |
JP3547887B2 (en) * | 1995-11-30 | 2004-07-28 | 株式会社東芝 | Node device and network resource reservation method |
JP3617868B2 (en) * | 1996-02-29 | 2005-02-09 | 株式会社東芝 | Node device and network resource reservation method |
IL134231A0 (en) * | 1997-07-30 | 2001-04-30 | Visto Corp | System and method for globally and securely accessing unifiled information in a computer network |
JP3775196B2 (en) * | 2000-09-29 | 2006-05-17 | 株式会社日立製作所 | Network access control device, control method thereof, control system thereof, and communication service method |
US7171661B1 (en) | 2000-10-19 | 2007-01-30 | International Business Machines Corporation | Realtime configuration updates and software distribution to active client positions |
JP3623455B2 (en) * | 2001-02-02 | 2005-02-23 | 日本電信電話株式会社 | Packet transfer control method, program for causing computer to execute the method, and recording medium recording the program |
JP2003274053A (en) * | 2002-03-19 | 2003-09-26 | Acca Networks Co Ltd | METHOD AND APPARATUS FOR REVISING COMMUNICATION SETTING IN xDSL SERVER |
JP2004274185A (en) * | 2003-03-05 | 2004-09-30 | Ntt Docomo Inc | Communication system, information transmitting apparatus, control apparatus, monitoring apparatus, and communication method |
-
2003
- 2003-12-06 GB GBGB0328383.5A patent/GB0328383D0/en not_active Ceased
-
2004
- 2004-12-02 CN CN2004800334543A patent/CN1879387B/en not_active Expired - Fee Related
- 2004-12-02 WO PCT/EP2004/053235 patent/WO2005055554A1/en active Application Filing
- 2004-12-02 JP JP2006541946A patent/JP4538465B2/en not_active Expired - Fee Related
- 2004-12-02 US US10/596,220 patent/US7519717B2/en not_active Expired - Fee Related
-
2009
- 2009-03-24 US US12/409,844 patent/US20090240820A1/en not_active Abandoned
Patent Citations (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5638412A (en) * | 1994-06-15 | 1997-06-10 | Qualcomm Incorporated | Method for providing service and rate negotiation in a mobile communication system |
US6519767B1 (en) * | 1995-06-07 | 2003-02-11 | Microsoft Corporation | Compiler and method for automatically building version compatible object applications |
US5926636A (en) * | 1996-02-21 | 1999-07-20 | Adaptec, Inc. | Remote procedural call component management method for a heterogeneous computer network |
US6968184B2 (en) * | 1996-08-07 | 2005-11-22 | Symbol Technologies, Inc. | Wireless software upgrades with version control |
US20020046243A1 (en) * | 1997-05-20 | 2002-04-18 | America Online, Inc. | Self-policing, rate limiting online forums |
US6469991B1 (en) * | 1997-10-14 | 2002-10-22 | Lucent Technologies Inc. | Method for overload control in a multiple access system for communication networks |
US6098098A (en) * | 1997-11-14 | 2000-08-01 | Enhanced Messaging Systems, Inc. | System for managing the configuration of multiple computer devices |
US6052720A (en) * | 1998-05-14 | 2000-04-18 | Sun Microsystems, Inc. | Generic schema for storing configuration information on a server computer |
US6487596B1 (en) * | 1998-07-15 | 2002-11-26 | At&T Corp. | Adaptive modem connection lifetimes |
US6341291B1 (en) * | 1998-09-28 | 2002-01-22 | Bentley Systems, Inc. | System for collaborative engineering using component and file-oriented tools |
US6947535B2 (en) * | 1998-10-19 | 2005-09-20 | Nokia Corporation | Service control in a telecommunications network |
US6560604B1 (en) * | 2000-03-10 | 2003-05-06 | Aether Systems, Inc. | System, method, and apparatus for automatically and dynamically updating options, features, and/or services available to a client device |
US20040064563A1 (en) * | 2000-08-31 | 2004-04-01 | Kauhanen Timo Heikki | Change of bandwidth in a cellular communications system |
US7103650B1 (en) * | 2000-09-26 | 2006-09-05 | Microsoft Corporation | Client computer configuration based on server computer update |
US20020177413A1 (en) * | 2001-03-14 | 2002-11-28 | Jarkko Jouppi | Method for selecting a quality of service in a wireless communication system |
US7047308B2 (en) * | 2001-08-31 | 2006-05-16 | Sharp Laboratories Of America, Inc. | System and method for simultaneous media playout |
US20030172270A1 (en) * | 2001-12-12 | 2003-09-11 | Newcombe Christopher Richard | Method and system for enabling content security in a distributed system |
US20030145315A1 (en) * | 2002-01-23 | 2003-07-31 | Tuomo Aro | Exchange of data between components of distributed software having different versions of software |
US7047527B1 (en) * | 2002-07-18 | 2006-05-16 | Unisys Corporation | Method for identification of version levels of components across heterogeneous systems while eliminating mis-matched versions |
US7263610B2 (en) * | 2002-07-30 | 2007-08-28 | Imagictv, Inc. | Secure multicast flow |
US7190957B2 (en) * | 2002-08-01 | 2007-03-13 | Ntt Docomo, Inc. | Base station connection method, radio network controller, and mobile station |
US20040203593A1 (en) * | 2002-08-09 | 2004-10-14 | Robert Whelan | Mobile unit configuration management for WLANs |
US7169050B1 (en) * | 2002-08-28 | 2007-01-30 | Matthew George Tyler | Online gaming cheating prevention system and method |
US7089548B2 (en) * | 2003-01-13 | 2006-08-08 | Taiwan Semiconductor Manufacturing Company, Ltd. | Method and system for nondisruptive deployment during upgrading of enterprise systems |
US7287082B1 (en) * | 2003-03-03 | 2007-10-23 | Cisco Technology, Inc. | System using idle connection metric indicating a value based on connection characteristic for performing connection drop sequence |
US20050005025A1 (en) * | 2003-07-04 | 2005-01-06 | Michael Harville | Method for managing a streaming media service |
US7574217B1 (en) * | 2003-09-02 | 2009-08-11 | Cisco Technology, Inc. | Method for dynamic configuration of a mobile access point |
US7318101B2 (en) * | 2003-11-24 | 2008-01-08 | Cisco Technology, Inc. | Methods and apparatus supporting configuration in a network |
Non-Patent Citations (1)
Title |
---|
Christoph, Bjorn et al.; PunkBuster for Server Administrators; July 21, 2003; Even Balance, Inc; Pertinent Sections: Quick Start Guide, Updating PunkBuster, Player Name Management Facility, Monitoring Game Variables * |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20120215841A1 (en) * | 2010-03-18 | 2012-08-23 | Tencent Technology (Shenzhen) Company Limited | Method and system for synchronizing operations of multiple groups |
US8954494B2 (en) * | 2010-03-18 | 2015-02-10 | Tencent Technology (Shenzhen) Company Limited | Method and system for synchronizing operations of multiple groups |
US20140317181A1 (en) * | 2011-12-31 | 2014-10-23 | Hangzhou H3C Technologies Co., Ltd. | Establishing dynamic connection |
Also Published As
Publication number | Publication date |
---|---|
WO2005055554A1 (en) | 2005-06-16 |
JP2007517284A (en) | 2007-06-28 |
CN1879387B (en) | 2010-09-22 |
CN1879387A (en) | 2006-12-13 |
GB0328383D0 (en) | 2004-01-14 |
JP4538465B2 (en) | 2010-09-08 |
US7519717B2 (en) | 2009-04-14 |
US20070100974A1 (en) | 2007-05-03 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20090240820A1 (en) | Quality of Service for Network Connected Clients | |
US6961754B2 (en) | Interactive access, manipulation, sharing and exchange of multimedia data | |
US9161087B2 (en) | User controlled multi-device media-on-demand system | |
US8688854B2 (en) | Messenger notification system and method using synchronization server | |
EP1623341B1 (en) | Methods, data structures, and systems for processing media data streams | |
US7640246B2 (en) | Method and system for providing content | |
KR101378218B1 (en) | Continuable communication management apparatus and continuable communication managing method | |
US20130010794A1 (en) | Generating Multiple Data Steams From a Single Data Source | |
US20040223485A1 (en) | Adaptive notification delivery in a multi-device environment | |
US20120143988A1 (en) | Dynamically optimizing delivery of multimedia content over a network | |
US8572278B2 (en) | Generating multiple data streams from a single data source | |
US8990870B2 (en) | Multi-source assisted content delivering system | |
KR101351715B1 (en) | Inheritance communication administrating apparatus | |
CN108551571B (en) | Monitoring video distribution method, device and system and distribution server | |
US20050055448A1 (en) | Internet service synchronization method for mobile communication terminal | |
US20040117458A1 (en) | Program, method and apparatus for processing information | |
KR100303087B1 (en) | Session and resource manager and manage method in a video on demand system | |
CN101313544A (en) | Method, system and apparatus for uploading user proxy archive information | |
WO2008078853A1 (en) | Method for receiving efficient video using received signal strength notification mechanism in iptv environment | |
KR100834295B1 (en) | Method for converting image in real time | |
CN1173566C (en) | Communicating enhancement data in layers | |
Vetro et al. | Providing multimedia services to a diverse set of consumer devices | |
CN112135178A (en) | Method, system and storage medium for realizing two-way communication based on television | |
CN117296040A (en) | Multimedia content access in remote desktop sessions | |
CN116233085A (en) | Multi-terminal streaming media transmission method, system and streaming media server cluster |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- AFTER EXAMINER'S ANSWER OR BOARD OF APPEALS DECISION |