Skip to content

maximvl/rot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

##About

Rot is RPC over TCP client/server application which allowes transparent parallel synchronious and asynchronious requests between nodes. Each erlang node can start several Rot servers and connections to other nodes under different names.

Start server on node1:

(node1@t530)1> rot:start_server([{name, srv}]).
{ok,<0.230.0>}

Connect and call from node2:

(node2@t530)1> rot:connect(localhost, [{name, cl}]).
{ok,<0.153.0>}
(node2@t530)2> rot:connected().
[srv]
(node2@t530)3> rot:call(srv, {erlang, self, []}).
<12820.366.0>

After connect on node1:

(node1@t530)2> rot:connected().
[cl]
(node1@t530)3> rot:call(cl, {erlang, self, []}).
<12756.340.0>

##API

  • rot:start() - start rot app and dependencies
  • rot:stop() - start rot app
  • rot:connected() - list of connected nodes
  • rot:connected(Node) - number of connections to node
  • rot:start_server(Opts) - start rot server (see configuration options below)
  • rot:stop_server(Name) - stops server with name Name
  • rot:connect(Host, Opts, Connections) - connect to rot server (see configuration options below)
  • rot:connect(Host, Opts) - same as rot:connect(Host, Opts, 4)
  • rot:connect_link(Host, Opts, Connections) - connect to rot server, and link connection pool supervisor
  • rot:connect_child_spec(Host, Opts, Connections) - supervisor child spec for connection pool supervisor
  • rot:call(Node, {M, F, A}, Timeout) - sync call to node, timeout in ms
  • rot:call(Node, {M, F, A}) - same as rot:call(Node, M, F, A, 5000)
  • rot:cast(Node, {M, F, A}) - async cast to node

####Technologies used:

##Jails

Both server and client can set {jail, Module} option which restricts all requests to that module, ignoring module passed in requests:

(node1@t530)1> rot:start_server([{name, srv}, {jail, ets}]).
{ok,<0.115.0>}

node2:

(node2@t530)1> rot:connect(localhost, [{name, cl}]).
{ok,<0.118.0>}
(node2@t530)2> rot:call(srv, {erlang, memory, []}).
** exception error: undefined function ets:memory/0
     in function  rot_util:handle_call/5 (rot/src/rot_util.erl, line 45)
     in call from proc_lib:init_p/3 (proc_lib.erl, line 224)
(node2@t530)3> rot:call(srv, {erlang, module_info, []}).
[{exports,[{match_spec_run,2},
           {repair_continuation,2},
           {fun2ms,1},
           {foldl,3},
           {foldr,3},
           ...

##Configuration ###Server

  • ip, default: {0, 0, 0, 0}
  • port, default: 2222
  • name, deafult: node()
  • transport, default: tcp (ssl will be supported soon)
  • acceptors, default: 10
  • jail, default: undefined

###Client

  • port, default: 2222
  • name, default: node()
  • transport, default: tcp
  • jail, default: undefined

##Todo

###Jails:

  • different jails for different clients on server
  • default jail

###Nodes:

  • stop all servers and clients on application stop?
  • disconnect (server forces clients?)
  • nodes graph walking
  • finding shortest paths
  • paths caching, recovering broken paths

About

RPC over TCP

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages