מידע על ניהול זיכרון אוטומטי

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

‫AlloyDB Omni משתמש באלגוריתמים אדפטיביים לניהול זיכרון.

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

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

זיכרון אוטומטי

כברירת מחדל, הפרמטר shared_buffers מוגדר לערך 0, שהוא ערך מיוחד שמגדיר את המגבלה העליונה של גודל מטמון shared buffers ל-80% מזיכרון המערכת. ההתחלה ב-AlloyDB Omni היא 10% מהתקרה העליונה של shared_buffers. אם shared_buffers מוחלף בערך מותאם אישית, AlloyDB Omni מתייחס לערך הזה כאל הגבול העליון של הגודל של shared_buffers, ומתחיל עם הגודל המותאם אישית שצוין.

כדי לציין גודל מותאם אישית, עורכים את קובץ התצורה postgresql.conf. לדוגמה, אפשר להגדיר את shared_buffers ל-1GB באחת מהדרכים הבאות:

  • docker run --name CONTAINER_NAME -e INITDB_ARGS="-c shared_buffers=1GB" $image

  • docker run --name CONTAINER_NAME $image -c shared_buffers=1GB

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

אופטימיזציה של ביצועי השאילתות

ערך ברירת המחדל של הפרמטר shared_buffers מתאים לתרחישים נפוצים.

עם זאת, אפשר לשנות את הערך כדי לשפר את הביצועים. אם בוחרים להסתמך על ערך ברירת המחדל shared_buffers כדי להסיק את הגבול העליון של המאגר המשותף, צריך להשתמש בערך של cgroup memory.max כדי להשפיע על החישוב.

זיכרון של מנוע מבוסס-עמודות

הערך הדינמי shared_buffers לא תלוי בזיכרון של מנוע מבוסס-עמודות. כשמנוע מבוסס-עמודות מופעל, אפשר לחשב את הגודל הדינמי shared_buffers על ידי הפחתת כמות הזיכרון שמשמשת את מנוע מבוסס-עמודות מ-80% מהזיכרון הכולל שזמין למערכת או לקבוצת הבקרה.

דפים ענקיים

שימוש בדפים ענקיים משפר את הביצועים של מסד הנתונים. מערכת AlloyDB Omni מנהלת דפים ענקיים באופן מפורש אם אפשר, אחרת היא מסתמכת על התכונה 'דפים ענקיים שקופים' (THP) של מערכת ההפעלה. אם אף אחד מסוגי הדפים הענקיים לא נתמך, מערכת AlloyDB Omni חוזרת לדף בגודל 4k ומציגה אזהרה ביומני קונטיינר של Docker‏ docker logs $container_name עם הוראות ספציפיות להגדרת דפים ענקיים. הוראות להפעלת קונטיינר מופיעות במאמר הפעלת AlloyDB Omni.

האזהרה תיראה כך:

HINT:  Please either execute the all-in-one setup script:
          docker run --rm --privileged $image setup-host
        OR manually execute:
          echo within_size | sudo tee /sys/kernel/mm/transparent_hugepage/shmem_enabled
          sudo sysctl -w vm.nr_overcommit_hugepages=1048576

ניהול זיכרון אוטומטי בזמן ריצה

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

שינוי גודל דינמי shared_buffers
AlloyDB Omni מגדיל את הגודל הדינמי של shared_buffers כשצריכת הזיכרון של המערכת נמוכה, ומקטין את הגודל כשצריכת הזיכרון של המערכת גבוהה. כדי לעקוב אחרי הגודל הדינמי של shared_buffers, משתמשים ב:
CREATE EXTENSION IF NOT EXISTS g_memory;
SELECT g_dynamic_shared_size();
סיום חיבור PostgreSQL כשהמערכת סובלת ממחסור חמור בזיכרון
AlloyDB Omni מנסה למחוק את חיבורי PostgreSQL שצורכים הכי הרבה זיכרון, עד שהעומס יחזור לרמה סבירה, אם הוא מזהה שרמת הזיכרון במערכת נמוכה מאוד. כשאירוע כזה קורה, המערכת רושמת את הפרטים הבאים ביומנים של קונטיינר Docker:
WARNING: Sending SIGTERM to pid=xxx NSpid=xxx (VA size = xxxMB) (RSS size = xxxMB)