בקטעים הבאים מוסבר איך להגדיר את השרת הראשי של AlloyDB Omni לשכפול, להגדיר את שרת הרפליקה ולאמת את סטטוס השכפול בשרת הראשי.
פרטים נוספים זמינים במאמר בנושא התקנת AlloyDB Omni ב-Kubernetes.
הגדרת השרת הראשי לשכפול
מעדכנים את הגדרות הרשת או חומת האש של המארח של השרת הראשי כך שיתאפשר תעבורת כניסה מהמארח של שרת ההעתקה דרך יציאת Postgres של השרת הראשי.
יוצרים משתמש שכפול:
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 כשהתקנתם אותו.
-
מוסיפים את השורות הבאות לקובץ
/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: הנתיב לספריית הנתונים של השרת הראשי.
-
מפעילים מחדש את השרת הראשי:
Docker
docker restart CONTAINER_NAMEPodman
podman restart CONTAINER_NAME
יצירה והגדרה של שרת העתקה
כדי ליצור ולהגדיר שרת העתקה של AlloyDB Omni:
מוודאים שלעותק יש קישוריות לרשת לשרת הראשי:
ping SOURCE_IPמחליפים את
SOURCE_IPבכתובת ה-IP של מכונת AlloyDB Omni הראשית שממנה רוצים לשכפל.מוודאים שההעתק יכול להתחבר לשרת הראשי:
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)לעותק צריך להיות מיקום אחסון מתמיד בדיסק:
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: התווית של שם משבצת השכפול.
-
מפעילים את מופע הרפליקה:
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/alloydbomniPodman
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"טבלת הפלט מכילה שורה אחת לכל עותק משוכפל שמחובר לשרת מסד הנתונים הראשי.
אחרי שמגדירים שכפול, כל ההוספות, העדכונים והמחיקות של שורות בשרת מסד הנתונים הראשי הופכים לקריאים בעותק תוך שניות.