ham_action_fail_execute()

Задать исполняемый файл, который будет выполнен, если указанное действие завершится с ошибкой

Прототип:

#include <ha/ham.h>
int ham_action_fail_execute( ham_action_t *ahdl,
const char *aname,
const char *path,
unsigned flags );

Аргументы:

ahdl
Дескриптор действия HAM. Может быть получен из:
aname
Действие HAM.
path
Параметр path должен содержать ПОЛНЫЙ путь path к исполняемому файлу вместе со всеми передаваемыми ему параметрами. Если либо имя пути, либо аргументы содержат пробелы, которые необходимо передать вызову spawn(), их необходимо заключить в кавычки. Когда подкомпоненты в аргументах path заключены в кавычки, используйте любой из следующих методов:
\'path with space\'
или
\"path with space\",
также допустимо:
"\'path with space\' arg1 arg2 \"arg3 with space\"".
Это будет рассматриваться как
"path with space" -> path
arg1 = arg1
arg2 = arg2
arg3 = "arg3 with space".
flags
Флаги.

Библиотека:

libham

Описание:

Функция ham_action_fail_execute() добавляет действие (aname), являющееся реакцией на ошибку указанного действия (в терминологии HAM). Действие исполнит внешнюю программу или команду, указываемую в path.

Командная строка, в свою очередь, передается HAM в команду spawn() для создания нового процесса, который будет выполнять данную команду.

Возвращаемое значение:

0
Успешное завершение.
-1
Возникла ошибка. Код ошибки записан в errno.

Коды ошибок:

EBADF
Не удалось подключиться к HAM.
EINVAL
Имя aname некорректно (например, содержит символ /) или имеет значение NULL. Не удалось подключиться к HAM. Это происходит, когда процесс, открывший соединение (используя ham_connect()), и процесс, вызывающий ham_action_execute(), не совпадают.
ENAMETOOLONG
Указанное имя (в aname) слишком длинное, т.е. оно превышает _POSIX_PATH_MAX (определено в <limits.h>). Обратите внимание, что общая длина имени объекта/условия/действия также ограничена _POSIX_PATH_MAX.
ENOENT
Отсутствует объект или условие с заданным дескриптором (chdl).
ENOMEM
Недостаточно памяти для создания нового дескриптора.

В дополнение к вышеуказанным ошибкам HAM возвращает любую ошибку, с которой он сталкивается при обслуживании данного запроса.

Классификация:

ЗОСРВ «Нейтрино»

Безопасность использования
Точка остановки потока
Нет
Обработчик прерываний
Нет
Обработчик сигналов
Нет
В потоке
Да

Тематические ссылки:

ham_action_execute(), ham_action_fail_execute(), ham_action_handle(), ham_action_handle_free(), ham_action_heartbeat_healthy(), ham_action_log(), ham_action_notify_pulse(), ham_action_notify_signal(), ham_action_remove(), ham_action_restart(), ham_action_waitfor(), ham_condition(), ham_condition_handle()




Предыдущий раздел: Менеджер высокой готовности (HAM)