Admin over SMA

This page covers configuration for Admin over SMA (Simple Messaging API), which allows monitoring and management of containers over messaging.

Admin Over SMA Configuration

circle-info

Since 3.10

Admin over SMA allows administrative applications to monitor and manage containers over messaging. When enabled, containers emit heartbeat, trace, and lifecycle events over defined messaging channels for consumption by listening clients.

Basic Configuration

At a high level, enabling Admin over SMA requires setting the following properties:

nv.discovery.descriptor=<discovery-provider>
nv.server.admin.transports=sma
nv.server.admin.bus.descriptor=<bus-connection-descriptor>

As long as both the admin client and the container use the same discovery descriptor and message bus, they will be able to communicate with one another.

circle-exclamation

Discovery Configuration

Admin clients should not attempt to issue commands until a container has been discovered via the discovery provider. When an admin client detects that a container is no longer discoverable, it should stop issuing commands over SMA.

See Discovery Configuration for details on configuring discovery.

Configuring Admin Clients

Administrative tools such as the rumi admin must be configured to enable SMA as a transport along with the admin bus connection information. Since admin clients won't always be configured via DDL, configuration is done via system/environment properties.

Properties-Based Configuration with Bus Descriptor:

Properties-Based Configuration with Decomposed Properties:

Alternatively, it is possible to configure the bus descriptor in decomposed form, which can be useful when configuration properties are overridden across environments:

Configuring Containers

Containers can be configured using the same environment properties as clients by setting the properties in the DDL environment section:

Advanced Container Bus Configuration

Using environment-based configuration is the simplest way of configuring Admin over SMA for a container. In cases where bus configuration is not being injected by deployment tools, it is possible to use the <container> <admin> element in DDL to enable admin over SMA and reference a DDL-defined bus definition.

Container Admin over SMA Configuration:

To configure a container to use a bus named 'container-admin', the container's <admin> <sma> element can be used:

Admin Bus Configuration:

The following bus definition can then be configured for use by the container:

Admin channels (container-request, container-response, container-heartbeat, container-event, and container-trace) should not be configured for the bus; they are automatically created by the container when it is started.

With the above configuration, the order-processing-1 container will create a connection to solace://solhost:55555 with a username of order-processing-1. It will use the following topics:

Subscribe:

  • container-request channel: container-admin/order-processing-1/request

Publish:

  • container-response channel: container-admin/${adminClientId}/response (where the adminClientId is substituted with that of the sending client when a response is sent)

  • container-heartbeats channel: container-admin/order-processing-1/heartbeat (when heartbeats are enabled)

  • container-trace channel: container-admin/order-processing-1/trace (when trace emission is enabled)

  • container-event channel: container-admin/order-processing-1/event

circle-info

Tip: Enabling container heartbeats isn't strictly necessary, but in most monitoring scenarios it is desirable.

Channel Prefix Configuration

By default, all admin channels start with the container-admin channel prefix. This prefix can be changed by setting the environment property nv.admin.sma.channelKeyPrefix, which can be useful for cases where it is desirable to more granularly partition admin traffic.

Passive Monitoring Configuration

It is possible to use Admin over SMA in a purely passive monitoring capacity by setting the property:

With the above configuration setting, clients will throw an exception if an attempt is made to send commands to a container, and containers will not issue subscriptions on the container-request channel.

Next Steps

  1. Configure discovery provider for container and admin clients

  2. Set up message bus for admin channels

  3. Enable Admin over SMA in container configuration

  4. Configure admin tools to use SMA transport

  5. Test admin operations via messaging

Last updated