ham_action_fail_log()

Поместить сообщение в журнал активности HAM

Прототип:

#include <ha/ham.h>
int ham_action_fail_log( ham_action_t *ahdl,
const char *aname,
const char *msg,
unsigned attachprefix,
int verbosity,
unsigned flags );

Аргументы:

ahdl
Дескриптор действия HAM. Может быть получен из:
aname
Действие HAM.
msg
Сообщение, которое будет помещено в поток журнала активности.
attachprefix
Префикс для добавления к сообщению. Префикс не будет добавлен, если attachprefix равен нулю.
verbosity
Уровень подробности вывода действия, которое будет сравниваться с уровнем подробности вывода HAM. Помещаемое сообщение будет сгенерировано в том случае, если уровень подробности вывода HAM больше или равен значению, указанному в verbosity.
flags
Связанное условие, которое в случае сбоя приведет к выполнению действия.

Библиотека:

libham

Описание:

Функция ham_action_fail_log() используется для помещения сообщений в поток журнала действий, который поддерживает HAM. Это действие выполняется при сбое соответствующего действия, с которым оно связано.

Помещаемое сообщение указывается в msg и будет генерироваться, если verbosity HAM больше или равно значению, указанному в verbosity. Кроме того, если attachprefix не равен нулю, к сообщению журнала будет добавлен префикс, содержащий текущий объект/условие/действие, к которому относится данное сообщение.

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

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)