Remote Invocation
Remote invocation represents the most common communication paradigm in distributed systems,
covering a range of techniques based on a two-way exchange between communicating entities in
a distributed system and resulting in the calling of a remote operation, procedure or method.
Remote invocation implies the following communication paradigm.
                      1)   Request Reply Protocol
                      2)   Remote Procedure Call
                      3)   Remote Method Invocation
   1) Request Reply Protocol
          It is designed to support the roles and message exchanges in client-server interactions.
          In the normal case, request-reply communication is synchronous because the client
           process blocks until the reply arrives from the server. It can also be reliable because
           the reply from the server is an acknowledgement to the client.
          In some situation, request-reply communication can also be asynchronous.
          It built with both UDP and TCP.
   It has three Communication Primitives:
   1. doOperation():
   public byte[] doOperation (RemoteRef s, int operationId, byte[] arguments)
      Sends a request message to the remote server and returns the reply.
      The arguments specify the remote server, the operation to be invoked and the arguments
       of that operation.
      doOperation marshals the arguments into an array of bytes and unmarshals the results
       from the array of bytes that is returned.
      class RemoteRef, which represents references for remote servers (IP address and Port
       number)
      The caller of doOperation is blocked until the server performs the requested operation
       and transmits a reply message to the client process.
   2. getRequest()
       public byte[] getRequest ();
      Acquires a client request via the server port.
      When the server has invoked the specified operation, it then uses sendReply to send the
       reply message to the client.
      When the reply message is received by the client the original doOperation is unblocked
       and execution of the client program continues.
   3. sendReply()
       public void sendReply (byte[] reply, InetAddress clientHost, int clientPort);
             Sends the reply message reply to the client at its Internet address and port.
Request-reply message structure
             The first field indicates whether the message is a Request or a Reply message.
             The second field, requestId, contains a message identifier.
             The third field is a remote reference.
             The fourth field is an identifier for the operation to be invoked.
Message identifiers
A message identifier consists of two parts:
               1. a requestId, which is taken from an increasing sequence of integers by the
               sending process;
               2. an identifier for the sender process, for example, its port and Internet address.
requestId reaches the maximum value for an unsigned integer (for example, 232 – 1) it is reset to
zero.
Failure model of the request-reply protocol
               • They suffer from omission failures.
               • Messages are not guaranteed to be delivered in sender order.
Timeouts
       The timeout may have been due to the request or reply message getting lost and the
        operation will have been performed.
       Solution: When doOperation returns, it will indicate to the client by an exception that no
        result was received.
Discarding duplicate request messages
       When the request message is retransmitted, the server may receive it more than once.
       Solution: To avoid this, the protocol is designed to recognize successive messages (from
        the same client) with the same request identifier and to filter out duplicates.
Lost reply messages
       An idempotent operation is an operation that can be performed repeatedly with the same
        effect as if it had been performed exactly once.
       A server whose operations are all idempotent need not take special measures to avoid
        executing its operations more than once.
History
       The term ‘history’ is used to refer to a structure that contains a record of (reply) messages
        that have been transmitted.
       An entry in a history contains a request identifier, a message and an identifier of the
        client to which it was sent.
Styles of exchange protocols
Use of TCP streams to implement the request-reply protocol
      The TCP protocol is chosen for request-reply protocols because it can simplify their
       implementation.
      If successive requests and replies between the same client-server pair are sent over the
       same stream, the connection overhead need not apply to every remote invocation. Also,
       the overhead due to TCP acknowledgement messages is reduced when a reply message
       follows soon after a request message.
HTTP: An example of a request-reply protocol
The HyperText Transfer Protocol (HTTP) used by web browser clients to make requests to web
servers and to receive replies from them.
HTTP is a protocol that specifies the messages involved in a request-reply exchange, the
methods, arguments and results, and the rules for representing (marshalling) them in the
messages.
It supports a fixed set of methods (GET, PUT, POST, etc) that are applicable to all of the server’s
resources.
                                     HTTP Request Message
      GET: Requests the resource whose URL is given as its argument. If the URL refers to
       data, then the web server replies by returning the data identified by that URL. If the URL
       refers to a program, then the web server runs the program and returns its output to the
       client.
   HEAD: This request is identical to GET, but it does not return any data. However, it does
    return all the information about the data, such as the time of last modification, its type or
    its size.
   POST: Specifies the URL of a resource (for example a program) that can deal with the
    data supplied in the body of the request
   PUT: Requests that the data supplied in the request is stored with the given URL as its
    identifier, either as a modification of an existing resource or as a new resource.
   DELETE: The server deletes the resource identified by the given URL. Servers may not
    always allow this operation, in which case the reply indicates failure.
   OPTIONS: The server supplies the client with a list of methods it allows to be applied to
    the given URL (for example GET, HEAD, PUT) and its special requirements.
   TRACE: The server sends back the request message. Used for diagnostic purposes.
                                      Remote Procedure Call
RPC and RMI are the mechanisms which enable a client to invoke the procedure or method from
the server through establishing communication between client and server. The common
difference between RPC and RMI is that RPC only supports procedural programming whereas
RMI supports object-oriented programming.
Remote Procedure Call (RPC) is a protocol that one program can use to request a service from a
program located in another computer on a network without having to understand the network's
details. A procedure call is also sometimes known as a function call or a subroutine call.
How RPC Works
A client has a request message that the RPC translates and sends to the server. This request may
be a procedure or a function call to a remote server. When the server receives the request, it
sends the required response back to the client. The client is blocked while the server is
processing the call and only resumed execution after the server is finished.
The sequence of events in a remote procedure call are given as follows:
      The client process calls the client stub with parameters, and its execution is suspended
       until the call is completed.
      The parameters are then translated into machine-independent form by marshalling
       through client stub. Then the message is prepared which contain the representation of the
       parameters.
      To find the identity of the site the client stub intercommunicate with name server at
       which remote procedure exists.
      Using blocking protocol the client stub sends the message to the site where remote
       procedure call exists. This step halt the client stub until it gets a reply.
      The server site receives the message sent from the client side and converts it into machine
       specific format.
      Now server stub executes a call on the server procedure along with the parameters, and
       the server stub is discontinued till the procedure gets completed.
      The server procedure returns the generated results to the server stub, and the results get
       converted into machine-independent format at server stub and create a message
       containing the results.
      The result message is sent to the client stub which is converted back into machine
       specific format suitable for the client stub.
      At last client, stub returns the results to the client process.
A diagram that demonstrates this is as follows:
Advantages of Remote Procedure Call
Some of the advantages of RPC are as follows:
      Remote procedure calls support process oriented and thread oriented models.
      The internal message passing mechanism of RPC is hidden from the user.
      The effort to re-write and re-develop the code is minimum in remote procedure calls.
      Remote procedure calls can be used in distributed environment as well as the local
       environment.
      Many of the protocol layers are omitted by RPC to improve performance.
Disadvantages of Remote Procedure Call
Some of the disadvantages of RPC are as follows:
      The remote procedure call is a concept that can be implemented in different ways. It is
       not a standard.
      There is no flexibility in RPC for hardware architecture. It is only interaction based.
      There is an increase in costs because of remote procedure call.
RPC call semantics
Types of delivery guarantees:
      Retry request message: Controls whether to retransmit the request message until either a
       reply is received or the server is assumed to have failed.
      Duplicate filtering: Controls when retransmissions are used and whether to filter out
       duplicate requests at the server.
      Retransmission of results: Controls whether to keep a history of result messages to enable
       lost results to be retransmitted without re-executing the operations at the server.
The choices of RPC invocation semantics are defined as follows.
      Maybe semantics: With maybe semantics, the remote procedure call may be executed
       once or not at all. Maybe semantics arises when no fault-tolerance measures are applied
       and can suffer from the following types of failure:
                     omission failures if the request or result message is lost;
                     crash failures when the server containing the remote operation fails.
      At-least-once semantics: With at-least-once semantics, the invoker receives either a
       result, in which case the invoker knows that the procedure was executed at least once, or
       an exception informing it that no result was received. At-least-once semantics can suffer
       from the following types of failure:
                     crash failures when the server containing the remote procedure fails;
                     arbitrary failures – in cases when the request message is retransmitted, the
                      remote server may receive it and execute the procedure more than once,
                      possibly causing wrong values to be stored or returned.
      At-most-once semantics: With at-most-once semantics, the caller receives either a
       result, in which case the caller knows that the procedure was executed exactly once, or an
       exception informing it that no result was received, in which case the procedure will have
       been executed either once or not at all.
                               Remote Method Invocation (RMI)
Remote Method Invocation (RMI) is similar to RPC but is language specific and a feature of
java. A thread is permitted to call the method on a remote object. To maintain the transparency
on the client and server side, it implements remote object using stubs and skeletons. The stub
resides with the client and for the remote object it behaves as a proxy.
When a client calls a remote method, the stub for the remote method is called. The client stub is
accountable for creating and sending the parcel containing the name of a method and the
marshalled parameters, and the skeleton is responsible for receiving the parcel.
The skeleton unmarshals parameters and invokes the desired method on the server. The skeleton
marshals the given value (or exceptions) with the parcel and sends it to client stub. The stub
reassembles the return parcel and sends it to the client.
In Java, the parameters are passed to methods and returned in the form of reference. This could
be troublesome for RMI service since not all objects are possibly remote methods. So, it must
determine which could be passed as reference and which could not.
Java uses process named as serialization where the objects are passed as value. The remote
object is localized by pass by value. It can also pass an object by reference through passing a
remote reference to the object along with the URL of the stub class. Pass by reference restricts a
stub for the remote object.
Difference between RPC and RMI
RPC and RMI are the mechanisms which enable a client to invoke the procedure or method from
the server through establishing communication between client and server. The common
difference between RPC and RMI is that RPC only supports procedural programming whereas
RMI supports object-oriented programming.
  BASIS FOR
                                    RPC                                      RMI
 COMPARISON
Supports               Procedural programming               Object-oriented programming
Parameters             Ordinary data structures are         Objects are passed to remote methods.
                       passed to remote procedures.
Efficiency             Lower than RMI                       More than RPC and supported by
                                                            modern programming approach (i.e.
                                                            Object-oriented paradigms)
  BASIS FOR
                              RPC                     RMI
 COMPARISON
Overheads              More         Less comparatively
In-out parameters      Yes          Not necessarily
are mandatory.
Provision of ease of   High         low
programming