Automating AMPS with Actions

AMPS provides the ability to run scheduled tasks or respond to events, such as Linux signals, using the Actions interface.

To create an action, you add an Actions section to the AMPS configuration file. Each Action contains one (or more) On statement which specifies when the action occurs, and one (or more) Do statement which specifies what the AMPS server does for the action. Within an action, AMPS performs each Do statement in the order in which they appear in the file.

AMPS actions may require the use of parameters. AMPS allows you to use variables in the parameters of an action. You can access these variables using the following syntax:

{{VARIABLE_NAME}}

AMPS defines a set of default variables when running an action. The event, or a previous action, can add variables in the context of the action. Those variables can be expanded in subsequent parameters. If a variable is used that isn't defined at the point where it is used, AMPS will expand that variable to an empty string literal. The context can also be updated as the module is running, so any variables that are available at any given point in the file depend on what action was previously executed.

By default, AMPS loads the following variables when it initializes an AMPS action:

Variable
Description

AMPS_INSTANCE_NAME

The name of the AMPS instance.

AMPS_BYTE_XX

Insert byte XX, where XX is a 2-digit uppercase hex number (00-FF). AMPS expands this variable to the corresponding byte value.

These variables are useful for creating field separators or producing characters that are not permitted within XML.

AMPS_DATETIME

The current date and time in ISO-8601 format.

AMPS_UNIX_TIMESTAMP

The current date and time as a UNIX timestamp.

An example to echo a message when AMPS starts up is shown below. Note the AMPS_INSTANCE_NAME is one of the variables that AMPS pushes to the context when an action is loaded.

<Actions>
    <Action>
        <On>
            <Module>amps-action-on-startup</Module>
        </On>
        <Do>
            <Module>amps-action-do-echo-message</Module>
            <Options>
                <Message>instance={{AMPS_INSTANCE_NAME}}</Message>
            </Options>
        </Do>
    </Action>
</Actions>

AMPS actions are implemented as AMPS modules. To run each statement, AMPS simply calls the module that implements that Do statement. The module is free to take any necessary actions. If a Do statement returns a failure, AMPS does not run subsequent Do statements in that action. This is intended to help make maintenance processes reliable. For example, if a Do statement that is intended to copy a log file to a storage directory fails because the device that holds the storage directory is not mounted, further steps in the action -- which might do things like remove the log file from the original directory -- should not be run. Likewise, if AMPS exits unexpectedly during a given Do statement, subsequent statements will not be run.

AMPS provides the following modules by default:

On: Choosing When an Action Runs

The following table lists the On actions that are provided in AMPS by default. Details for each action are provided in the section describing that action.

Condition
Modules

amps-action-on-schedule

amps-action-on-startup amps-action-on-shutdown

amps-action-on-signal

amps-action-on-admin

amps-action-on-minidump

amps-action-on-connect-client amps-action-on-disconnect-client

amps-action-on-logon-client

amps-action-on-offline-start amps-action-on-offline-stop

amps-action-on-subscribe amps-action-on-unsubscribe

amps-action-on-connect-incoming-replication amps-action-on-disconnect-incoming-replication

amps-action-on-connect-replication amps-action-on-disconnect-replication amps-action-on-replication-resync-complete amps-action-on-upgrade-replication amps-action-on-downgrade-replication

amps-action-on-publish-message

amps-action-on-deliver-message

amps-action-on-message-affinity

amps-action-on-sow-expire-message

amps-action-on-sow-delete-message

amps-action-on-oof-message

amps-action-on-message-condition-timeout

amps-action-on-alert

amps-action-on-execute-event

Do: Choosing What an Action Does

The following table lists the Do actions that are provided in AMPS by default. Details for each action are provided in the section describing that action.

Action
Module

amps-action-do-rotate-logs

amps-action-do-compress-files

amps-action-do-truncate-statistics

amps-action-do-archive-journal amps-action-do-compress-journal amps-action-do-remove-journal

amps-action-do-remove-files

amps-action-do-delete-sow

amps-action-do-compact-sow

amps-action-do-query-sow

amps-action-do-disable-authentication amps-action-do-enable-authentication amps-action-do-reset-authentication amps-action-do-reset-entitlement

amps-action-do-disable-entitlement amps-action-do-enable-entitlement

amps-action-do-enable-transport amps-action-do-disable-transport

amps-action-do-publish-message

amps-action-do-downgrade-replication amps-action-do-upgrade-replication

amps-action-do-extract-values

amps-action-do-translate-data

amps-action-do-increment-counter

amps-action-do-execute-event

amps-action-do-execute-system

amps-action-do-enable-proxied-transfer amps-action-do-disable-proxied-transfer

amps-action-do-minidump

amps-action-do-shutdown

amps-action-do-nothing amps-action-do-echo-message

Conditionally Stop an Action

The following table lists the If actions that are provided in AMPS by default. Details for each action are provided in the section describing that action.

Condition
Module

amps-action-if-file-system-usage

Examples

See the configuration section of the AMPS documentation for examples of action configuration.

Last updated

Copyright 2013-2024 60East Technologies, Inc.