בדף הזה מוסבר איך להגדיר זמינות גבוהה ב-AlloyDB Omni. בדף הזה מוסבר רק איך ליצור מכונת AlloyDB Omni חדשה בהגדרת זמינות גבוהה. הוא לא כולל המרה של מופעים קיימים לזמינות גבוהה.
לפני שמתחילים
כדאי לקרוא את המאמר בנושא זמינות גבוהה ועמידות נתונים.
אם עדיין אין לכם פרויקט, אתם יכולים ליצור Google Cloud פרויקט.
מוודאים שהחיוב מופעל בפרויקט.
פותחים את Cloud Shell במסוף Google Cloud .
במסוף Google Cloud , משכפלים את מאגר המקור הבא.
git clone https://github.com/GoogleCloudPlatform/cloud-solutions.git
התקנה
במדריך הזה נסביר איך פורסים קלאסטר של שלושה צמתים של Patroni עם AlloyDB Omni וקלאסטר של שלושה צמתים של etcd כמאגר ההגדרות. בחלק הקדמי של האשכול, אנחנו משתמשים ב-HAProxy בקבוצת מופעי מכונה מנוהלים עבור כתובת ה-IP הצפה, כדי שהמעבר לגיבוי יהיה שקוף ללקוחות.
ההגדרה הראשונית של המערך הזה מוצגת בדיאגרמה הבאה:
איור 1. הגדרה שבה HAProxy מנהל את החיבור בין הלקוחות לבין הצומת הראשי.
אם מתרחשת הפסקה זמנית בשירות, ההגדרה משתנה לדיאגרמה הבאה:
איור 2. הגדרות העדכון שבהן הצומת הראשי שנכשל מוחלף בצומת ההמתנה.
אם מספר הלקוחות שמתחברים למסד הנתונים הופך לבעיה ונתקלים בבעיות בביצועים בגלל מספר גדול של חיבורים בו-זמניים למסד הנתונים, מומלץ להוסיף מאגר חיבורים בצד האפליקציה. אם אי אפשר לעשות את זה, אפשר להוסיף מאגר חיבורים בצד מסד הנתונים באמצעות כלי כמו PgBouncer.
פריסה
ב-Cloud Shell, אחרי שכפול המאגר Cloud Solutions, עוברים לספרייה terraform.
cd cloud-solutions/projects/alloydbomni-ha-patroni-etcd/terraform
יוצרים ועורכים קובץ
terraform.tfvars. בתוך הקובץ, מגדירים ערכים למשתנים הבאים.project_id = "PROJECT_ID" region = "REGION" zones = "ZONES" node_count = 3 cluster_name = "CLUSTER_NAME" replication_user_password = "REPLICATION_USER_PASSWORD" postgres_super_user_password = "PG_SUPER_USER_PASSWORD"תיאורים של כל משתנה זמינים ב-GitHub בקובץ תצורת המשתנים.
מריצים את סקריפט Terraform כדי ליצור את כל המשאבים.
terraform init && terraform apply
הסקריפט הזה יוצר ומגדיר את הפריטים הבאים:
שלושה צמתים לאשכול etcd
שלושה צמתים לאשכול Patroni
צומת אחד ל-HAProxy
הגדרת Patroni כסינכרוני
כדי להגדיר ש-Patroni ישתמש רק בשכפול סינכרוני באשכול של שלושת הצמתים, מוסיפים פריטי הגדרה כמו synchronous_mode, synchronous_node_count, synchronous_commit ו-synchronous_standby_names בקטע bootstrap בקובצי ההגדרה של Patroni. ההגדרה של Patroni מוגדרת בתבנית של סקריפט הפעלה ובקובץ /alloydb/config/patroni.yml בצמתי Patroni. כדי להשתמש בשכפול סינכרוני, הגדרת האתחול של Patroni צריכה להיראות כך:
bootstrap:
dcs:
ttl: 30
loop_wait: 10
retry_timeout: 10
maximum_lag_on_failover: 1048576
synchronous_mode: true
synchronous_node_count: 2
postgresql:
use_pg_rewind: true
use_slots: true
parameters:
hot_standby: "on"
wal_keep_segments: 20
max_wal_senders: 8
max_replication_slots: 8
synchronous_commit: remote_apply
synchronous_standby_names: '*'
כשsynchronous_mode מופעל, Patroni משתמש בשכפול סינכרוני בין השרת הראשי לבין שאר העותקים המשוכפלים. הפרמטר synchronous_node_count משמש את Patroni לניהול מספר העותקים המשוכפלים של הגיבוי הסינכרוני. Patroni מנהל מספר מדויק של עותקים משוכפלים במצב המתנה סינכרוני על סמך הפרמטר synchronous_node_count, ומתאים את המצב במאגר ההגדרות וב-synchronous_standby_names כשהחברים מצטרפים ועוזבים. מידע נוסף על שכפול סינכרוני זמין בקטע מצבי שכפול במסמכי העזרה של Patroni.