-
Notifications
You must be signed in to change notification settings - Fork 1.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Warm reboot: restore the database docker with content saved #2216
Changes from 6 commits
ace9553
fa331f9
504d691
2ed1ebe
f6c7a64
33a1c9b
40788df
0030740
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,19 +2,55 @@ | |
|
||
function getMountPoint() | ||
{ | ||
echo $1 | python -c "import sys, json, os; mnts = [x for x in json.load(sys.stdin)[0]['Mounts'] if x['Destination'] == '/usr/share/sonic/hwsku']; print '' if len(mnts) == 0 else os.path.basename(mnts[0]['Source'])" 2>/dev/null | ||
echo $1 | python -c "import sys, json, os; mnts = [x for x in json.load(sys.stdin)[0]['Mounts'] if x['Destination'] == '/usr/share/sonic/hwsku']; print '' if len(mnts) == 0 else os.path.basename(mnts[0]['Source'])" 2>/dev/null | ||
} | ||
|
||
function getRebootType() | ||
{ | ||
local TYPE | ||
case "$(cat /proc/cmdline)" in | ||
*SONIC_BOOT_TYPE=fast*) | ||
TYPE='fast' | ||
;; | ||
*SONIC_BOOT_TYPE=warm*) | ||
TYPE='warm' | ||
;; | ||
*) | ||
TYPE="normal" | ||
esac | ||
echo $TYPE | ||
} | ||
|
||
function postStartAction() | ||
{ | ||
REBOOT_TYPE=`getRebootType` | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. BOOT_TYPE #Resolved |
||
{%- if docker_container_name == "database" %} | ||
until [[ $(/usr/bin/docker exec database redis-cli ping | grep -c PONG) -gt 0 ]]; do | ||
sleep 1; | ||
done | ||
WARM_DIR=/host/warmboot | ||
SUDO=sudo -n | ||
if [[ "$REBOOT_TYPE" == "warm" && -d $WARM_DIR ]]; then | ||
function redisLoadAndDelete() | ||
{ | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This function needs to also take database ID as a parameter #Resolved |
||
DB="$1" | ||
FILENAME="$2" | ||
test -e $FILENAME || { echo "No file $FILENAME" >&2; exit 10; } | ||
$SUDO redis-load -s /var/run/redis/redis.sock -d $DB -e EMPTY $FILENAME || { echo "Failed to redis-load $FILENAME" >&2; exit 11; } | ||
$SUDO rm $FILENAME || exit 12 | ||
} | ||
# Load applDB from /host/warm-reboot/appl_db.json | ||
redisLoadAndDelete $WARM_DIR/appl_db.json | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. where is the DB argument? #Resolved |
||
# Load configDB from /host/warm-reboot/config_db.json | ||
redisLoadAndDelete $WARM_DIR/config_db.json | ||
# Load stateDB from /host/warm-reboot/state_db.json | ||
redisLoadAndDelete $WARM_DIR/state_db.json | ||
# Load asicDB from /host/warm-reboot/asic_db.json | ||
redisLoadAndDelete $WARM_DIR/asic_db.json | ||
fi | ||
{%- elif docker_container_name == "swss" %} | ||
docker exec swss rm -f /ready # remove cruft | ||
if [[ -d /host/fast-reboot ]]; | ||
then | ||
if [[ "$REBOOT_TYPE" == "fast" && -d /host/fast-reboot ]]; then | ||
test -e /host/fast-reboot/fdb.json && docker cp /host/fast-reboot/fdb.json swss:/ | ||
test -e /host/fast-reboot/arp.json && docker cp /host/fast-reboot/arp.json swss:/ | ||
test -e /host/fast-reboot/default_routes.json && docker cp /host/fast-reboot/default_routes.json swss:/ | ||
|
@@ -58,7 +94,7 @@ start() { | |
echo "Starting existing {{docker_container_name}} container with HWSKU $HWSKU" | ||
docker start {{docker_container_name}} | ||
postStartAction | ||
exit 0 | ||
exit $? | ||
fi | ||
|
||
# docker created with a different HWSKU, remove and recreate | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
getBootType #Resolved