data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
Component
of remote procedure call: user, user-stud, communication package, server-stub,
server |
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
Procedure
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
user
places normal local call |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
user-stub
does binding and makes packets with procedure call and arguments |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
communication
package transfers the packets reliably |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
server-stub
unpacks the packets and call server as a local call |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
server-stub
packs the result of local call |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
communication
package transfers the result packet |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
user-stub
unpacks the packet and pass the result to user |
|
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
All
communication is done in blocking mode |
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
Absolutely
the same semantics of local call: if user and server are brought to a
single machine and bound together, they will work! |
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
Distributed
programming in RPC
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
write
interfaces, like *.h file |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
write
the server which implements those interfaces |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
write
the client which calls those interfaces |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
pass
the interfaces to Lupine, which then generates user-stub and
server-stub |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
=>
No network programming at all! |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
However
the programmer needs to pass information needed for binding and be
prepared to handle machine or communication error |
|
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
This
system uses Grapevine distributed database |
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
Both
of type and instance are represented by RNames of the same registry, i.e.
entries in the single logical database
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
Type:
group entry whose members are RNames of instance of the type |
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
Instance:
individual entry which represents a host which exports the interface |
|
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
Export
& Import
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
server
calls Export(type, name) -> server-stub calls
ExportInterface(type, instance, ...)
data:image/s3,"s3://crabby-images/f02d4/f02d4ba196836f6c89e34c181939cce761586de7" alt="" |
->
update the database: add the instance as a member of type
RName |
data:image/s3,"s3://crabby-images/f02d4/f02d4ba196836f6c89e34c181939cce761586de7" alt="" |
->
stash information about export, including a unique id, into a
table inside server-stub |
|
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
client
calls Import(type, name) -> user-stub calls
ImportInterface(type, instance, ...)
data:image/s3,"s3://crabby-images/f02d4/f02d4ba196836f6c89e34c181939cce761586de7" alt="" |
->
do database query to get ip-address of the exporter
data:image/s3,"s3://crabby-images/f02d4/f02d4ba196836f6c89e34c181939cce761586de7" alt="" |
Contact
any registry server and get a registry server for RPC
registry |
data:image/s3,"s3://crabby-images/f02d4/f02d4ba196836f6c89e34c181939cce761586de7" alt="" |
Get
the member (= the exporter) of the type RName from the
RPC registry |
|
data:image/s3,"s3://crabby-images/f02d4/f02d4ba196836f6c89e34c181939cce761586de7" alt="" |
->
contact the exporter -> exporter replies with the
unique id and table index |
data:image/s3,"s3://crabby-images/f02d4/f02d4ba196836f6c89e34c181939cce761586de7" alt="" |
->
ip-addr, id, table index are stashed in user-stub |
|
|
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
->
After binding, all RPC packets from caller to callee have these
information |
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
->
Server-stub uses the table index to check the id and call the appropriate
function |
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
Binding
to any server
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
client
calls Import(type) -> user-stub gets all member of the type
from the database -> tries in turn in the order of ... |
|
data:image/s3,"s3://crabby-images/f5368/f5368e24452efa6a338dd1712656c88d24b85ae1" alt="" |
Binding
without using Grapevine
data:image/s3,"s3://crabby-images/8ac59/8ac59f752ad1237c51e30a2beceaed9c1e973c58" alt="" |
client
calls Import(type, ip-addr) -> user-stub contacts server-stub
directly using the ip-addr |
|