Analysing RPC and Testing the Performance of Solutions

Authors

  • Sandor Kiraly Eszterhazy Karoly University
  • Szilveszter Szekely Imperial College London

DOI:

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

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

Author Biography

Sandor Kiraly, Eszterhazy Karoly University

Institute of Mathematics and Informatics

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

Downloads

Published

2018-09-24

How to Cite

Kiraly, S., & Szekely, S. (2018). Analysing RPC and Testing the Performance of Solutions. Informatica, 42(4). https://doi.org/10.31449/inf.v42i4.1510

Issue

Section

Regular papers