Это очень похоже на то, что должно моделироваться с помощью ресурса Service
, а не Exec
.Для этого не требуется управление службой через обычную подсистему управления службами системы (initscripts, systemd, ...), хотя я, безусловно, рекомендую организовать это, даже если вам придется самостоятельно писать соответствующие сценарии или файлы конфигурации.,В этом случае, однако, скрипт hq-agent.sh
звучит так, как будто он имеет интерфейс, похожий, если не идентичный, традиционному initscript.Если это так, то, вероятно, было бы довольно легко настроить ее как обычный системный сервис.Если вы это сделаете, то управлять им будет так же просто, как
service { 'hq-agent':
ensure => 'running',
enable => true,
}
Но если вы просто хотите использовать ad hoc сценарии для управления службой, Puppet может это поддержать.В частности, ресурс Service
имеет атрибуты start
, restart
, status
и stop
, с помощью которых можно указать произвольные команды для управления службой.Например,
service { 'hq-agent':
ensure => 'running',
provider => 'service',
hasstatus => false,
hasrestart => false,
status => 'hq-agent.sh status',
start => 'hq-agent.sh start',
stop => 'hq-agent.sh stop',
path => '/path/to/hyperic/bin',
# no 'enable' attribute specified
}
Этот конкретный пример делает некоторые предположения о кодах выхода скрипта hq-agent.sh
, основываясь на его внешнем сходстве со стандартным initscript SysV.В частности, предполагается, что они соответствуют спецификациям LSB .Если на самом деле это не так, так что вам нужно протестировать вывод скрипта вместо его кодов выхода, тогда типичным подходом было бы перенаправить вывод в grep
.Например,
status => 'hq-agent.sh status | grep -q running'
Однако остерегайтесь того, что вам может потребоваться проверить стандартную ошибку сценария вместо его стандартного вывода.