הגדרת Barman ל-AlloyDB Omni

בחירת גרסה של מאמר העזרה:

בדף הזה מוסבר איך להגן על הנתונים על ידי הגדרת AlloyDB Omni לעבודה עם Barman, שרת גיבוי מסד נתונים בקוד פתוח.

אתם יכולים להגן על הנתונים ב-AlloyDB Omni באמצעות כל טכנולוגיית גיבוי של מסד נתונים שפועלת עם PostgreSQL. לדוגמה, אתם יכולים להגדיר את AlloyDB Omni כך שיאפשר חיבורים משרת Barman שאתם שולטים בו. הפעולה הזו מאפשרת לשרת Barman לבצע גיבויים רציפים של הנתונים שמאוחסנים בשרת AlloyDB Omni.

אחרי שמגדירים את השרתים של Barman ו-AlloyDB Omni כך שיפעלו יחד, אפשר להריץ פקודות Barman כדי לבצע מגוון משימות של הגנה על נתונים והתאוששות מאסון, כולל:

  • יצירת גיבוי לפי דרישה של הנתונים.
  • מגדירים סטרימינג סינכרוני של WAL של שינויי הנתונים לשרת הגיבוי.
  • שחזור מגיבוי ספציפי.
  • מבצעים שחזור מנקודה מסוימת בזמן.

מידע נוסף על הפעולה של Barman זמין במדריך של Barman.

לפני שמתחילים

לפני שמגדירים את AlloyDB Omni לעבודה עם Barman, צריך לוודא שיש לכם את הדברים הבאים:

הגדרת AlloyDB Omni לעבודה עם Barman

כדי להכין את שרת AlloyDB Omni לעבודה עם Barman, מריצים את הפקודות הבאות בשרת שבו התקנתם את AlloyDB Omni.

  1. יוצרים את משתמש מסד הנתונים 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 כשהתקנתם אותו.

  2. מוסיפים את השורות הבאות לקובץ 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.

  3. מוסיפים את השורות הבאות לקובץ DATA_DIR/postgresql.conf:

    archive_command='/bin/true'
    archive_mode=on
    listen_addresses='*'
    wal_level='replica'
    
  4. מפעילים מחדש את שירות AlloyDB Omni:

    Docker

    docker restart CONTAINER_NAME

    Podman

    podman restart CONTAINER_NAME

    מחליפים את CONTAINER_NAME בשם שהקציתם לקונטיינר של AlloyDB Omni כשהתקנתם אותו.

  5. מריצים את הפקודה הבאה כדי לוודא שכל הפרמטרים הדרושים מוגדרים בצורה מתאימה:

    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.

  1. מוודאים שחיבור השכפול של הסטרימינג פועל:

    psql -h DATABASE_IP -U streaming_barman -c "IDENTIFY_SYSTEM" replication=1

    הפלט אמור להיראות כך:

          systemid       | timeline |  xlogpos   | dbname
    ---------------------+----------+------------+--------
     7265722823667040273 |        1 | 0/1F0AFCD0 |
    (1 row)
    
  2. מוודאים ש-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
    
  3. מגדירים את שרת הגיבוי של 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.

  4. עוברים למשתמש barman.

    sudo su - barman
  5. משתמשים בפקודה barman receive-wal כדי ליצור משבצת שכפול, ואז מתחילים לקבל מקור WAL משרת מסד הנתונים:

    barman receive-wal --create-slot CONFIGURATION_TAG
    barman receive-wal CONFIGURATION_TAG &

    מחליפים את CONFIGURATION_TAG בתג ההגדרה שבחרתם בשלב הקודם.

הכלי Barman מוגדר עכשיו לעבודה עם שרת AlloyDB Omni. כדי לבדוק את סטטוס השכפול, ליצור גיבויים ידניים ולבצע משימות אחרות, אפשר לעיין בפקודות כלליות.

לדוגמה, כדי ליצור גיבוי ידני, מריצים את הפקודה barman backup.

המאמרים הבאים