כדי להפעיל הצפנת נתונים שקופה (TDE), צריך לספק את משתני הסביבה הנדרשים של הכספת ולכלול את הדגל --tde-kek-url בתוך POSTGRES_INITDB_ARGS.
לפני שמתחילים
- מגדירים את מנוע הסודות KV-V2 של HashiCorp Vault כדי לוודא שנתיב מפתח ההצפנה (KEK) ואסימון האינטרנט מסוג JSON (JWT) זמינים.
- מוודאים של-AlloyDB Omni יש הרשאה לקרוא את קובץ ה-JWT.
יצירת האשכול
כדי ליצור אשכול עם TDE, צריך להעביר את ההגדרות הנדרשות של שירות ניהול המפתחות (KMS) ואת פרטי האימות במהלך האתחול של מסד הנתונים. סוג האימות הנתמך היחיד הוא jwt.
בוחרים את הכרטיסייה של זמן הריצה של מאגר התגים.
Docker
docker run -d --name CONTAINER_NAME \ --network host \ -v DATA_DIR:/var/lib/postgresql/data \ -v VAULT_CERT_PATH_ON_DISK:VAULT_CERT_PATH \ -e VAULT_AUTH_TYPE=jwt \ -e VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT \ -e VAULT_JWT_PATH=JWT_FILE_PATH \ -e VAULT_ROLE=VAULT_ROLE \ -e VAULT_CERT_PATH=VAULT_CERT_PATH \ -e POSTGRES_INITDB_ARGS=" \ --tde-kek-url=KEK_URL" \ google/alloydbomni:IMAGE_TAG
Docker
docker run -d --name CONTAINER_NAME \ --network host \ -v DATA_DIR:/var/lib/postgresql/data \ -v VAULT_CERT_PATH_ON_DISK:VAULT_CERT_PATH \ -e VAULT_AUTH_TYPE=jwt \ -e VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT \ -e VAULT_JWT_PATH=JWT_FILE_PATH \ -e VAULT_ROLE=VAULT_ROLE \ -e VAULT_CERT_PATH=VAULT_CERT_PATH \ -e POSTGRES_INITDB_ARGS=" \ --tde-kek-url=KEK_URL" \ google/alloydbomni:IMAGE_TAG
Podman
podman run -d --name CONTAINER_NAME \ --network host \ -v DATA_DIR:/var/lib/postgresql/data \ -v VAULT_CERT_PATH_ON_DISK:VAULT_CERT_PATH \ -e VAULT_AUTH_TYPE=jwt \ -e VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT \ -e VAULT_JWT_PATH=JWT_FILE_PATH \ -e VAULT_ROLE=VAULT_ROLE \ -e VAULT_CERT_PATH=VAULT_CERT_PATH \ -e POSTGRES_INITDB_ARGS=" \ --tde-kek-url=KEK_URL" \ google/alloydbomni:IMAGE_TAG
Podman
podman run -d --name CONTAINER_NAME \ --network host \ -v DATA_DIR:/var/lib/postgresql/data \ -v VAULT_CERT_PATH_ON_DISK:VAULT_CERT_PATH \ -e VAULT_AUTH_TYPE=jwt \ -e VAULT_AUTH_MOUNT=JWT_AUTH_ENGINE_MOUNT \ -e VAULT_JWT_PATH=JWT_FILE_PATH \ -e VAULT_ROLE=VAULT_ROLE \ -e VAULT_CERT_PATH=VAULT_CERT_PATH \ -e POSTGRES_INITDB_ARGS=" \ --tde-kek-url=KEK_URL" \ google/alloydbomni:IMAGE_TAG
מחליפים את מה שכתוב בשדות הבאים:
-
CONTAINER_NAME: השם של מאגר התגים שרוצים ליצור. לדוגמה,alloydb-tde. -
DATA_DIR: הספרייה המקומית להרכבה כנפח הנתונים של AlloyDB Omni. לדוגמה,/local/data. -
VAULT_AUTH_TYPE: סוג האימות שבו יש להשתמש לחיבור למאגר. יש תמיכה רק ב-jwt. -
JWT_AUTH_ENGINE_MOUNT: הנתיב שבו מותקן מנוע האימות של HashiCorp Vault. לדוגמה,/auth/jwt. -
JWT_FILE_PATH: הנתיב שבו שמור ה-JWT של Vault בצמתים. לדוגמה,tde-tls/jwt-token. - (אופציונלי)
VAULT_ROLE: תפקיד הלקוח שמוגדר בהגדרת הכספת ומאפשר ל-HashiCorp Vault לאמת את האותנטיות של אסימון ה-JWT. -
VAULT_CERT_PATH_ON_DISK: הנתיב לאישורי Vault במכונת המארח. לדוגמה,/local/vault/config. -
VAULT_CERT_PATH: הנתיב שבו נמצאים האישורים לחיבור לכספת בתוך הקונטיינר. לדוגמה,/tde-tls. אם לא מגדירים את המדיניות, המערכת תשתמש באישורים במאגר האישורים שמוגדר כברירת מחדל. -
KEK_URL: כתובת ה-URL המלאה של KEK ב-HashiCorp Vault. משתמשים ב-vaultכפרוטוקול כדי לציין את HashiCorp Vault כספק KMS. לדוגמה,vault://127.0.0.1:8200/v1/secrets/data/alloydb_kek. -
IMAGE_TAG: משתמשים ב-18.1.0לקובץ האימג' העדכני של Debian או ב-18.1.0-ubiלקובץ האימג' העדכני של UBI.
הצגת מדדי TDE
אחרי שהאשכול מאותחל, מבצעים את השלבים הבאים כדי לוודא ש-TDE מופעל ולצפות במדדים שקשורים ל-TDE.
- מתחברים למסד הנתונים באמצעות
psqlאו לקוח מועדף. הוראות מפורטות לחיבור למופעים זמינות במאמר הפעלה וחיבור ל-AlloyDB Omni. מריצים את הפקודה הבאה:
select * FROM pgsnap.g$tde_stats;בפלט מוצגים מדדים של TDE, כמו האם TDE מופעל, כתובת ה-URL של KEK, גרסת KEK וחותמת הזמן של יצירת KEK.
בטבלה הבאה מוסבר מה המשמעות של כל מדד.
שם תיאור תווית יחידה סוג alloydb_omni_database_tde_data_blocks_decrypted_count_totalמספר בלוקי הנתונים שפוענחו. לא רלוונטי מונה alloydb_omni_database_tde_data_blocks_encrypted_count_totalמספר בלוקי הנתונים שהוצפנו. לא רלוונטי מונה alloydb_omni_database_tde_data_decryption_time_us_totalהזמן הכולל שנדרש לפענוח בלוק הנתונים. לא רלוונטי מיקרו-שניות מונה alloydb_omni_database_tde_data_encryption_time_us_totalהזמן הכולל שהוקדש להצפנת בלוק נתונים. לא רלוונטי מיקרו-שניות מונה alloydb_omni_database_tde_enabledסטטוס ההפעלה של TDE. לא רלוונטי מד alloydb_omni_database_tde_kek_infoמידע על KEK של TDE. -
kek_version: הגרסה של מפתח ה-KEK
שנמצאת בשימוש לאריזת המפתח. -
kek_url: נתיב מוגדר במלואו
ל-KEK ב-KMS -
kek_creation_timestamp:
זמן היצירה של גרסת ה-KEK שבשימוש.
מד alloydb_omni_database_tde_temp_blocks_decrypted_count_totalמספר החסימות הזמניות שפוענחו. לא רלוונטי מונה alloydb_omni_database_tde_temp_blocks_encrypted_count_totalמספר החסימות הזמניות שהוצפנו. לא רלוונטי מונה alloydb_omni_database_tde_temp_decryption_time_us_totalהזמן הכולל שהוקדש לפענוח של חסימה זמנית. לא רלוונטי מיקרו-שניות מונה alloydb_omni_database_tde_temp_encryption_time_us_totalהזמן הכולל שהוקדש להצפנה של בלוקים זמניים. לא רלוונטי מיקרו-שניות מונה alloydb_omni_database_tde_wal_blocks_decrypted_count_totalמספר בלוקים של WAL שפוענחו. לא רלוונטי מונה alloydb_omni_database_tde_wal_blocks_encrypted_count_totalמספר בלוקים של WAL שהוצפנו. לא רלוונטי מונה alloydb_omni_database_tde_wal_decryption_time_us_totalהזמן הכולל שהוקדש לפענוח של בלוקים ב-WAL. לא רלוונטי מיקרו-שניות מונה alloydb_omni_database_tde_wal_encryption_time_us_totalהזמן הכולל שהוקדש להצפנת בלוקים ב-WAL. לא רלוונטי מיקרו-שניות מונה -