[services] kill container on stop in warm/fast mode (#10510)
- Why I did it To optimize stop on warm boot. - How I did it Added kill for containers
This commit is contained in:
parent
c243af0cce
commit
e662008f72
@ -594,6 +594,17 @@ stop() {
|
|||||||
{%- endif %}
|
{%- endif %}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
kill() {
|
||||||
|
{%- if docker_container_name == "database" %}
|
||||||
|
docker kill $DOCKERNAME
|
||||||
|
if [ "$DEV" ]; then
|
||||||
|
ip netns delete "$NET_NS"
|
||||||
|
fi
|
||||||
|
{%- else %}
|
||||||
|
/usr/local/bin/container kill $DOCKERNAME
|
||||||
|
{%- endif %}
|
||||||
|
}
|
||||||
|
|
||||||
DOCKERNAME={{docker_container_name}}
|
DOCKERNAME={{docker_container_name}}
|
||||||
OP=$1
|
OP=$1
|
||||||
DEV=$2 # namespace/device number to operate on
|
DEV=$2 # namespace/device number to operate on
|
||||||
@ -621,7 +632,7 @@ fi
|
|||||||
[ -f /etc/sonic/sonic-environment ] && . /etc/sonic/sonic-environment
|
[ -f /etc/sonic/sonic-environment ] && . /etc/sonic/sonic-environment
|
||||||
|
|
||||||
case "$1" in
|
case "$1" in
|
||||||
start|wait|stop)
|
start|wait|stop|kill)
|
||||||
$1
|
$1
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
|
@ -8,6 +8,6 @@ Before=ntp-config.service
|
|||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
User={{ sonicadmin_user }}
|
User={{ sonicadmin_user }}
|
||||||
ExecStartPre=/usr/bin/{{docker_container_name}}.sh start
|
ExecStartPre=/usr/local/bin/{{docker_container_name}}.sh start
|
||||||
ExecStart=/usr/bin/{{docker_container_name}}.sh wait
|
ExecStart=/usr/local/bin/{{docker_container_name}}.sh wait
|
||||||
ExecStop=/usr/bin/{{docker_container_name}}.sh stop
|
ExecStop=/usr/local/bin/{{docker_container_name}}.sh stop
|
||||||
|
@ -14,9 +14,9 @@ StartLimitBurst=3
|
|||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
User=root
|
User=root
|
||||||
ExecStartPre=/usr/bin/{{docker_container_name}}.sh start{% if multi_instance == 'true' %} %i{% endif %}
|
ExecStartPre=/usr/local/bin/{{docker_container_name}}.sh start{% if multi_instance == 'true' %} %i{% endif %}
|
||||||
ExecStart=/usr/bin/{{docker_container_name}}.sh wait{% if multi_instance == 'true' %} %i{% endif %}
|
ExecStart=/usr/local/bin/{{docker_container_name}}.sh wait{% if multi_instance == 'true' %} %i{% endif %}
|
||||||
ExecStop=/usr/bin/{{docker_container_name}}.sh stop{% if multi_instance == 'true' %} %i{% endif %}
|
ExecStop=/usr/local/bin/{{docker_container_name}}.sh stop{% if multi_instance == 'true' %} %i{% endif %}
|
||||||
RestartSec=30
|
RestartSec=30
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
|
@ -10,7 +10,7 @@ StartLimitIntervalSec=1200
|
|||||||
StartLimitBurst=3
|
StartLimitBurst=3
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
ExecStartPre=/usr/bin/{{docker_container_name}}.sh start
|
ExecStartPre=/usr/local/bin/{{docker_container_name}}.sh start
|
||||||
ExecStart=/usr/bin/{{docker_container_name}}.sh wait
|
ExecStart=/usr/local/bin/{{docker_container_name}}.sh wait
|
||||||
ExecStop=/usr/bin/{{docker_container_name}}.sh stop
|
ExecStop=/usr/local/bin/{{docker_container_name}}.sh stop
|
||||||
RestartSec=30
|
RestartSec=30
|
||||||
|
@ -853,6 +853,10 @@ sudo LANG=C cp $SCRIPTS_DIR/bgp.sh $FILESYSTEM_ROOT/usr/local/bin/bgp.sh
|
|||||||
sudo LANG=C cp $SCRIPTS_DIR/teamd.sh $FILESYSTEM_ROOT/usr/local/bin/teamd.sh
|
sudo LANG=C cp $SCRIPTS_DIR/teamd.sh $FILESYSTEM_ROOT/usr/local/bin/teamd.sh
|
||||||
sudo LANG=C cp $SCRIPTS_DIR/lldp.sh $FILESYSTEM_ROOT/usr/local/bin/lldp.sh
|
sudo LANG=C cp $SCRIPTS_DIR/lldp.sh $FILESYSTEM_ROOT/usr/local/bin/lldp.sh
|
||||||
sudo LANG=C cp $SCRIPTS_DIR/radv.sh $FILESYSTEM_ROOT/usr/local/bin/radv.sh
|
sudo LANG=C cp $SCRIPTS_DIR/radv.sh $FILESYSTEM_ROOT/usr/local/bin/radv.sh
|
||||||
|
sudo LANG=C cp $SCRIPTS_DIR/database.sh $FILESYSTEM_ROOT/usr/local/bin/database.sh
|
||||||
|
sudo LANG=C cp $SCRIPTS_DIR/snmp.sh $FILESYSTEM_ROOT/usr/local/bin/snmp.sh
|
||||||
|
sudo LANG=C cp $SCRIPTS_DIR/telemetry.sh $FILESYSTEM_ROOT/usr/local/bin/telemetry.sh
|
||||||
|
sudo LANG=C cp $SCRIPTS_DIR/mgmt-framework.sh $FILESYSTEM_ROOT/usr/local/bin/mgmt-framework.sh
|
||||||
sudo LANG=C cp $SCRIPTS_DIR/asic_status.sh $FILESYSTEM_ROOT/usr/local/bin/asic_status.sh
|
sudo LANG=C cp $SCRIPTS_DIR/asic_status.sh $FILESYSTEM_ROOT/usr/local/bin/asic_status.sh
|
||||||
sudo LANG=C cp $SCRIPTS_DIR/asic_status.py $FILESYSTEM_ROOT/usr/local/bin/asic_status.py
|
sudo LANG=C cp $SCRIPTS_DIR/asic_status.py $FILESYSTEM_ROOT/usr/local/bin/asic_status.py
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ StartLimitBurst=3
|
|||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
User={{ sonicadmin_user }}
|
User={{ sonicadmin_user }}
|
||||||
ExecStartPre=/usr/bin/{{docker_container_name}}.sh start
|
ExecStartPre=/usr/local/bin/{{docker_container_name}}.sh start
|
||||||
ExecStart=/usr/bin/{{docker_container_name}}.sh wait
|
ExecStart=/usr/local/bin/{{docker_container_name}}.sh wait
|
||||||
ExecStop=/usr/bin/{{docker_container_name}}.sh stop
|
ExecStop=/usr/local/bin/{{docker_container_name}}.sh stop
|
||||||
RestartSec=30
|
RestartSec=30
|
||||||
|
1
files/scripts/database.sh
Symbolic link
1
files/scripts/database.sh
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
service_mgmt.sh
|
1
files/scripts/mgmt-framework.sh
Symbolic link
1
files/scripts/mgmt-framework.sh
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
service_mgmt.sh
|
@ -1,84 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
function debug()
|
|
||||||
{
|
|
||||||
/usr/bin/logger $1
|
|
||||||
/bin/echo `date` "- $1" >> ${DEBUGLOG}
|
|
||||||
}
|
|
||||||
|
|
||||||
function check_warm_boot()
|
|
||||||
{
|
|
||||||
SYSTEM_WARM_START=`$SONIC_DB_CLI STATE_DB hget "WARM_RESTART_ENABLE_TABLE|system" enable`
|
|
||||||
SERVICE_WARM_START=`$SONIC_DB_CLI STATE_DB hget "WARM_RESTART_ENABLE_TABLE|${SERVICE}" enable`
|
|
||||||
if [[ x"$SYSTEM_WARM_START" == x"true" ]] || [[ x"$SERVICE_WARM_START" == x"true" ]]; then
|
|
||||||
WARM_BOOT="true"
|
|
||||||
else
|
|
||||||
WARM_BOOT="false"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
function check_fast_boot ()
|
|
||||||
{
|
|
||||||
if [[ $($SONIC_DB_CLI STATE_DB GET "FAST_REBOOT|system") == "1" ]]; then
|
|
||||||
FAST_BOOT="true"
|
|
||||||
else
|
|
||||||
FAST_BOOT="false"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
start() {
|
|
||||||
debug "Starting ${SERVICE}$DEV service..."
|
|
||||||
|
|
||||||
check_warm_boot
|
|
||||||
check_fast_boot
|
|
||||||
debug "Warm boot flag: ${SERVICE}$DEV ${WARM_BOOT}."
|
|
||||||
debug "Fast boot flag: ${SERVICE}$DEV ${FAST_BOOT}."
|
|
||||||
|
|
||||||
# start service docker
|
|
||||||
/usr/bin/${SERVICE}.sh start $DEV
|
|
||||||
debug "Started ${SERVICE}$DEV service..."
|
|
||||||
}
|
|
||||||
|
|
||||||
wait() {
|
|
||||||
/usr/bin/${SERVICE}.sh wait $DEV
|
|
||||||
}
|
|
||||||
|
|
||||||
stop() {
|
|
||||||
debug "Stopping ${SERVICE}$DEV service..."
|
|
||||||
|
|
||||||
check_warm_boot
|
|
||||||
check_fast_boot
|
|
||||||
debug "Warm boot flag: ${SERVICE}$DEV ${WARM_BOOT}."
|
|
||||||
debug "Fast boot flag: ${SERVICE}$DEV ${FAST_BOOT}."
|
|
||||||
|
|
||||||
# For WARM/FAST boot do not perform service stop
|
|
||||||
if [[ x"$WARM_BOOT" != x"true" ]] && [[ x"$FAST_BOOT" != x"true" ]]; then
|
|
||||||
/usr/bin/${SERVICE}.sh stop $DEV
|
|
||||||
debug "Stopped ${SERVICE}$DEV service..."
|
|
||||||
else
|
|
||||||
debug "Killing Docker radv..."
|
|
||||||
/usr/bin/docker kill radv &> /dev/null || debug "Docker radv is not running ($?) ..."
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
DEV=$2
|
|
||||||
|
|
||||||
SERVICE="radv"
|
|
||||||
DEBUGLOG="/tmp/radv-debug$DEV.log"
|
|
||||||
NAMESPACE_PREFIX="asic"
|
|
||||||
if [ "$DEV" ]; then
|
|
||||||
NET_NS="$NAMESPACE_PREFIX$DEV" #name of the network namespace
|
|
||||||
SONIC_DB_CLI="sonic-db-cli -n $NET_NS"
|
|
||||||
else
|
|
||||||
SONIC_DB_CLI="sonic-db-cli"
|
|
||||||
fi
|
|
||||||
|
|
||||||
case "$1" in
|
|
||||||
start|wait|stop)
|
|
||||||
$1
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Usage: $0 {start|wait|stop}"
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
1
files/scripts/radv.sh
Symbolic link
1
files/scripts/radv.sh
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
service_mgmt.sh
|
80
files/scripts/service_mgmt.sh
Executable file
80
files/scripts/service_mgmt.sh
Executable file
@ -0,0 +1,80 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
function debug()
|
||||||
|
{
|
||||||
|
/usr/bin/logger $1
|
||||||
|
/bin/echo `date` "- $1" >> ${DEBUGLOG}
|
||||||
|
}
|
||||||
|
|
||||||
|
function check_warm_boot()
|
||||||
|
{
|
||||||
|
SYSTEM_WARM_START=`$SONIC_DB_CLI STATE_DB hget "WARM_RESTART_ENABLE_TABLE|system" enable`
|
||||||
|
SERVICE_WARM_START=`$SONIC_DB_CLI STATE_DB hget "WARM_RESTART_ENABLE_TABLE|${SERVICE}" enable`
|
||||||
|
if [[ x"$SYSTEM_WARM_START" == x"true" ]] || [[ x"$SERVICE_WARM_START" == x"true" ]]; then
|
||||||
|
WARM_BOOT="true"
|
||||||
|
else
|
||||||
|
WARM_BOOT="false"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function check_fast_boot ()
|
||||||
|
{
|
||||||
|
if [[ $($SONIC_DB_CLI STATE_DB GET "FAST_REBOOT|system") == "1" ]]; then
|
||||||
|
FAST_BOOT="true"
|
||||||
|
else
|
||||||
|
FAST_BOOT="false"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
start() {
|
||||||
|
debug "Starting ${SERVICE}$DEV service..."
|
||||||
|
|
||||||
|
# start service docker
|
||||||
|
/usr/bin/${SERVICE}.sh start $DEV
|
||||||
|
debug "Started ${SERVICE}$DEV service..."
|
||||||
|
}
|
||||||
|
|
||||||
|
wait() {
|
||||||
|
/usr/bin/${SERVICE}.sh wait $DEV
|
||||||
|
}
|
||||||
|
|
||||||
|
stop() {
|
||||||
|
debug "Stopping ${SERVICE}$DEV service..."
|
||||||
|
|
||||||
|
check_warm_boot
|
||||||
|
check_fast_boot
|
||||||
|
debug "Warm boot flag: ${SERVICE}$DEV ${WARM_BOOT}."
|
||||||
|
debug "Fast boot flag: ${SERVICE}$DEV ${FAST_BOOT}."
|
||||||
|
|
||||||
|
# For WARM/FAST boot do not perform service stop
|
||||||
|
if [[ x"$WARM_BOOT" != x"true" ]] && [[ x"$FAST_BOOT" != x"true" ]]; then
|
||||||
|
/usr/bin/${SERVICE}.sh stop $DEV
|
||||||
|
debug "Stopped ${SERVICE}$DEV service..."
|
||||||
|
else
|
||||||
|
debug "Killing Docker ${SERVICE}${DEV}..."
|
||||||
|
/usr/bin/${SERVICE}.sh kill $DEV
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
DEV=$2
|
||||||
|
|
||||||
|
SCRIPT_NAME=$(basename -- "$0")
|
||||||
|
SERVICE="${SCRIPT_NAME%.*}"
|
||||||
|
DEBUGLOG="/tmp/$SERVICE-debug$DEV.log"
|
||||||
|
NAMESPACE_PREFIX="asic"
|
||||||
|
if [ "$DEV" ]; then
|
||||||
|
NET_NS="$NAMESPACE_PREFIX$DEV" #name of the network namespace
|
||||||
|
SONIC_DB_CLI="sonic-db-cli -n $NET_NS"
|
||||||
|
else
|
||||||
|
SONIC_DB_CLI="sonic-db-cli"
|
||||||
|
fi
|
||||||
|
|
||||||
|
case "$1" in
|
||||||
|
start|wait|stop)
|
||||||
|
$1
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Usage: $0 {start|wait|stop}"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
1
files/scripts/snmp.sh
Symbolic link
1
files/scripts/snmp.sh
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
service_mgmt.sh
|
1
files/scripts/telemetry.sh
Symbolic link
1
files/scripts/telemetry.sh
Symbolic link
@ -0,0 +1 @@
|
|||||||
|
service_mgmt.sh
|
Loading…
Reference in New Issue
Block a user