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/ce142/ce1428bcc723fd2b6a49c11e606558bd86520af6" alt=""
data:image/s3,"s3://crabby-images/d9b40/d9b40a3b21b0c7e99470886cc3fcfb18c16e2f7f" 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/d6844/d6844fe941fd9cf6137eb3e622cad097e9bb9ef5" alt=""
data:image/s3,"s3://crabby-images/16b13/16b134a8d2c9be898c8c4126b8e3a136f4f2639b" 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/b8f74/b8f7449128a6b0108d2b9da56fa3588d39aec2cb" alt=""
data:image/s3,"s3://crabby-images/3c60e/3c60e061ccf464332a06578777dd10077f900255" alt=""