Revert "systemd: Always create the systemd unit files"
This reverts commit 15b0a5f1eb849a30bcea9a1e437e9a88ae2c6f92. The change had an assumption that a service is properly configured even when it isn't enabled. The assumption is not true. Change-Id: Ib5a8ffe63eaec15bc29bfdd133db7169507bab82 Closes-Bug: #1698129
This commit is contained in:
parent
15b0a5f1eb
commit
c087c71834
@ -1508,13 +1508,8 @@ EOF
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
# Defines a systemd service which can be enabled and started later on.
|
# Helper function to build a basic unit file and run it under systemd.
|
||||||
# arg1: The openstack service name ('n-cpu', 'c-sch', ...).
|
function _run_under_systemd {
|
||||||
# arg2: The command to start (e.g. path to service binary + config files).
|
|
||||||
# arg3: The group which owns the process.
|
|
||||||
# arg4: The user which owns the process.
|
|
||||||
# Returns: The systemd service name which got defined.
|
|
||||||
function _define_systemd_service {
|
|
||||||
local service=$1
|
local service=$1
|
||||||
local command="$2"
|
local command="$2"
|
||||||
local cmd=$command
|
local cmd=$command
|
||||||
@ -1529,7 +1524,9 @@ function _define_systemd_service {
|
|||||||
else
|
else
|
||||||
write_user_unit_file $systemd_service "$cmd" "$group" "$user"
|
write_user_unit_file $systemd_service "$cmd" "$group" "$user"
|
||||||
fi
|
fi
|
||||||
echo $systemd_service
|
|
||||||
|
$SYSTEMCTL enable $systemd_service
|
||||||
|
$SYSTEMCTL start $systemd_service
|
||||||
}
|
}
|
||||||
|
|
||||||
# Helper to remove the ``*.failure`` files under ``$SERVICE_DIR/$SCREEN_NAME``.
|
# Helper to remove the ``*.failure`` files under ``$SERVICE_DIR/$SCREEN_NAME``.
|
||||||
@ -1570,19 +1567,11 @@ function run_process {
|
|||||||
local user=$4
|
local user=$4
|
||||||
|
|
||||||
local name=$service
|
local name=$service
|
||||||
local systemd_service
|
|
||||||
|
|
||||||
time_start "run_process"
|
time_start "run_process"
|
||||||
# Note we deliberately make all service files, even if the service
|
|
||||||
# isn't enabled, so it can be enabled by a dev manually on command
|
|
||||||
# line.
|
|
||||||
if [[ "$USE_SYSTEMD" = "True" ]]; then
|
|
||||||
systemd_service=$(_define_systemd_service "$name" "$command" "$group" "$user")
|
|
||||||
fi
|
|
||||||
if is_service_enabled $service; then
|
if is_service_enabled $service; then
|
||||||
if [[ "$USE_SYSTEMD" = "True" ]]; then
|
if [[ "$USE_SYSTEMD" = "True" ]]; then
|
||||||
$SYSTEMCTL enable $systemd_service
|
_run_under_systemd "$name" "$command" "$group" "$user"
|
||||||
$SYSTEMCTL start $systemd_service
|
|
||||||
elif [[ "$USE_SCREEN" = "True" ]]; then
|
elif [[ "$USE_SCREEN" = "True" ]]; then
|
||||||
if [[ "$user" == "root" ]]; then
|
if [[ "$user" == "root" ]]; then
|
||||||
command="sudo $command"
|
command="sudo $command"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user