Revert "systemd: Always create the systemd unit files"

This reverts commit 15b0a5f1eb.

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:
YAMAMOTO Takashi 2017-06-15 12:10:45 +00:00 committed by Sean Dague
parent 15b0a5f1eb
commit c087c71834

View File

@ -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"