 |
Index for Section 4 |
|
 |
Alphabetical listing for C |
|
 |
Bottom of page |
|
clua_services(4)
NAME
clua_services - Defines sockets, protocols, and connection attributes for
Internet services that use cluster aliases
SYNOPSIS
/etc/clua_services
DESCRIPTION
The cluster alias subsystem provides a mechanism to associate a network
address with a cluster alias (a hostname) without associating the address
with a physical network interface. Client systems can invoke a network
service on one or cluster nodes without explicit regard to which nodes are
up or which nodes are running the service.
Note
Each cluster has a default cluster alias, the name of the
cluster, which is assigned a network address when the cluster is
created. Other aliases are created as needed using the cluamgr
command.
Many applications running in a cluster can operate without knowledge that
they are in a cluster, and still be reached at a cluster alias address.
Other applications will benefit from being made cluster aware. A cluster
aware application might need to bind explicitly to a cluster alias address:
for example, to send a reply using the same network address over which it
received a request (using the library routines clua_getaliasaddress() or
clua_getdefaultalias()).
Applications that bind to dynamic network ports and use the port mapper to
enable clients to find them can use the clusvc_getcommport() or
clusvc_getresvcommport() functions to permit multiple copies of the
application to run on different cluster nodes using the same dynamic
network port.
The /etc/clua_services file is a static configuration file in which you
register services that use well-known ports for connections through a
cluster alias address. When registering a service, you also specify
attributes that govern the service's behavior under the alias. A service is
treated as one that:
· Runs on one member at a time (in_single).
Note that there could be several member running the service in the
cluster; however, the alias subsystem will deliver requests or
messages only to one member.
· Runs on multiple members simultaneously (in_multi).
· Rejects messages addressed to a cluster alias (in_noalias).
· Rejects messages addressed to a specific member of the cluster
(in_nolocal).
· Uses the default cluster alias IP address as its source address
(out_alias).
· Registers its port so that the port cannot be assigned as a dynamic
port (static).
By default, the /etc/clua_services file contains a subset of the services
defined in the /etc/services file. You can add user-defined services to
/etc/clua_services. If you modify the clua_services file, run cluamgr-f on
each cluster member in order for the modifications to take effect.
The entry for a service consists of a single line of the following form:
ServiceName PortNumber/ProtocolName Options
Fields are separated by spaces or tabs. Comments begin with a # (number
sign) and continue to the end of the line.
The fields contain the following information:
ServiceName
The official Internet service name.
PortNumber/ProtocolName
The socket port number used for the service and the transport
protocol used for the service. These are the same numbers and
names used in /etc/services.
Options A comma-separated list of cluster alias options.
The following list describes the available Options:
in_multi Indicates a service that can run concurrently on two or more
cluster members.
For TCP, the cluster alias software distributes connection
requests from clients using a round-robin algorithm. Each
connection is bound to a single alias member, but different
connections to the service from the same client might be
established on different alias members.
For UDP, the cluster alias software distributes messages using a
round-robin algorithm. Each packet might go to a different alias
member.
See cluamgr(8) for information on parameters that affect the
round-robin algorithm.
You must register a multiple-instance service, either in the
/etc/clua_services file or by calling the clua_registerservice()
function.
in_single Indicates a service that can run on only one cluster member at a
time, but can fail over to another instance of the service on
another member when the active service goes away. (Active, in
this context, relates only to messages addressed to the cluster
alias. All instances of a service are always active for their
node's local IP address(es) unless the in_nolocal attribute is
set.) As each service binds to the single-instance port, the
first is flagged as active for the alias, and the others flagged
as inactive. If the active service fails, one of the inactive
daemons is marked as active.
in_single is the default alias attribute for TCP ports. This
means that if a service is not explicitly listed in
/etc/clua_services as an in_multi service, the cluster alias
subsystem will treat the service as an in_single service.
in_noalias
Indicates a port that will not receive inbound alias messages.
out_alias When a connection is made to a port flagged as out_alias, the
default cluster alias address is used as the source address
whenever this port is used as a destination. Normally, outbound
connections (or UDP messages) use the local IP address of the
cluster member on which the client is running. (Note that
cluster-aware applications can bind explicitly to any cluster
alias address.)
It is important to remember that out_alias applies only when a
TCP connection or an outbound UDP send originates from the
cluster; that is, the cluster is the client. If a process running
on a cluster member initiates an outbound connection, and the
destination port (the port representing that half of the
connection that is not in the cluster) is flagged in the
cluster's /etc/clua_services file as out_alias, the connection
will use the default alias as its source address.
The same logic holds true when the outbound traffic is a UDP
send, because each send can be viewed as a micro-connection.
Consider the following example. An application running on a
member A in cluster B connects to a service on non-cluster node C
using port xxx. If port xxx is in /etc/clua_services with the
out_alias attribute set, the connection to node C comes from node
B (the default cluster alias). Otherwise, the connection to node
C comes from node A (the cluster member).
It is often beneficial to use the cluster alias address as the
source address for outbound traffic from the cluster (for
example, to simplify authorization). For example, the default
/etc/clua_services file assigns out_alias to the login service.
Therefore, if you decide to modify a /.rhosts file on a client to
allow non-password-protected logins and remote shells from the
cluster, use the default cluster alias as the host name, not the
host name of an individual cluster member.
The out_alias attribute has no bearing whatsoever on the port
associated with the cluster half of a connection. Assume that you
have more than one alias: the default cluster alias (deli) and
one that addresses a subset of cluster members (another-alias).
A client outside the cluster connects via TCP to a service port
using the IP address of another-alias. All return traffic within
the context of that connection will use the IP address of
another-alias as the source address. (Otherwise, there would be
no connection because a connection is uniquely identified by its
source address/port and its destination address/port. If a client
initiates a connection using another-alias as the address, the
cluster must respond using another-alias as the address.)
The following example shows the use of out_alias as a way to
apply single-system semantics to X applications displayed from
cluster members.
In /etc/clua_services, the out_alias attribute is set for the X
server port (6000). A user on a system outside the cluster wants
to run an X application on a cluster member and display back to
his or her system. Because the out_alias attribute is set on port
6000 in the cluster, the user must specify the name of the
default cluster alias when running the xhost command to allow X
clients access to his or her local system. For example, for a
cluster named deli, the user would run the following command on
the local system:
$ xhost +deli
This use of out_alias allows any X application from any cluster
member to display on that user's system. A cluster administrator
who wants users to allow access on a per-member basis could
either comment out the Xserver line in /etc/clua_services, or
remove the out_alias attribute from that line (and then run
cluamgr -f on each cluster member to make the change take
effect.)
in_nolocal
Indicates that the port will not honor connection requests to
non-alias addresses. For TCP, the port will not accept
connections; for UDP, the port will drop messages.
static Indicates that the port cannot be assigned as a dynamic port. The
port cannot be globally locked (dedicated to a single node) by
the cluster alias subsystem.
Dynamic (ephemeral) ports are automatically handed out by the
system in response to wildcard bind requests. Extending the
range of ephemeral ports beyond port 5000 to accommodate more
concurrent outbound connections results in overlaying the port
address space that was previously reserved for user well-known
ports. (The upper limit of the user range is determined by the
value of the sysconfigtab attribute ipport_userreserved.)
An application using a well-known port in this extended range
runs the risk of having that port assigned as an ephemeral port
before the application has a chance to bind to it (especially if
the service does not start when the system boots). To avoid this,
mark the port as a static port to make sure that it will never be
dynamically assigned a port number.
The same principle holds for the well-known reserved (privileged)
ports between 512-1024. An application is using a well-know
reserved port marked static should start at boot time, for
example through a mechanism like inetd.conf. Otherwise, an
application trawling for a reserved port might get the port even
though it is marked static. (There is no way to differentiate
between an application that is searching for a reserved port and
one that knows which well-known port it wants.)
Specifying a port as static also prevents a port from being
globally locked (dedicated to a single node) by the cluster alias
subsystem. This lets unmodified applications binding to a well-
known port run on several nodes in the cluster. Note that unless
in_multi is also set, the first application run will always be
selected by the round-robin algorithm.
Administrators should keep entries marked static synchronized
with the actual applications running on the system. If not
running an application whose port is marked static, comment out
that port entry in clua_services. Conversely, make sure that
static port entries for running applications are uncommented.
The in_multi, in_single, and in_noalias options are mutually exclusive.
The in_nolocal and in_noalias options are mutually exclusive.
Note
Applications can use the clua_registerservice() function as an
alternative to adding an entry to the clua_services file.
The strings used in the /etc/clua_services file have a 1:1 mapping to the
CLUASRV_* flags used by clua_registerservice(). Some of these strings/flags
also have a relationship with the cluster alias setsockopt() options. The
following table shows these relationships.
______________________________________________________________
clua_services clua_registerservice() setsockopt()
______________________________________________________________
in_multi CLUASRV_MULTI
in_single CLUASRV_SINGLE
in_noalias CLUASRV_IN_NOALIAS SO_CLUA_IN_NOALIAS
out_alias CLUASRV_OUT* SO_CLUA_DEFAULT_SRC**
in_nolocal CLUASRV_IN_NOLOCAL SO_CLUA_IN_NOLOCAL
static CLUASRV_STATIC
SO_REUSEALIASPORT
______________________________________________________________
* The CLUASRV_OUT flag forces the default cluster alias as the source
address only if the destination port for the service has the out_alias
attribute set in the clua_services file.
** The SO_CLUA_DEFAULT_SRC option does not check the attributes associated
with the destination port. (Note that neither CLUASRV_OUT nor
SO_CLUA_DEFAULT_SRC will override the manual setting of an address. These
two options set the source address to the default cluster alias only if the
address is not yet set.)
EXAMPLES
The following example shows sample entries in the clua_services file. The
login, who, and Xserver entries are explained after the example.
echo 7/tcp in_multi
echo 7/udp in_multi
discard 9/tcp in_multi
discard 9/udp in_multi
daytime 13/tcp in_multi
daytime 13/udp in_multi
netstat 15/tcp in_single
quote 17/udp in_multi
chargen 19/tcp in_multi
chargen 19/udp in_multi
ftp 21/tcp in_multi
telnet 23/tcp in_multi,out_alias
smtp 25/tcp in_multi
time 37/tcp in_multi
time 37/udp in_multi
.
.
.
login 513/tcp in_multi,out_alias,static
who 513/udp in_noalias,static
.
.
.
# Xserver is the X Windows server port. The following line lets a
# user on a workstation outside the cluster give display access to the
# default cluster alias using the xhost +<default_alias> command.
# Giving access to the cluster alias lets any cluster member display
# to that workstation. If you prefer that users authorize each
# cluster member individually with the xhost command, comment out the
# following line.
Xserver 6000/tcp out_alias,static # X Windows Server
Because the login service has the in_multi attribute set, the alias
subsystem will distribute login requests among members of the default
cluster alias. This means that if you log in to the cluster using the
cluster name rather than the host name of an individual member, the login
request will go to whichever cluster member is next on the alias
subsystem's list of eligible members.
The out_alias attribute ensures that login requests originating from a
cluster member will use the default cluster alias as the source address.
The static attribute means that port 513 will not be assigned as a dynamic
port. Note that both protocols using port 513 have the static attribute
set.
Because the who service has the in_noalias attribute set, the alias
subsystem will reject who requests made to a cluster alias. A who request
must be made directly to a member of the cluster.
Because the Xserver service has the out_alias attribute set, all X Window
applications displayed from the cluster will use the default cluster alias
as the source address. For example, you cannot treat xterm differently from
dxaccounts; setting out_alias for a service like an X server affects all
applications that use the service.
FILES
/etc/clua_services
Static configuration file where services using well-known ports
are registered for cluster alias connections.
SEE ALSO
Commands: cluamgr(8), clua_active(8), aliasd(8)
Functions: clua_error(3), clua_getaliasaddress(3), clua_getaliasinfo(3),
clua_getdefaultalias(3), clua_isalias(3), clua_registerservice(3),
clusvc_getcommport(3)
Files: clu_alias.config(4), exports.aliases(4)
 |
Index for Section 4 |
|
 |
Alphabetical listing for C |
|
 |
Top of page |
|