Analysing RPC and Testing the Performance of Solutions

Sandor Kiraly, Szilveszter Szekely

Abstract


In distributed computing, network sockets provide mechanism for a process to establish a remote connection to another process and send messages back and forth. This interface makes possible a proper mechanism that allows a program running as a process on computer A to call a procedure or a function on remote computer B and pass parameters to it. In the case of synchronous Remote Procedure Call (RPC), processes on computer A need to wait for the finishing of execution of procedures on computer B. When the called procedure finishes, produces its result and passes it to the process on computer A that can continue execution. The question is what happens between the time of the remote procedure call and arrival of the returned values and how much the caller must wait for result. To answer that question, this paper describes the structure of third generation RPCs and analyses them putting the focus on performance and the way of marshalling parameters. To facilitate the choice between them this paper represents the results of performance tests carried out by the authors

Full Text:

PDF

References


Andrew D. Birrell and Bruce Jay Nelson (1984). Implementing Remote Procedure Calls. ACM Transactions on Computer Systems, Vol. 2, No. 1, February 1984, Pages 39-59

Andrew S. Tanenbaum, Robbert van Renesse (1988). A Critique of the Remote Procedure Call Paradigm.

Available at

http://www.cs.vu.nl/~ast/Publications/Papers/euteco-1988.pdf

Andrew S. Tanenbaum, Maarten van Steen (2016). Distributed Systems: Principles and Paradigms. Pearson Education Inc. ISBN:978-15-302817-5-6

Andrew D. Birrell (1985). Secure Communication Using Remote Procedure Calls. ACM Transactions on Computer Systems, Vol. 3, No. 1, February 1985, Pages

-14

Paul Krzyzanowski (2012). Remote Procedure Calls Available at https://www.cs.rutgers.edu/~pxk/417/notes/08-rpc.html

Michael D. Schroeder and Michael Burrows1 (2006). Performance of Firefly RPC. http://web.mit.edu/6.826/www/notes/HO11.pdf

Hakan Bagci and Ahmet Kara (2016). A Lightweight and High Performance Remote Procedure Call Framework for Cross Platform Communication. ICSOFT-EA 2016 Abstracts. Available at:

http://www.scitepress.org/DigitalLibrary/PublicationsDetail.aspx?ID=Rqt07DUDIy8=&t=1

What is gRPC? Available at http://www.grpc.io/docs/guides/

Protocol Buffers. Available at https://developers.google.com/protocol-buffers/docs/overview#whynotxml

XML-RPC for C and C++. Available at http://xmlrpc-c.sourceforge.net/

Apache XML-RPC. Available at https://ws.apache.org/xmlrpc/

XML-RPC for Ruby. Available at https://github.com/ruby/xmlrpc

JSON-RPC 2.0. Essential Java libraries and tools for JSON-RPC 2.0development. Available at http://software.dzhuvinov.com/json-rpc-2.0.html

JSON-RPC 2.0. Available at http://software.dzhuvinov.com/json-rpc-2.0-client.html

JSON-RPC 2.0. for Ruby. Available at https://github.com/chriskite/jimson




DOI: https://doi.org/10.31449/inf.v42i4.1510

Creative Commons License
This work is licensed under a Creative Commons Attribution 3.0 License.