Re: question about RPC

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Fri, 22 May 2015 at 07:20 Jeffry Killen <jekillen@xxxxxxxxxxx> wrote:

> This may be a bit off topic but I begin with understanding of
> php and doing synchronous and async queries generated by
> javascript  on the client side.
>
> Recently I resurrected a home built server and installed FreeBSD.
> Since I have been doing probably as much javascript as php, I have
> been interested in exploring node.js.
>
> My question is academic
>
> How is a simple query from a client like Firefox to an http server using
> php to process the request different from RPC?
> (I have been looking at Wikipedia article on RPC:
> http://en.wikipedia.org/wiki/Remote_procedure_call)
>
> I have written call back functions that are invoke from a window opened
> in javascript that call functions in the opening window. And as well,
> calling
> a server side script generally involves calling functions and methods
> and
> sending a result back to the client.
>
> For instance, there may be a form that is used to compose and execute a
> query of the server's data base server (MySQL, Postgres, etc) and the
> result is assembled and sent back to the client for display.
>
> How is this different from formal RPC?
>
> Now there is Apache Thrift with bindings to node.js (and other
> languages),
> which seems to imply that php can hand off requests to a node.js server,
> that might in turn satisfy a client request. (node.js is server side
> javascript)
>
> Right now I wouldn't do anything outside of localhost with node.js
> because
> it looks like asking for a whole lot of trouble if used over public
> network.
>
> Are there any academic thoughts on this?
>

 Generally speaking, RPC (as a concept) is simply "making a request to a
remote server and receiving the results." The term originated with
distributed systems with technologies such as CORBA. Essentially RPC
describes the format of the request before it hits the transport mechanism
(HTTP, 0MQ, TCP, whatever), and there are several different standards.
XMLRPC is another technology that does RPC defined using XML over HTTP:
http://en.wikipedia.org/wiki/XML-RPC.

The main distinguishing feature of an RPC against simply using, for
example, a REST service is that the client does not necessarily know that
it's calling a remote procedure. That fact is hidden by a class or library
that wraps the remote call in a local function.

Doing RPC over public networks is acceptable so long as you use SSL to
protect the data and authentication to prevent unauthorised access. This is
generally not a bad idea even within a private network, because there
really is no such thing as a private network!

I hope that helps expand on what RPC is and why it's different from
submitting a form on a web page.

-Stuart

-- 
Stuart Dallas
3ft9 Ltd
http://3ft9.com/

[Index of Archives]     [PHP Home]     [Apache Users]     [PHP on Windows]     [Kernel Newbies]     [PHP Install]     [PHP Classes]     [Pear]     [Postgresql]     [Postgresql PHP]     [PHP on Windows]     [PHP Database Programming]     [PHP SOAP]

  Powered by Linux