אתם יכולים להגן על הנתונים ב-AlloyDB Omni באמצעות כל טכנולוגיית גיבוי של מסד נתונים שפועלת עם PostgreSQL. לדוגמה, אתם יכולים להגדיר את AlloyDB Omni כך שיאפשר חיבורים משרת Barman שאתם שולטים בו. הפעולה הזו מאפשרת לשרת Barman לבצע גיבויים רציפים של הנתונים שמאוחסנים בשרת AlloyDB Omni.
אחרי שמגדירים את השרתים של Barman ו-AlloyDB Omni כך שיפעלו יחד, אפשר להריץ פקודות Barman כדי לבצע מגוון משימות של הגנה על נתונים והתאוששות מאסון, כולל:
- יצירת גיבוי לפי דרישה של הנתונים.
- מגדירים סטרימינג סינכרוני של WAL של שינויי הנתונים לשרת הגיבוי.
- שחזור מגיבוי ספציפי.
- מבצעים שחזור מנקודה מסוימת בזמן.
מידע נוסף על הפעולה של Barman זמין במדריך של Barman.
לפני שמתחילים
לפני שמגדירים את AlloyDB Omni לעבודה עם Barman, צריך לוודא שיש לכם את הדברים הבאים:
AlloyDB Omni מותקן ופועל בשרת שבשליטתכם.
Barman מותקן בשרת נפרד. השרת שבו התקנתם את Barman צריך להיות מסוגל לתקשר עם שרת AlloyDB Omni באמצעות TCP.
הגדרת AlloyDB Omni לעבודה עם Barman
כדי להכין את שרת AlloyDB Omni לעבודה עם Barman, מריצים את הפקודות הבאות בשרת שבו התקנתם את AlloyDB Omni.
יוצרים את משתמש מסד הנתונים
barmanעם ההרשאות המתאימות:Docker
docker exec CONTAINER_NAME psql -h localhost -U postgres -c " CREATE USER barman; GRANT EXECUTE ON FUNCTION pg_backup_start(text, boolean) to barman; GRANT EXECUTE ON FUNCTION pg_backup_stop(boolean) to barman; GRANT EXECUTE ON FUNCTION pg_switch_wal() to barman; GRANT EXECUTE ON FUNCTION pg_create_restore_point(text) to barman; GRANT pg_read_all_settings TO barman; GRANT pg_read_all_stats TO barman; CREATE USER streaming_barman WITH REPLICATION; "מחליפים את
CONTAINER_NAMEבשם שהקציתם לקונטיינר של AlloyDB Omni כשהתקנתם אותו.Podman
podman exec CONTAINER_NAME psql -h localhost -U postgres -c " CREATE USER barman; GRANT EXECUTE ON FUNCTION pg_backup_start(text, boolean) to barman; GRANT EXECUTE ON FUNCTION pg_backup_stop(boolean) to barman; GRANT EXECUTE ON FUNCTION pg_switch_wal() to barman; GRANT EXECUTE ON FUNCTION pg_create_restore_point(text) to barman; GRANT pg_read_all_settings TO barman; GRANT pg_read_all_stats TO barman; CREATE USER streaming_barman WITH REPLICATION; "מחליפים את
CONTAINER_NAMEבשם שהקציתם לקונטיינר של AlloyDB Omni כשהתקנתם אותו.מוסיפים את השורות הבאות לקובץ
DATA_DIR/pg_hba.confלפני השורהhost all all all scram-sha-256שקיימת בקובץ:host all barman BARMAN_IP/32 AUTHN_METHOD host replication streaming_barman BARMAN_IP/32 AUTHN_METHODמחליפים את מה שכתוב בשדות הבאים:
DATA_DIR: הנתיב במערכת הקבצים שמשמש לספריית הנתונים של AlloyDB Omni.
BARMAN_IP: כתובת ה-IP של שרת Barman.
AUTHN_METHOD: שיטת האימות של PostgreSQL שהשרת שלכם ב-AlloyDB ל-PostgreSQL מצפה משרת Barman. מומלץ להשתמש באחד מהערכים הבאים:כדי לאפשר לשרת Barman לבצע אימות ללא סיסמה, משתמשים ב-
trust.כדי לדרוש סיסמה משרת Barman, משתמשים ב-
scram-sha-256.
מוסיפים את השורות הבאות לקובץ
DATA_DIR/postgresql.conf:archive_command='/bin/true' archive_mode=on listen_addresses='*' wal_level='replica'מפעילים מחדש את שירות AlloyDB Omni:
Docker
docker restart CONTAINER_NAMEPodman
podman restart CONTAINER_NAMEמחליפים את
CONTAINER_NAMEבשם שהקציתם לקונטיינר של AlloyDB Omni כשהתקנתם אותו.מריצים את הפקודה הבאה כדי לוודא שכל הפרמטרים הדרושים מוגדרים בצורה מתאימה:
Docker
docker exec CONTAINER_NAME psql -h localhost -U postgres -c " SELECT name, setting FROM pg_catalog.pg_settings WHERE name IN ('archive_command', 'archive_mode', 'listen_addresses', 'wal_level') ORDER BY name;"Podman
podman exec CONTAINER_NAME psql -h localhost -U postgres -c " SELECT name, setting FROM pg_catalog.pg_settings WHERE name IN ('archive_command', 'archive_mode', 'listen_addresses', 'wal_level') ORDER BY name;"הפלט אמור להיראות כך:
name | setting ------------------|----------- archive_command | /bin/true archive_mode | on listen_addresses | * wal_level | replica (4 rows)
הגדרת שרת הגיבוי של Barman
כדי להגדיר את Barman כך שיפעל עם שרת AlloyDB Omni, מריצים את הפקודות הבאות בשרת Barman.
מוודאים שחיבור השכפול של הסטרימינג פועל:
psql -h DATABASE_IP -U streaming_barman -c "IDENTIFY_SYSTEM" replication=1הפלט אמור להיראות כך:
systemid | timeline | xlogpos | dbname ---------------------+----------+------------+-------- 7265722823667040273 | 1 | 0/1F0AFCD0 | (1 row)מוודאים ש-Barman יכול להתחבר לשרת AlloyDB Omni כמשתמש מסד הנתונים
barman.psql -t -h DATABASE_IP -U barman -d postgres -c "SELECT 'Connected as: '||current_user"מחליפים את
DATABASE_IPבכתובת ה-IP של שרת AlloyDB Omni.הפלט אמור להיראות כך:
Connected as: barmanמגדירים את שרת הגיבוי של Barman בהתאם לצרכים ולהעדפות שלכם.
ההגדרות הבאות צריכות להיכלל בהגדרה:
- מגדירים את
conninfoלהתחבר למסד הנתוניםpostgresשל AlloyDB Omni בתור המשתמשbarman. - מגדירים את
streaming_conninfoלשימוש במשתמשstreaming_barman. - מגדירים הנחיות אחרות שנדרשות להפעלת סטרימינג של WAL, לפי ההוראות במסמכי Barman.
בדוגמה המינימלית אך המלאה הבאה, משנים דוגמה להגדרת סטרימינג מתוך התיעוד של Barman:
[CONFIGURATION_TAG] description = "Backup settings for my AlloyDB Omni server" conninfo = host=DATABASE_IP user=barman dbname=postgres streaming_conninfo = host=DATABASE_IP user=streaming_barman backup_method = postgres streaming_archiver = on slot_name = barmanמחליפים את מה שכתוב בשדות הבאים:
CONFIGURATION_TAG: תג קצר לזיהוי הגדרות השרת האלה כשמריצים פקודותbarman. לדוגמה:omni.
DATABASE_IP: כתובת ה-IP של שרת AlloyDB Omni.
- מגדירים את
עוברים למשתמש
barman.sudo su - barmanמשתמשים בפקודה
barman receive-walכדי ליצור משבצת שכפול, ואז מתחילים לקבל מקור WAL משרת מסד הנתונים:barman receive-wal --create-slot CONFIGURATION_TAGbarman receive-wal CONFIGURATION_TAG &מחליפים את
CONFIGURATION_TAGבתג ההגדרה שבחרתם בשלב הקודם.
הכלי Barman מוגדר עכשיו לעבודה עם שרת AlloyDB Omni. כדי לבדוק את סטטוס השכפול, ליצור גיבויים ידניים ולבצע משימות אחרות, אפשר לעיין בפקודות כלליות.
לדוגמה, כדי ליצור גיבוי ידני, מריצים את הפקודה barman backup.