Addressing
Service Address
A Service address consists of two parts, assigned by the developer
- A Service Type number – typically hard-coded
- A Service Instance number – often calculated by user in run time
data:image/s3,"s3://crabby-images/eba54/eba54a867497cdc587e854187d933ebc9b29e347" alt=""
data:image/s3,"s3://crabby-images/4d165/4d165b48abd38cb35ca3ba396a8c905189f05800" alt=""
A service address is always qualified by a scope indicator
- Indicating lookup scope on the calling side node == 0 indicates cluster global lookup
- Indicating visibility scope on the binding side There are dedicated values for node local or cluster global visibility
node != 0 indicates that lookup should be performed only on that node
Service Address Binding
There are almost no restrictions on how to bind service addresses
- Different service addresses can be bound to same socket
- Same service address can be bound to different sockets
- Service address ranges can be bound to a socket
- Only one service address per socket in message bus mode
- This address type is also used for sending datagram and
communication group multicast
data:image/s3,"s3://crabby-images/4df16/4df16e9c177c7fb6cc49cb324b78a3b24bd09010" alt=""
data:image/s3,"s3://crabby-images/c7e1e/c7e1e944520b701c1dadc2001b644299c1f17810" alt=""
Location Transparency
A client doesn't need to know the location of the server
- Translation from service address to socket address is performed on-the-fly at the source node.
- There is a replica of the global binding table on each node for performing this translation.
- A sender can still indicate an explicit socket address when that is more practical,. e.g., when just responding to an incoming message.
data:image/s3,"s3://crabby-images/27887/27887faa1eebdf4f639997a5e903fd7aee57e172" alt=""
data:image/s3,"s3://crabby-images/f6cef/f6cefc65444a916a8337baf227b83bac84dad6ff" alt=""