הפעלת דפים גדולים
AlloyDB Omni, כמו PostgreSQL, תומך בשימוש בדפים גדולים. כדי לעשות את זה, צריך להפעיל במחשב דפים גדולים, וגם להפעיל את הגדרת מסד הנתונים huge_pages.
מריצים את הסקריפט שסופק כדי להפעיל דפים גדולים במחשב:
Docker
docker run --rm --privileged google/alloydbomni setup-host
Docker
docker run --rm --privileged google/alloydbomni setup-host
Podman
podman run --rm --privileged google/alloydbomni setup-host
Podman
podman run --rm --privileged google/alloydbomni setup-host
כדי להפעיל דפים גדולים, מוסיפים את השורה הבאה ל-
postgresql.conf:huge_pages=on
הפעלת החלפה
החלפה במערכת ההפעלה מאפשרת להרחיב את הזיכרון הפיזי הזמין על ידי העברת דפי זיכרון לא פעילים בין זיכרון הגישה האקראית (RAM) לבין הדיסק הקשיח, כדי לפנות מקום בזיכרון ה-RAM לתהליכים פעילים. AlloyDB Omni משתמש בהחלפה כשהעומס עליו גבוה והוא זקוק לזיכרון נוסף.
כדי לבדוק כמה שטח החלפה מופעל במערכת, מריצים את הפקודה הבאה:
cat /proc/meminfo | grep SwapTotalהפלט אמור להיראות כך:
SwapTotal: 165748732 kB
כדי להפעיל את ההחלפה במערכת ההפעלה אם ערך הפלט הוא 0, אפשר לעיין במאמרים הבאים:
הפעלת ליבות dump
אם AlloyDB Omni נתקל בשגיאה שלא ניתן לתקן וקורס, כדאי שיהיה לכם קובץ ליבת זיכרון (core dump) לצורך ניתוח. Core dump הוא תמונת מצב של הזיכרון של תהליך AlloyDB Omni בנקודת הקריסה.
כדי להגדיר ליבות (kernel) של BERT, מגדירים את kernel.core_pattern באופן הבא:
- משתמשים בפקודה
sysctlכדי להגדיר פרמטרים של ליבת זמן הריצה. כדי להגדיר את
kernel.core_patternבאופן מיידי, משתמשים בפקודה:sysctl -w kernel.core_pattern="CORE_PATTERN"מחליפים את
CORE_PATTERNבתבנית של שם קובץ ליבה, כמו "%e-%t.core".מידע נוסף על תבניות של שמות קבצים מרכזיים זמין במאמר איך מגדירים עיבוד של שמות קבצים מרכזיים.
ה-handler של systemd-coredump מאפשר להגדיר עוד את הגדרות ה-coredump. הכלי מותקן כברירת מחדל ב-RHEL. במערכות Debian ו-Ubuntu, מריצים את הפקודה
sudo apt install coredumpctlכדי להתקין את הכלי.כשמפעילים את AlloyDB Omni, צריך לוודא שמעבירים את הארגומנט
--ulimit=core:-1:-1בפקודהdocker run:Docker
docker run --name CONTAINER_NAME \ -e POSTGRES_PASSWORD=NEW_PASSWORD \ --ulimit=core:-1:-1 \ -p HOST_PORT:5432 -d google/alloydbomni
Docker
docker run --name CONTAINER_NAME \ -e POSTGRES_PASSWORD=NEW_PASSWORD \ --ulimit=core:-1:-1 \ -p HOST_PORT:5432 -d google/alloydbomni
Podman
podman run --name CONTAINER_NAME \ -e POSTGRES_PASSWORD=NEW_PASSWORD \ --ulimit=core:-1:-1 \ -p HOST_PORT:5432 -d google/alloydbomni
Podman
podman run --name CONTAINER_NAME \ -e POSTGRES_PASSWORD=NEW_PASSWORD \ --ulimit=core:-1:-1 \ -p HOST_PORT:5432 -d google/alloydbomni
מחליפים את מה שכתוב בשדות הבאים:
-
CONTAINER_NAME: השם של מאגר חדש של AlloyDB Omni, לדוגמהmy-omni-1. -
NEW_PASSWORD: הסיסמה שהוקצתה למשתמשpostgresשל המאגר החדש אחרי יצירת הסיסמה.
-
הפעלת רישום ביומן פנימי
AlloyDB Omni מספק יותר הודעות בנוסף ליומני PostgreSQL הרגילים. ההודעות האלה מיועדות לתמיכה ב-AlloyDB ל-PostgreSQL בגלל האופי הטכני שלהן. עם זאת, מידע נוסף יכול לעזור בניפוי באגים בבעיות במסד הנתונים.
כדי להפעיל רישום ביומן פנימי, צריך לבצע את השלבים הבאים:
מגדירים את פרמטר מסד הנתונים
enable_alloydb_internal_logלערךon:ALTER SYSTEM SET enable_alloydb_internal_log=on;מידע נוסף על שינוי ההגדרות של AlloyDB Omni זמין במאמר הגדרת פרמטרים של מסד נתונים ב-AlloyDB Omni.
מפעילים מחדש כדי להחיל את השינויים:
Docker
docker restart CONTAINER_NAME
Docker
docker restart CONTAINER_NAME
Podman
podman restart CONTAINER_NAME
Podman
podman restart CONTAINER_NAME
כדי להתאים אישית את הרישום ביומן הפנימי, למשל להגדיר שמות של קובצי יומן ומדיניות רוטציה, משתמשים בפרמטרים של PostgreSQL.
לדוגמה, הפרמטר log_directory מציין את הספרייה שבה יישמר קובץ היומן, והפרמטר log_filename מגדיר את השם של קובץ היומן.
AlloyDB Omni משלב את הפרמטרים log_directory ו-log_filename ושומר יומנים פנימיים באופן הבא:
LOG_DIRECTORY/LOG_FILENAME.internal
הגדרת יחידות systemd להפעלת פעולות באופן אוטומטי
אם מריצים את AlloyDB Omni בשרת ייעודי, יכול להיות שתרצו להגדיר פעולות מסוימות שיתחילו אוטומטית כשהשרת יופעל. אחת הדרכים לעשות זאת היא באמצעות יחידות systemd.
לדוגמה, השלבים הבאים מגדירים את systemd כך שדפים גדולים יופעלו אוטומטית בכל פעם שהשרת יופעל.
יוצרים קובץ ב-
/etc/systemd/system/alloydb-setup-env.service:[Unit] Description=Setup huge pages for AlloyDB Omni [Service] Type=oneshot ExecStart=/usr/bin/docker run --rm --privileged google/alloydbomni setup-host [Install] WantedBy=multi-user.targetכדי להפעיל את השירות:
sudo systemctl enable alloydb-setup-env.service