יצירת עותק משוכפל לקריאה בלבד

בוחרים גרסת תיעוד:

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

בקטעים הבאים מוסבר איך להגדיר את השרת הראשי של AlloyDB Omni לשכפול, להגדיר את שרת הרפליקה ולאמת את סטטוס השכפול בשרת הראשי.

פרטים נוספים זמינים במאמר בנושא התקנת AlloyDB Omni ב-Kubernetes.

הגדרת השרת הראשי לשכפול

  1. מעדכנים את הגדרות הרשת או חומת האש של המארח של השרת הראשי כך שיתאפשר תעבורת כניסה מהמארח של שרת ההעתקה דרך יציאת Postgres של השרת הראשי.

  2. יוצרים משתמש שכפול:

    Docker

    docker exec CONTAINER_NAME psql -h localhost -U postgres -c "create user REPLICA_USER with replication password 'PASSWORD'"

    מחליפים את מה שכתוב בשדות הבאים:

    • REPLICA_USER: השם של משתמש ההעתק.
    • PASSWORD: הסיסמה של המשתמש המשוכפל.
    • CONTAINER_NAME: השם שהקציתם לקונטיינר של AlloyDB Omni כשהתקנתם אותו.

    Podman

    podman exec CONTAINER_NAME psql -h localhost -U postgres -c "create user REPLICA_USER with replication password 'PASSWORD'"

    מחליפים את מה שכתוב בשדות הבאים:

    • REPLICA_USER: השם של משתמש ההעתק.
    • PASSWORD: הסיסמה של המשתמש המשוכפל.
    • var>CONTAINER_NAME: השם שהקציתם לקונטיינר של AlloyDB Omni כשהתקנתם אותו.
  3. מוסיפים את השורות הבאות לקובץ /DATA_DIR/pg_hba.conf של השרת הראשי לפני host all all all scram-sha-256 שקיים בקובץ:

    host alloydbmetadata    alloydbmetadata   IP_RANGE trust
    host replication        REPLICA_USER    IP_RANGE scram-sha-256
    

    מחליפים את מה שכתוב בשדות הבאים:

    • IP_RANGE: טווח כתובות ה-IP, בסימון CIDR, של תת-הרשת שבה נמצאת מכונת העותק. לדוגמה, 203.0.113.0/24.
    • DATA_DIR: הנתיב לספריית הנתונים של השרת הראשי.
  4. מפעילים מחדש את השרת הראשי:

    Docker

    docker restart CONTAINER_NAME

    Podman

    podman restart CONTAINER_NAME

יצירה והגדרה של שרת העתקה

כדי ליצור ולהגדיר שרת העתקה של AlloyDB Omni:

  1. מוודאים שלעותק יש קישוריות לרשת לשרת הראשי:

    ping SOURCE_IP

    מחליפים את SOURCE_IP בכתובת ה-IP של מכונת AlloyDB Omni הראשית שממנה רוצים לשכפל.

  2. מוודאים שההעתק יכול להתחבר לשרת הראשי:

    Docker

    docker run -it --rm google/alloydbomni psql "host=SOURCE_IP user=REPLICA_USER replication=1" -c "IDENTIFY_SYSTEM;"

    Podman

    podman run -it --rm google/alloydbomni psql "host=SOURCE_IP user=REPLICA_USER replication=1" -c "IDENTIFY_SYSTEM;"

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

           systemid       | timeline |  xlogpos  | dbname
     ---------------------+----------+-----------+--------
      7376500460465963036 |        1 | 0/454B670 |
      (1 row)
    
  3. לעותק צריך להיות מיקום אחסון מתמיד בדיסק:

    Docker

     mkdir alloydb && docker run --rm -it \
       -e PGDATA=/var/lib/postgresql/data/pgdata \
       -v "$PWD/alloydb":/var/lib/postgresql/data \
       -p 5432:5432 \
       --user $(id -u):$(id -g) \
       google/alloydbomni \
       /usr/lib/postgresql/15/bin/pg_basebackup \
         --pgdata=/var/lib/postgresql/data/pgdata \
         --checkpoint=fast \
         --host="SOURCE_IP" \
         --port="SOURCE_PORT" \
         --username=REPLICA_USER \
         --create-slot \
         --write-recovery-conf \
         --slot="SLOT_NAME"

    מחליפים את מה שכתוב בשדות הבאים:

    • SOURCE_PORT: יציאת ה-TCP של מכונת AlloyDB Omni הראשית שממנה מתבצע השכפול. אם לא תציינו את הערך הזה, AlloyDB Omni יחיל ערך ברירת מחדל של 5432.
    • SLOT_NAME: התווית של שם משבצת השכפול.

    Podman

     mkdir alloydb && podman run --rm -it \
       -e PGDATA=/var/lib/postgresql/data/pgdata \
       -v "$PWD/alloydb":/var/lib/postgresql/data \
       -p 5432:5432 \
       --user $(id -u):$(id -g) \
       google/alloydbomni \
       /usr/lib/postgresql/15/bin/pg_basebackup \
         --pgdata=/var/lib/postgresql/data/pgdata \
         --checkpoint=fast \
         --host="SOURCE_IP" \
         --port="SOURCE_PORT" \
         --username=REPLICA_USER \
         --create-slot \
         --write-recovery-conf \
         --progress \
         --slot="SLOT_NAME"

    מחליפים את מה שכתוב בשדות הבאים:

    • SOURCE_PORT: יציאת ה-TCP של מכונת AlloyDB Omni הראשית שממנה מתבצע השכפול. אם לא תציינו את הערך הזה, AlloyDB Omni יחיל ערך ברירת מחדל של 5432.
    • SLOT_NAME: התווית של שם משבצת השכפול.
  4. מפעילים את מופע הרפליקה:

    Docker

    docker run --detach \
      --name pg-service \
      -e POSTGRES_PASSWORD=a \
      -e PGDATA=/var/lib/postgresql/data/pgdata \
      -v "$PWD/alloydb":/var/lib/postgresql/data \
      -v /dev/shm:/dev/shm \
      -p 5432:5432 \
      --user $(id -u):$(id -g) \
      google/alloydbomni

    Podman

    podman run --detach \
      --name pg-service \
      -e POSTGRES_PASSWORD=a \
      -e PGDATA=/var/lib/postgresql/data/pgdata \
      -v "$PWD/alloydb":/var/lib/postgresql/data \
      -v /dev/shm:/dev/shm \
      -p 5432:5432 \
      --user $(id -u):$(id -g) \
      google/alloydbomni

אימות סטטוס השכפול בשרת הראשי

כדי לוודא שהשכפול מוגדר בצורה נכונה, מריצים את הפקודה הבאה במארח של השרת הראשי:

Docker

  docker exec -it CONTAINER_NAME psql -h localhost -U postgres -c "select * from pg_stat_replication"

Podman

  podman exec -it CONTAINER_NAME psql -h localhost -U postgres -c "select * from pg_stat_replication"

טבלת הפלט מכילה שורה אחת לכל עותק משוכפל שמחובר לשרת מסד הנתונים הראשי.

אחרי שמגדירים שכפול, כל ההוספות, העדכונים והמחיקות של שורות בשרת מסד הנתונים הראשי הופכים לקריאים בעותק תוך שניות.

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