סקירה כללית של מנוע מבוסס-עמודות של AlloyDB מופיעה במאמר סקירה כללית של מנוע העמודות של AlloyDB Omni.
הפעלת מנוע מבוסס-עמודות
כדי להשתמש במנוע מבוסס-עמודות במכונה, מגדירים את הדגל google_columnar_engine.enabled של המכונה לערך on.
שרת יחיד
כדי להגדיר את google_columnar_engine.enabled ל-on, פועלים לפי השלבים הבאים:
מריצים את הפקודה
ALTER SYSTEMPostgreSQL:ALTER SYSTEM SET google_columnar_engine.enabled = 'on'אם רוצים לשנות את ההגדרות של מנוע העמודות, צריך לפעול לפי ההוראות שבקטע הבא לפני שמפעילים מחדש את שרת מסד הנתונים. אחרת, משלימים את השלב הבא כדי להפעיל מחדש את שרת מסד הנתונים.
כדי שהשינוי בפרמטרים של ההגדרה ייכנס לתוקף, צריך להפעיל מחדש את הקונטיינר הפועל עם AlloyDB Omni.
Docker
sudo docker restart CONTAINER_NAMEPodman
sudo podman restart CONTAINER_NAME
הגדרת הגודל של מאגר העמודות
כשהמנוע מבוסס-עמודות מופעל במופע, AlloyDB Omni מקצה חלק מהזיכרון של המופע לאחסון הנתונים העמודתיים שלו. הקצאת זיכרון RAM מהיר במיוחד למאגר העמודות מוודאת ש-AlloyDB Omni יוכל לגשת לנתונים העמודתיים במהירות המרבית.
הזיכרון והמטמון של האחסון מייצגים יחד את הקיבולת הכוללת של מנוע מבוסס-עמודות.
הגדרת הזיכרון
אפשר להגדיר את ההקצאה לגודל קבוע באמצעות הדגל google_columnar_engine.memory_size_in_mb.
שרת יחיד
כדי להגדיר את הדגל google_columnar_engine.memory_size_in_mb במופע:
מגדירים את הזיכרון על ידי הפעלת הפקודה
ALTER SYSTEMPostgreSQL:ALTER SYSTEM SET google_columnar_engine.memory_size_in_mb = COLUMN_MEMORY_SIZE;מחליפים את
COLUMN_MEMORY_SIZEבגודל החדש של אחסון העמודה, במגה-בייט – לדוגמה,256.כדי שהשינוי בפרמטרים של ההגדרה ייכנס לתוקף, צריך להפעיל מחדש את הקונטיינר הפועל עם AlloyDB Omni.
Docker
sudo docker restart CONTAINER_NAMEPodman
sudo podman restart CONTAINER_NAME
הגדרת מטמון אחסון
שרת יחיד
אפשר להגדיר את מטמון האחסון של מנוע מבוסס-עמודות במכשירים ייעודיים או במכשירים משותפים.
מכשירים ייעודיים
במכשירים ייעודיים, כדי להפעיל מטמון של אחסון מבוסס-עמודות במנוע מבוסס-עמודות של AlloyDB Omni עבור קונטיינר של שרת יחיד, צריך להקצות דיסקים וליצור מערכת קבצים, ואז לטעון את ספריית המטמון בתוך AlloyDB Omni, ולבסוף להפעיל את המטמון של אחסון מבוסס-עמודות.
הקצאת דיסקים ויצירת מערכת קבצים
כדי לספק אחסון למטמון של מנוע מבוסס-עמודות של AlloyDB Omni, פועלים לפי ההוראות של מערכת ההפעלה של המארח כדי להכין אמצעי אחסון – כמו נפח Docker עם שם או מערכת קבצים בדיסקים ייעודיים.
מערכות הפעלה שאינן Linux (macOS, Windows)
ב-macOS או ב-Windows, כדי להבטיח ביצועים אופטימליים, צריך להשתמש בנפח Docker עם שם בשביל מטמון אחסון עמודות.
-
יוצרים נפח אחסון עם שם:
docker volume create COLUMNAR_CACHE_VOLUME
מחליפים את
COLUMNAR_CACHE_VOLUMEבשם של אמצעי האחסון, לדוגמה,omni-columnar-cache. -
משתמשים בעוצמת הקול הזו כשמריצים את הקונטיינר. מידע נוסף מופיע במאמר הוספת ספריית מטמון של אחסון עמודות.
Linux
כדי להקצות דיסקים וליצור מערכת קבצים למטמון של מנוע מבוסס-עמודות של AlloyDB Omni, יוצרים מערכת קבצים בדיסק אחד או בכמה דיסקים ומעלים אותה בתוך קונטיינר עם AlloyDB Omni. בנוסף, אפשר להשתמש בכלי עזר כמו mdadm או lvm כדי לאגד את הקיבולת באמצעות כמה דיסקים ולהשתמש בכל מערכת קבצים. השלבים הבאים מדגימים שימוש בפקודות lvm ו-ext4 במכונת Ubuntu ב-Compute Engine באמצעות כונני NVMe SSD.
כדי ליצור קבוצת עוצמת קול מכל המכשירים הפיזיים הזמינים:
nvme_prefix="STORAGE_PREFIX" nvme_list=$(ls "$nvme_prefix"*) sudo vgcreate VOLUME_GROUP ${nvme_list}
מחליפים את מה שכתוב בשדות הבאים:
-
STORAGE_PREFIX: הקידומת של הנתיב של הדיסקים המקומיים של היעד שמצורפים למכונה וירטואלית באמצעות ממשק NVMe (זיכרון לא נדיף) – לדוגמה, ב- Google Cloud, הנתיבים של מכשירי NVMe תמיד מתחילים ב-/dev/nvme0n. -
VOLUME_GROUP: השם של קבוצת נפחים שבה משולבים כונני ה-SSD שלכם, לדוגמה,omni-disk-cache-volume.
-
-
כדי ליצור נפח לוגי מהקיבולת הפנויה של קבוצת הנפחים מהשלב הקודם, משתמשים בפקודה הבאה:
sudo lvcreate -n LOGICAL_VOLUME -l 100%FREE VOLUME_GROUP
מחליפים את
LOGICAL_VOLUMEבשם של נפח לוגי שמערכת LVM מתייחסת אליו כמחיצה – לדוגמה,omni_disk_cache_device. - יוצרים את מערכת הקבצים
ext4בווליום הלוגי. אם צריך, אפשר לציין אפשרויות אחרות שלext4בהתאם לאבטחת הנתונים.sudo mkfs.ext4 /dev/VOLUME_GROUP/LOGICAL_VOLUME
כדי ליצור ספרייה שתשמש כנקודת טעינה במחשב המארח ולטעון את מערכת הקבצים, משתמשים בפקודה הבאה:
sudo mkdir /OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY sudo mount /dev/VOLUME_GROUP/LOGICAL_VOLUME /OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY
מחליפים את
OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORYבשם של הספרייה או בנתיב לספרייה שמשמשת כנקודת צירוף – לדוגמה,omni_columnar_storage_cache_directory.
טעינת ספריית מטמון של אחסון עמודות בתוך AlloyDB Omni
לפני שמפעילים את מטמון הדיסק ב-AlloyDB Omni שפועל בקונטיינר, צריך לטעון את ספריית המטמון בתוך AlloyDB Omni.
כדי לטעון את ספריית המטמון בתוך הקונטיינר, משתמשים בדגל -v.
לנתיבי מארח ב-Linux:
-v /OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY:/CACHE_DIRECTORY_PATH_INSIDE_CONTAINERלכרכים עם שם (לא Linux):
-v COLUMNAR_CACHE_VOLUME:/CACHE_DIRECTORY_PATH_INSIDE_CONTAINER
דוגמה לפקודת Docker שמשתמשת בנפח אחסון עם שם:
sudo docker run --name CONTAINER_NAME
-e POSTGRES_PASSWORD=PASSWORD
-e PGDATA=/var/lib/postgresql/data/pgdata
-v DATA_DIR:/var/lib/postgresql/data
-v COLUMNAR_CACHE_VOLUME:/var/lib/alloydb/columnar_cache
-d google/alloydbomni
במאמר התאמה אישית של ההתקנה של AlloyDB Omni מוסבר איך להתקין את AlloyDB Omni מקובץ אימג' של Docker ואיך להתאים אותה אישית.
כדי לטעון את OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY בתוך קונטיינר Docker שבו פועל AlloyDB Omni, משתמשים בפקודה הבאה:
Docker
sudo docker run --name CONTAINER_NAME
-e POSTGRES_PASSWORD=PASSWORD
-e PGDATA=/var/lib/postgresql/data/pgdata
-v DATA_DIR:/var/lib/postgresql/data
-v /OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY:/CACHE_DIRECTORY_PATH_INSIDE_CONTAINER
-d google/alloydbomni
מחליפים את מה שכתוב בשדות הבאים:
-
CONTAINER_NAME: השם שיוקצה למאגר החדש של AlloyDB Omni, לדוגמהmy-omni. -
PASSWORD: הסיסמה של מנהל הבסיס של מסד הנתונים של PostgreSQL. -
DATA_DIR: הנתיב במערכת הקבצים שרוצים ש-AlloyDB Omni ישתמש בו לספריית הנתונים שלו. -
CACHE_DIRECTORY_PATH_INSIDE_CONTAINER: ספריית המטמון בתוך מאגר AlloyDB Omni שממופה לנקודת הטעינה במחשב המארח – לדוגמה, בהתאם לערך של ספריית המטמון בתוך המאגר,/omni_disk_cache_directory, בדומה ל-OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY, או/disk/cache/inside/container.
Podman
podman run --name CONTAINER_NAME
-e POSTGRES_PASSWORD=PASSWORD
-e PGDATA=/var/lib/postgresql/data/pgdata
-v DATA_DIR:/var/lib/postgresql/data
-v /OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY:/CACHE_DIRECTORY_PATH_INSIDE_CONTAINER
-d docker.io/google/alloydbomni
מחליפים את מה שכתוב בשדות הבאים:
-
CONTAINER_NAME: השם שיוקצה למאגר החדש של AlloyDB Omni, לדוגמהmy-omni. -
PASSWORD: הסיסמה של מנהל הבסיס של מסד הנתונים של PostgreSQL. -
CACHE_DIRECTORY_PATH_INSIDE_CONTAINER: ספריית המטמון בתוך מאגר AlloyDB Omni שממופה לנקודת הטעינה במחשב המארח – לדוגמה, בהתאם לערך של ספריית המטמון בתוך המאגר,/omni_columnar_storage_cache_directory, בדומה ל-OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY, או/disk/cache/inside/container.
כדי להעניק הרשאות גישה מלאות ל-OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY שנטען, משתמשים בפקודות הבאות:
Docker
sudo docker exec -it CONTAINER_NAME chown postgres:postgres /CACHE_DIRECTORY_PATH_INSIDE_CONTAINER sudo docker exec -it CONTAINER_NAME chmod -R a+rw /CACHE_DIRECTORY_PATH_INSIDE_CONTAINER
Podman
sudo podman exec -it CONTAINER_NAME chown postgres:postgres /CACHE_DIRECTORY_PATH_INSIDE_CONTAINER sudo podman exec -it CONTAINER_NAME chmod -R a+rw /CACHE_DIRECTORY_PATH_INSIDE_CONTAINER
הפעלת מטמון אחסון עמודות ב-AlloyDB Omni ל-AlloyDB Omni שפועל בקונטיינר
כדי להפעיל מטמון של אחסון עמודות ב-AlloyDB Omni במכשירים ייעודיים למסד הנתונים, צריך להגדיר את הפרמטרים המתאימים של Grand Unified Configuration (GUC) אחרי שמוודאים שאפשר לגשת לספריית המטמון המצורפת מתוך קונטיינר Docker.
מגדירים את ספריית המטמון של אחסון בעמודות:
ALTER SYSTEM SET google_columnar_engine.omni_storage_cache_directory = OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORY;מחליפים את
OMNI_COLUMNAR_STORAGE_CACHE_DIRECTORYבנתיב המוחלט לספרייה הייעודית שבה רוצים ש-AlloyDB Omni ישמור את קובצי המטמון של אחסון מנוע מבוסס-עמודות. מוודאים שהספרייה הזו קיימת ושיש למשתמש במסד הנתונים הרשאות כתיבה מתאימות.מגדירים את גודל מטמון האחסון:
ALTER SYSTEM SET google_columnar_engine.storage_cache_size = STORAGE_CACHE_SIZE;מחליפים את
STORAGE_CACHE_SIZEבגודל הרצוי של מטמון האחסון העמודתי, במגה-בייט. כברירת מחדל, כל הגודל של המכשיר הייעודי מוקצה למנוע העמודות, בלי להשפיע על מטמון הדיסק. הערך המקסימלי המותר לסימון הזה הוא 1,000 אוgoogle_columnar_engine.memory_size_in_mb, הנמוך מביניהם.כדי שהשינוי בפרמטרים של ההגדרה ייכנס לתוקף, צריך להפעיל מחדש את הקונטיינר הפועל עם AlloyDB Omni.
Docker
sudo docker restart CONTAINER_NAMEPodman
sudo podman restart CONTAINER_NAME
מכשירים משותפים
לפני שמגדירים את המטמון של אחסון עמודות במכשירים משותפים עם מטמון דיסק, צריך להפעיל את מטמון הדיסק של AlloyDB Omni.
כדי להגדיר מטמון אחסון במכשירים משותפים:
מגדירים את מטמון האחסון:
ALTER SYSTEM SET google_columnar_engine.storage_cache_size = STORAGE_CACHE_SIZE;מחליפים את
STORAGE_CACHE_SIZEבגודל של מטמון האחסון הרצוי, במגה-בייט. כברירת מחדל, 5% ממטמון הדיסק מוקצים למנוע העמודות. הערך המקסימלי המותר לדגל הזה הוא 50% מסך מטמון הדיסק או 1000 *google_columnar_engine.memory_size_in_mb, הנמוך מביניהם.כדי שהשינוי בפרמטרים של ההגדרה ייכנס לתוקף, צריך להפעיל מחדש את הקונטיינר הפועל עם AlloyDB Omni.
Docker
sudo docker restart CONTAINER_NAMEPodman
sudo podman restart CONTAINER_NAME
הפעלה של הצטרפות וקטורית
למנוע מבוסס-עמודות יש תכונה של צירוף וקטורי שיכולה לשפר את הביצועים של צירופים על ידי החלת עיבוד וקטורי על שאילתות שעומדות בדרישות.
אחרי שמפעילים את ההצטרפות הווקטורית, למתכנן השאילתות של AlloyDB יש אפשרות להחיל את אופרטור ההצטרפות הווקטורית במקום אופרטור ההצטרפות הרגיל של PostgreSQL. המתכנן מקבל את ההחלטה הזו על ידי השוואה בין העלות של ביצוע השאילתה באמצעות כל אחת מהשיטות.
כדי להפעיל את התכונה 'צירוף וקטורי' במופע, מגדירים את התכונה הניסיונית google_columnar_engine.enable_vectorized_join של המופע לערך on.
כדי להגדיר את הדגל הזה במופע, מריצים את הפקודה ALTER SYSTEM של PostgreSQL:
ALTER SYSTEM SET google_columnar_engine.enable_vectorized_join = 'on';
כברירת מחדל, AlloyDB Omni מקצה שרשור אחד לתכונה של צירוף וקטורי. כדי להגדיל את מספר השרשורים שזמינים לתכונה הזו, צריך להגדיר את הדגל google_columnar_engine.vectorized_join_threads לערך גבוה יותר. הערך המקסימלי הוא cpu_count * 2.
רענון ידני של מנוע מבוסס-עמודות
כברירת מחדל, כשהמנוע מבוסס-עמודות מופעל, הוא מרענן את מאגר העמודות ברקע.
כדי לרענן את מנוע העמודות באופן ידני, מריצים את שאילתת ה-SQL הבאה:
SELECT google_columnar_engine_refresh(relation =>'TABLE_NAME');
מחליפים את TABLE_NAME בשם הטבלה או התצוגה החומרית שרוצים לרענן באופן ידני.
השבתת מנוע מבוסס-עמודות
כדי להשבית את מנוע Columbar במכונה, מגדירים את הדגל google_columnar_engine.enabled לערך off.
שרת יחיד
כדי להגדיר את google_columnar_engine.enabled ל-off, פועלים לפי השלבים הבאים:
- מריצים את הפקודה
ALTER SYSTEMPostgreSQL:
ALTER SYSTEM SET google_columnar_engine.enabled = 'off'
- כדי שהשינוי בפרמטרים של ההגדרה ייכנס לתוקף, צריך להפעיל מחדש את הקונטיינר הפועל עם AlloyDB Omni.
Docker
כדי להפעיל מחדש קונטיינר של AlloyDB Omni, מריצים את הפקודה docker container restart:
sudo docker restart CONTAINER_NAMEמחליפים את CONTAINER_NAME בשם שהקציתם לקונטיינר AlloyDB Omni כשהתקנתם אותו.
Podman
כדי להפעיל מחדש קונטיינר של AlloyDB Omni, מריצים את הפקודה podman container start:
sudo podman restart CONTAINER_NAMEמחליפים את CONTAINER_NAME בשם שהקציתם לקונטיינר AlloyDB Omni כשהתקנתם אותו.
המאמרים הבאים
עובדים לפי ההוראות במדריך האצת שאילתות אנליטיות באמצעות מנוע עמודות ב-AlloyDB Omni של Google CodeLab.