Docker containers logs cleanup

pull/6/head
Dominik Dzienia 7 months ago
parent 61adb44d39
commit c39a9cd1d1

@ -1,6 +1,6 @@
{ {
"name": "@dlvoy/ns-installer-mikrus", "name": "@dlvoy/ns-installer-mikrus",
"version": "1.9.0", "version": "1.9.1",
"description": "Nightscout installer for mikr.us VPS", "description": "Nightscout installer for mikr.us VPS",
"main": "index.js", "main": "index.js",
"scripts": { "scripts": {

@ -29,12 +29,12 @@ TOOL_FILE=/srv/nightscout/tools/nightscout-tool
TOOL_LINK=/usr/bin/nightscout-tool TOOL_LINK=/usr/bin/nightscout-tool
UPDATES_DIR=/srv/nightscout/updates UPDATES_DIR=/srv/nightscout/updates
UPDATE_CHANNEL=master UPDATE_CHANNEL=master
DISK_LOW_WARNING=838860800 # == 800 MiB DISK_LOW_WARNING=838860800 # == 800 MiB
DISK_LOW_MAIL=5184000 # == 60 days in seconds DISK_LOW_MAIL=5184000 # == 60 days in seconds
DISK_CRITICAL_WARNING=104857600 # == 100 MiB DISK_CRITICAL_WARNING=104857600 # == 100 MiB
DISK_CRITICAL_MAIL=604800 # == 7 days in seconds DISK_CRITICAL_MAIL=604800 # == 7 days in seconds
SCRIPT_VERSION="1.9.0" #auto-update SCRIPT_VERSION="1.9.1" #auto-update
SCRIPT_BUILD_TIME="2024.10.12" #auto-update SCRIPT_BUILD_TIME="2024.10.16" #auto-update
#======================================= #=======================================
# SETUP # SETUP
@ -149,6 +149,8 @@ uni_confirm_ed=" $(printf '\U1F4DD') Edytuj "
uni_install=" $(printf '\U1F680') Instaluj " uni_install=" $(printf '\U1F680') Instaluj "
uni_resign=" $(printf '\U1F6AB') Rezygnuję " uni_resign=" $(printf '\U1F6AB') Rezygnuję "
uni_send=" $(printf '\U1F4E7') Wyślij " uni_send=" $(printf '\U1F4E7') Wyślij "
uni_delete=" $(printf '\U1F5D1') Usuń "
uni_leave_logs=" $(printf '\U1F4DC') Zostaw "
uni_ns_ok="$(printf '\U1F7E2') działa" uni_ns_ok="$(printf '\U1F7E2') działa"
uni_watchdog_ok="$(printf '\U1F415') Nightscout działa" uni_watchdog_ok="$(printf '\U1F415') Nightscout działa"
@ -248,13 +250,13 @@ set_last_time() {
local actionName=$1 local actionName=$1
local actionFile="${DATA_ROOT_DIR}/last_${actionName}" local actionFile="${DATA_ROOT_DIR}/last_${actionName}"
local nowDate="$(date +'%s')" local nowDate="$(date +'%s')"
echo "$nowDate" > "$actionFile" echo "$nowDate" >"$actionFile"
} }
clear_last_time() { clear_last_time() {
local actionName=$1 local actionName=$1
local actionFile="${DATA_ROOT_DIR}/last_${actionName}" local actionFile="${DATA_ROOT_DIR}/last_${actionName}"
rm -f "$actionFile" rm -f "$actionFile"
} }
#======================================= #=======================================
@ -1605,6 +1607,32 @@ do_cleanup_db() {
msgcheck "Czyszczenie kopii zapasowych zakończono" msgcheck "Czyszczenie kopii zapasowych zakończono"
} }
do_cleanup_container_logs() {
ohai "Zatrzymywanie kontenerów..."
docker stop 'ns-server'
docker stop 'ns-database'
docker stop 'ns-backup'
ohai "Usuwanie logów kontenerów..."
truncate -s 0 "$(docker inspect --format='{{.LogPath}}' 'ns-server')"
truncate -s 0 "$(docker inspect --format='{{.LogPath}}' 'ns-database')"
truncate -s 0 "$(docker inspect --format='{{.LogPath}}' 'ns-backup')"
ohai "Ponowne uruchamianie kontenerów..."
docker start 'ns-server'
docker start 'ns-database'
docker start 'ns-backup'
msgok "Logi usunięte"
}
prompt_cleanup_container_logs() {
yesnodlg "Usunąć logi kontenerów?" "$uni_delete" "$uni_leave_logs" \
"Czy chcesz usunąć logi kontenerów nightscout i bazy?" \
"${TL}Jeśli Twój serwer działa poprawnie," \
"${NL}- możesz spokojnie usunąć logi." \
"${TL}Jeśli masz problem z serwerem - zostaw logi!" \
"${NL}- logi mogą być niezbędne do diagnostyki" \
"${TL}(ta operacja uruchomi ponownie kontenery)"
}
cleanup_menu() { cleanup_menu() {
while :; do while :; do
@ -1633,11 +1661,12 @@ cleanup_menu() {
local CHOICE=$(whiptail --title "Sprzątanie" --menu \ local CHOICE=$(whiptail --title "Sprzątanie" --menu \
"${statusTitle/=/%}" \ "${statusTitle/=/%}" \
16 50 5 \ 17 50 6 \
"A)" "Posprzątaj wszystko" \ "A)" "Posprzątaj wszystko" \
"S)" "Posprzątaj zasoby systemowe" \ "S)" "Posprzątaj zasoby systemowe" \
"D)" "Usuń nieużywane obrazy Dockera" \ "D)" "Usuń nieużywane obrazy Dockera" \
"B)" "Usuń kopie zapasowe bazy danych" \ "B)" "Usuń kopie zapasowe bazy danych" \
"L)" "Usuń logi kontenerów" \
"M)" "Powrót do menu" \ "M)" "Powrót do menu" \
--ok-button="Wybierz" --cancel-button="$uni_back" \ --ok-button="Wybierz" --cancel-button="$uni_back" \
3>&2 2>&1 1>&3) 3>&2 2>&1 1>&3)
@ -1652,9 +1681,17 @@ cleanup_menu() {
"${NL} ${uni_bullet}kopie zapasowe bazy danych")" \ "${NL} ${uni_bullet}kopie zapasowe bazy danych")" \
"${TL}(ta operacja może potrwać od kilku do kilkudziesięciu minut)" "${TL}(ta operacja może potrwać od kilku do kilkudziesięciu minut)"
if ! [ $? -eq 1 ]; then if ! [ $? -eq 1 ]; then
do_cleanup_sys prompt_cleanup_container_logs
do_cleanup_docker if ! [ $? -eq 1 ]; then
do_cleanup_db do_cleanup_container_logs
do_cleanup_sys
do_cleanup_docker
do_cleanup_db
else
do_cleanup_sys
do_cleanup_docker
do_cleanup_db
fi
fi fi
;; ;;
"S)") "S)")
@ -1681,6 +1718,12 @@ cleanup_menu() {
do_cleanup_db do_cleanup_db
fi fi
;; ;;
"L)")
prompt_cleanup_container_logs
if ! [ $? -eq 1 ]; then
do_cleanup_container_logs
fi
;;
"M)") "M)")
break break
;; ;;
@ -2124,74 +2167,74 @@ install_or_menu() {
free_space_check() { free_space_check() {
lastTimeSpaceInfo=$(get_space_info) lastTimeSpaceInfo=$(get_space_info)
local remainingB=$(echo "$lastTimeSpaceInfo" | awk '{print $3}') local remainingB=$(echo "$lastTimeSpaceInfo" | awk '{print $3}')
local remainingTxt=$(echo "$lastTimeSpaceInfo" | awk '{print $3}' | numfmt --to iec-i --suffix=B) local remainingTxt=$(echo "$lastTimeSpaceInfo" | awk '{print $3}' | numfmt --to iec-i --suffix=B)
if ((remainingB < DISK_LOW_WARNING)); then if ((remainingB < DISK_LOW_WARNING)); then
if ((remainingB < DISK_CRITICAL_WARNING)); then if ((remainingB < DISK_CRITICAL_WARNING)); then
local lastCalled=$(get_since_last_time "disk_critical") local lastCalled=$(get_since_last_time "disk_critical")
local domain=$(get_td_domain) local domain=$(get_td_domain)
if ((lastCalled == -1)) || ((lastCalled > DISK_CRITICAL_MAIL)); then if ((lastCalled == -1)) || ((lastCalled > DISK_CRITICAL_MAIL)); then
set_last_time "disk_critical" set_last_time "disk_critical"
{ {
echo "Na twoim serwerze mikr.us z Nightscoutem (https://$domain) zostało krytycznie mało miejsca (${remainingTxt})!" echo "Na twoim serwerze mikr.us z Nightscoutem (https://$domain) zostało krytycznie mało miejsca (${remainingTxt})!"
echo " " echo " "
echo "Tak mała ilość miejsca nie pozwala serwerowi na stabilne działanie!" echo "Tak mała ilość miejsca nie pozwala serwerowi na stabilne działanie!"
echo "🚨PILNIE🚨 posprzątaj na serwerze, aby to zrobić możesz:" echo "🚨PILNIE🚨 posprzątaj na serwerze, aby to zrobić możesz:"
echo " " echo " "
echo "1. Usunąć stare statusy i wpisy z poziomu strony Nightscout:" echo "1. Usunąć stare statusy i wpisy z poziomu strony Nightscout:"
echo " - wejdź do hamburger menu strony Nightscout i wybierz: 【 Narzędzia administratora 】- wymaga zalogowania" echo " - wejdź do hamburger menu strony Nightscout i wybierz: 【 Narzędzia administratora 】- wymaga zalogowania"
echo " to powinno otwórzyć adres: https://${domain}/admin" echo " to powinno otwórzyć adres: https://${domain}/admin"
echo " - w polach tekstowych poustawiaj ile dni historii chcesz zachować, i w odpowiednich sekcjach kliknij:" echo " - w polach tekstowych poustawiaj ile dni historii chcesz zachować, i w odpowiednich sekcjach kliknij:"
echo " 【 Usuń stare dokumenty 】" echo " 【 Usuń stare dokumenty 】"
echo " " echo " "
echo "2. Posprzątać nieużywane pliki na serwerze mikr.us:" echo "2. Posprzątać nieużywane pliki na serwerze mikr.us:"
echo " - zaloguj się na swój mikr.us do panelu administracyjnego, przejdź do WebSSH" echo " - zaloguj się na swój mikr.us do panelu administracyjnego, przejdź do WebSSH"
echo " https://mikr.us/panel/?a=webssh" echo " https://mikr.us/panel/?a=webssh"
echo " - zaloguj się, uruchom narzędzie komendą: nightscout-tool" echo " - zaloguj się, uruchom narzędzie komendą: nightscout-tool"
echo " - wybierz: 【 C) Sprztąj... 】" echo " - wybierz: 【 C) Sprztąj... 】"
echo " - wybierz: 【 A) Posprzątaj wszystko 】 i potwierdź 【 Tak 】" echo " - wybierz: 【 A) Posprzątaj wszystko 】 i potwierdź 【 Tak 】"
echo " - cierpliwie poczekaj, po sprzątaniu narzędzie pokaże ile miejsca zwolniono" echo " - cierpliwie poczekaj, po sprzątaniu narzędzie pokaże ile miejsca zwolniono"
} | pusher "🚨_Krytycznie_mało_miejsca_na_Twoim_serwerze_Nightscout!" } | pusher "🚨_Krytycznie_mało_miejsca_na_Twoim_serwerze_Nightscout!"
echo "Free space on server: CRITICALLY LOW (${remainingTxt}) - sending email to user" echo "Free space on server: CRITICALLY LOW (${remainingTxt}) - sending email to user"
else else
echo "Free space on server: CRITICALLY LOW (${remainingTxt}) - user already notified" echo "Free space on server: CRITICALLY LOW (${remainingTxt}) - user already notified"
fi fi
else else
local lastCalled=$(get_since_last_time "disk_warning") local lastCalled=$(get_since_last_time "disk_warning")
local domain=$(get_td_domain) local domain=$(get_td_domain)
if ((lastCalled == -1)) || ((lastCalled > DISK_LOW_MAIL)); then if ((lastCalled == -1)) || ((lastCalled > DISK_LOW_MAIL)); then
set_last_time "disk_warning" set_last_time "disk_warning"
{ {
echo "Na twoim serwerze mikr.us z Nightscout-em (https://$domain) powoli kończy się miejsce (${remainingTxt})!" echo "Na twoim serwerze mikr.us z Nightscout-em (https://$domain) powoli kończy się miejsce (${remainingTxt})!"
echo " " echo " "
echo "🧹 W wolnej chwili posprzątaj na serwerze, aby to zrobić możesz:" echo "🧹 W wolnej chwili posprzątaj na serwerze, aby to zrobić możesz:"
echo " " echo " "
echo "1. Usunąć stare statusy i wpisy z poziomu strony Nightscout:" echo "1. Usunąć stare statusy i wpisy z poziomu strony Nightscout:"
echo " - wejdź do hamburger menu strony Nightscout i wybierz:【 Narzędzia administratora 】- wymaga zalogowania" echo " - wejdź do hamburger menu strony Nightscout i wybierz:【 Narzędzia administratora 】- wymaga zalogowania"
echo " to powinno otwórzyć adres: https://${domain}/admin" echo " to powinno otwórzyć adres: https://${domain}/admin"
echo " - w polach tekstowych poustawiaj ile dni historii chcesz zachować, i w odpowiednich sekcjach kliknij:" echo " - w polach tekstowych poustawiaj ile dni historii chcesz zachować, i w odpowiednich sekcjach kliknij:"
echo " 【 Usuń stare dokumenty 】" echo " 【 Usuń stare dokumenty 】"
echo " " echo " "
echo "2. Posprzątać nieużywane pliki na serwerze mikr.us:" echo "2. Posprzątać nieużywane pliki na serwerze mikr.us:"
echo " - zaloguj się na swój mikr.us do panelu administracyjnego, przejdź do WebSSH" echo " - zaloguj się na swój mikr.us do panelu administracyjnego, przejdź do WebSSH"
echo " https://mikr.us/panel/?a=webssh" echo " https://mikr.us/panel/?a=webssh"
echo " - zaloguj się, uruchom narzędzie komendą: nightscout-tool" echo " - zaloguj się, uruchom narzędzie komendą: nightscout-tool"
echo " - wybierz: 【 C) Sprztąj... 】" echo " - wybierz: 【 C) Sprztąj... 】"
echo " - wybierz: 【 A) Posprzątaj wszystko 】 i potwierdź 【 Tak 】" echo " - wybierz: 【 A) Posprzątaj wszystko 】 i potwierdź 【 Tak 】"
echo " - cierpliwie poczekaj, po sprzątaniu narzędzie pokaże ile miejsca zwolniono" echo " - cierpliwie poczekaj, po sprzątaniu narzędzie pokaże ile miejsca zwolniono"
} | pusher "🧹_Powoli_kończy_sie_miejsce_na_Twoim_serwerze_Nightscout!" } | pusher "🧹_Powoli_kończy_sie_miejsce_na_Twoim_serwerze_Nightscout!"
echo "Free space on server: LOW (${remainingTxt}) - sending email to user" echo "Free space on server: LOW (${remainingTxt}) - sending email to user"
else else
echo "Free space on server: LOW (${remainingTxt}) - user already notified" echo "Free space on server: LOW (${remainingTxt}) - user already notified"
fi fi
fi fi
else else
clear_last_time "disk_critical" clear_last_time "disk_critical"
clear_last_time "disk_warning" clear_last_time "disk_warning"
echo "Free space on server: OK (${remainingTxt})" echo "Free space on server: OK (${remainingTxt})"
fi fi
} }
watchdog_check() { watchdog_check() {
@ -2221,7 +2264,7 @@ watchdog_check() {
WATCHDOG_LAST_STATUS="unknown" WATCHDOG_LAST_STATUS="unknown"
fi fi
free_space_check free_space_check
local NS_STATUS=$(get_container_status_code 'ns-server') local NS_STATUS=$(get_container_status_code 'ns-server')
local DB_STATUS=$(get_container_status_code 'ns-database') local DB_STATUS=$(get_container_status_code 'ns-database')

Loading…
Cancel
Save