Method and system for remote access to computer devices via client managed server buffers exclusively allocated to the client
First Claim
1. In a computer system having a client and server, a method for accessing a remote device of the server, comprising:
- allocating a plurality of managed buffers at the server for exclusive use by the client and server;
receiving an I/O request at a client mechanism;
communicating a message corresponding to the I/O request to a server mechanism, the client managing the buffers at the server including designating a managed buffer for buffering data in the message, the server buffering at least some of the data in the message in the managed buffer designated by the client; and
passing information in the message from the server mechanism to a device driver associated with the remote device.
2 Assignments
0 Petitions
Accused Products
Abstract
A method and system for providing remote access and control of devices such as disks, tape drives and modems across a network. A client driver intercepts I/O requests that are destined for a device which an application essentially considers a local device, such as for purposes of disk mirroring. The client driver queues and dequeues the I/O request, marshals it with header information and data, and sends it as a message to the server over one of possibly multiple connections to the server. A server driver unmarshalls the message, places it in a preallocated buffer as designated by the client, and generates an I/O request therefrom directed to the server device. The server responds with a completion status. The client side manages the server buffers, and the client classifies and partitions large requests into one or more segments that fit the server buffers. Sequential processing also may be ensured. The client also handles cancel operations on the remote device, and the client may also load balance across the multiple paths, by selecting a connection based on criteria including pending message size and dynamic performance measurements of the connections.
-
Citations
72 Claims
-
1. In a computer system having a client and server, a method for accessing a remote device of the server, comprising:
-
allocating a plurality of managed buffers at the server for exclusive use by the client and server;
receiving an I/O request at a client mechanism;
communicating a message corresponding to the I/O request to a server mechanism, the client managing the buffers at the server including designating a managed buffer for buffering data in the message, the server buffering at least some of the data in the message in the managed buffer designated by the client; and
passing information in the message from the server mechanism to a device driver associated with the remote device. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36)
-
- 37. In a computer system having a client and server connected by a communication mechanism, a system for accessing a device of the server from the client, comprising, a client-side mechanism for allocating a plurality of managed buffers on the server, the managed buffers managed by the client for exclusive use by the client and server, a client-side driver for receiving an I/O request and preparing the I/O request as a message for communication, the message identifying a designated managed buffer on the server as designated by the client, the client-side driver connected to the communication mechanism for sending the message, a server-side mechanism connected to the communication mechanism for receiving the message, the server-side mechanism interpreting the message to place information therein into the designated managed buffer on the server, and the server-side mechanism passing information in the message to a device driver associated with the device of the server.
- 64. In a computer system having a client and server, a method for accessing a remote device of the server, comprising, allocating a plurality of managed buffers at the server, the buffers managed by the client for exclusive use by the client and server, receiving an I/O request at a client mechanism, selecting at the client one of the managed buffets on the server, sending a message corresponding to the I/O request to the server, the message associated with information identifying to the server the managed buffer selected by the client for the message, receiving the message at the server, passing information in the message from the server mechanism to the remote device via the selected managed buffer, receiving result information at the server from the remote device, sending a reply message corresponding to the result information to the client, receiving the reply message at the client, and completing the I/O request at the client by returning status information corresponding to the result information from the client mechanism.
-
71. A computer-readable medium having computer-executable instructions for performing a method, comprising:
-
allocating a plurality of managed buffers at a server for exclusive use by a client and the server;
receiving an I/O request at a client mechanism;
communicating a message corresponding to the I/O request to a server mechanism, the client managing the buffers at the server including designating a managed buffer for buffering data in the message, the server buffering at least some of the data in the message in the managed buffer designated by the client; and
passing information in the message from the server mechanism to a device driver associated with a remote device of the server.
-
-
72. A computer-readable medium having computer-executable instructions for performing a method, comprising, allocating a plurality of managed buffers at a server, the buffers managed by a client for exclusive use by the client and server, receiving an I/O request at a client mechanism, selecting at the client one of the managed buffers on the server, sending a message corresponding to the I/O request to the server, the message associated with information identifying to the server the managed buffer selected by the client for the message, receiving the message at the server, passing information in the message from the server mechanism to a remote device of the server via the selected managed buffer, receiving result information at the server from the remote device, sending a reply message corresponding to the result information to the client, receiving the reply message at the client, and completing the I/O request at the client by returning status information corresponding to the result information from the client mechanism.
Specification