notebookvb
This commit is contained in:
@@ -1,32 +1,53 @@
|
||||
#!/bin/bash
|
||||
# ==============================================================================
|
||||
# MongoDB Verify Backup Integrity — ověření konzistence po restore
|
||||
# ==============================================================================
|
||||
#
|
||||
# CO DĚLÁ:
|
||||
# Připojí se k MongoDB a pro každou databázi zkontroluje:
|
||||
# 1. Existence databáze
|
||||
# 2. Počet a seznam kolekcí
|
||||
# 3. Indexy na každé kolekci
|
||||
# 4. Statistiky (počet dokumentů, velikost)
|
||||
# 5. Pro admin DB: počet systémových uživatelů a rolí
|
||||
#
|
||||
# KDY POUŽÍT:
|
||||
# Po provedení mongodbrestore_from_backup.sh — ověří, že data jsou v pořádku.
|
||||
# Spouštět ručně, není součástí automatizovaného schedule.
|
||||
#
|
||||
# VÝSTUP:
|
||||
# ✅ / ❌ indikátory pro každý krok.
|
||||
# Skript vrátí exit code 1 pokud cokoliv selže.
|
||||
# ==============================================================================
|
||||
set -x
|
||||
|
||||
# ==========================================================
|
||||
# VERIFY BACKUP INTEGRITY
|
||||
# Kontroluje že se indexy, metadata, a všechny kolekce
|
||||
# správně obnovily
|
||||
# ==========================================================
|
||||
|
||||
# ==============================================================================
|
||||
# KONFIGURACE
|
||||
# ==============================================================================
|
||||
CONTAINER_NAME="MongoDB"
|
||||
MONGO_HOST="localhost"
|
||||
MONGO_PORT="27017"
|
||||
|
||||
# Databases to verify
|
||||
# Databáze ke kontrole — zahrnuje i MySQL databáze zrcadlené do MongoDB,
|
||||
# protože verify kontroluje aktuální stav MongoDB, ne zálohu.
|
||||
WHAT_TO_VERIFY=("admin" "fio" "torrents" "OrdinaceDropBoxBackup" "medevio" "kanboard" "medicus" "studie" "puzzle")
|
||||
|
||||
echo "Starting backup integrity verification..."
|
||||
echo "=========================================="
|
||||
|
||||
ALL_OK=true
|
||||
ALL_OK=true # flag — pokud jakákoliv kontrola selže, nastaví se na false
|
||||
|
||||
for DB_NAME in "${WHAT_TO_VERIFY[@]}"; do
|
||||
echo ""
|
||||
echo "Verifying database: $DB_NAME"
|
||||
echo "------------------------------------------"
|
||||
|
||||
# ======================================================
|
||||
# 1. CHECK IF DB EXISTS
|
||||
# ======================================================
|
||||
# --------------------------------------------------------------------------
|
||||
# 1. EXISTENCE DATABÁZE
|
||||
# adminCommand('listDatabases') vrátí seznam všech DB.
|
||||
# Filtrujeme podle jména — pokud filter nic nevrátí (length=0), DB neexistuje.
|
||||
# mongosh --quiet potlačí uvítací banner, --eval vykoná JS výraz.
|
||||
# --------------------------------------------------------------------------
|
||||
DB_EXISTS=$(docker exec "$CONTAINER_NAME" mongosh \
|
||||
--host="$MONGO_HOST" \
|
||||
--port="$MONGO_PORT" \
|
||||
@@ -36,13 +57,15 @@ for DB_NAME in "${WHAT_TO_VERIFY[@]}"; do
|
||||
if [ "$DB_EXISTS" != "true" ]; then
|
||||
echo "❌ ERROR: Database $DB_NAME does not exist!"
|
||||
ALL_OK=false
|
||||
continue
|
||||
continue # bez DB nemá smysl kontrolovat dál
|
||||
fi
|
||||
echo "✅ Database exists: $DB_NAME"
|
||||
|
||||
# ======================================================
|
||||
# 2. COUNT COLLECTIONS
|
||||
# ======================================================
|
||||
# --------------------------------------------------------------------------
|
||||
# 2. POČET KOLEKCÍ
|
||||
# getCollectionNames() vrátí pole názvů všech kolekcí v DB.
|
||||
# .length dá číslo — slouží jako rychlá sanity check (0 by bylo podezřelé).
|
||||
# --------------------------------------------------------------------------
|
||||
COLLECTION_COUNT=$(docker exec "$CONTAINER_NAME" mongosh \
|
||||
--host="$MONGO_HOST" \
|
||||
--port="$MONGO_PORT" \
|
||||
@@ -51,9 +74,10 @@ for DB_NAME in "${WHAT_TO_VERIFY[@]}"; do
|
||||
|
||||
echo "✅ Collections count: $COLLECTION_COUNT"
|
||||
|
||||
# ======================================================
|
||||
# 3. LIST ALL COLLECTIONS
|
||||
# ======================================================
|
||||
# --------------------------------------------------------------------------
|
||||
# 3. SEZNAM KOLEKCÍ
|
||||
# Vypíše název každé kolekce — pro vizuální kontrolu po restore.
|
||||
# --------------------------------------------------------------------------
|
||||
echo " Collections:"
|
||||
docker exec "$CONTAINER_NAME" mongosh \
|
||||
--host="$MONGO_HOST" \
|
||||
@@ -61,9 +85,11 @@ for DB_NAME in "${WHAT_TO_VERIFY[@]}"; do
|
||||
--quiet \
|
||||
--eval "use $DB_NAME; db.getCollectionNames().forEach(c => print(' - ' + c))"
|
||||
|
||||
# ======================================================
|
||||
# 4. CHECK INDEXES FOR EACH COLLECTION
|
||||
# ======================================================
|
||||
# --------------------------------------------------------------------------
|
||||
# 4. INDEXY NA KAŽDÉ KOLEKCI
|
||||
# getIndexes() vrátí pole index definic. Každý index má field "key" (JSON).
|
||||
# Výpis indexů ověří, že mongorestore správně obnovil i indexy (ne jen data).
|
||||
# --------------------------------------------------------------------------
|
||||
echo " Indexes per collection:"
|
||||
docker exec "$CONTAINER_NAME" mongosh \
|
||||
--host="$MONGO_HOST" \
|
||||
@@ -80,9 +106,12 @@ db.getCollectionNames().forEach(collName => {
|
||||
});
|
||||
"
|
||||
|
||||
# ======================================================
|
||||
# 5. CHECK COLLECTION STATS (document count, size)
|
||||
# ======================================================
|
||||
# --------------------------------------------------------------------------
|
||||
# 5. STATISTIKY KOLEKCÍ (počet dokumentů, velikost)
|
||||
# db[collName].stats() vrátí objekt se statistikami kolekce.
|
||||
# .count = počet dokumentů, .size = velikost v bytech → převádíme na MB.
|
||||
# Nulový count může signalizovat problém (záloha prázdné DB nebo selhání restore).
|
||||
# --------------------------------------------------------------------------
|
||||
echo " Collection stats:"
|
||||
docker exec "$CONTAINER_NAME" mongosh \
|
||||
--host="$MONGO_HOST" \
|
||||
@@ -98,9 +127,11 @@ db.getCollectionNames().forEach(collName => {
|
||||
});
|
||||
"
|
||||
|
||||
# ======================================================
|
||||
# 6. VERIFY USERS/ROLES (if admin DB)
|
||||
# ======================================================
|
||||
# --------------------------------------------------------------------------
|
||||
# 6. UŽIVATELÉ A ROLE (pouze admin DB)
|
||||
# admin DB obsahuje systémové uživatele a role — i bez auth jsou zálohovány.
|
||||
# Ověřujeme, že restore je správně obnovil.
|
||||
# --------------------------------------------------------------------------
|
||||
if [ "$DB_NAME" = "admin" ]; then
|
||||
echo " Users and Roles:"
|
||||
USER_COUNT=$(docker exec "$CONTAINER_NAME" mongosh \
|
||||
|
||||
Reference in New Issue
Block a user