מידע על מדיניות בנושא סיסמאות
אם משתמשי מסד הנתונים של האפליקציה מאומתים באמצעות AlloyDB Omni בשיטה המובנית שמבוססת על סיסמה, אתם יכולים לחייב שימוש בסיסמאות חזקות כדי לשפר את אבטחת האימות. אפשר להגדיר ולאפשר אכיפה של סיסמאות על ידי הגדרת מדיניות סיסמאות ב-AlloyDB Omni.
מגבלות של מדיניות הסיסמאות
אלו המגבלות שחלות על מדיניות הסיסמאות ב-AlloyDB Omni:
מדיניות הסיסמאות חלה רק על סיסמאות שנוצרו אחרי שהגדרתם את המדיניות. שינוי במדיניות הסיסמאות לא משפיע על סיסמאות קיימות של משתמשים.
מדיניות הסיסמאות חלה רק על סיסמאות שמוזנות כטקסט פשוט. המדיניות בנושא סיסמאות לא חלה על סיסמאות שמוזנות כמחרוזות מוצפנות.
הגדרת מדיניות סיסמאות ב-AlloyDB Omni
כדי להגדיר מדיניות סיסמאות, צריך לעדכן את פרמטרי הסיסמה של Grand Unified Configuration (GUC) בקובץ התצורה postgresql.conf. במאמר הגדרת פלאגים של מסד נתונים ב-AlloyDB Omni מוסבר איך להגדיר פרמטר GUC.
מדיניות סיסמאות ל-AlloyDB Omni יכולה לכלול את האפשרויות הבאות:
איסור שימוש בשם המשתמש: מונע שימוש בשם המשתמש בסיסמה.
מורכבות הסיסמה: בדקו אם הסיסמה מכילה את מספר התווים המותר של אותיות קטנות, אותיות גדולות, ספרות ותווים לא אלפאנומריים. כדאי גם לבדוק אם אורך הסיסמה תקין.
תוקף הסיסמה: חשוב לוודא שהסיסמאות מתחלפות באופן קבוע.
רשימה של הדגלים של מדיניות הסיסמאות שנתמכים ב-AlloyDB Omni מופיעה במאמר בנושא דגלים של מדיניות הסיסמאות.
כדי לעמוד בתקני האבטחה ולפעול בהתאם להמלצות של כלי האבטחה, צריך להפעיל את כל שלוש האפשרויות יחד על ידי הגדרת דגלי האכיפה הראשיים שלהן לערך ON:
password.enforce_password_does_not_contain_usernamepassword.enforce_complexitypassword.enforce_expiration
אם מגדירים את אחד משלושת ה-flags האלה לערך OFF או משמיטים אותם, כלי המלצות האבטחה מסמן את המופע ככזה שלא מופעלת בו מדיניות סיסמאות.
טעינה מראש של ספריית אימות הסיסמאות
כדי שמדיניות הסיסמאות תיכנס לתוקף ב-AlloyDB Omni, צריך לטעון את הספרייה alloydb_password_validation. כדי לטעון את הספרייה הזו:
פועלים לפי השלבים הבאים:
מאתרים את קובץ ההגדרות
postgresql.confשל ההתקנה של AlloyDB Omni ופותחים אותו בכלי לעריכת טקסט.מחפשים את השורה
shared_preload_librariesובודקים אם היא כוללת אתalloydb_password_validation. אם לא, צריך להוסיף אותה. בסיום, השורהshared_preload_librariesתיראה בערך כך:shared_preload_libraries='google_columnar_engine,google_job_scheduler,google_storage,alloydb_password_validation'
אכיפת סיסמאות מורכבות
כדי לאכוף מדיניות בנושא מורכבות סיסמאות:
מוודאים שקובץ
postgresql.confטוען מראש את ספריית אימות הסיסמה.מגדירים את הדגל
password.enforce_complexityלערךON.משתמשים בדגלים של מדיניות הסיסמאות כדי להגדיר את מדיניות הסיסמאות.
לדוגמה, כדי לאכוף מדיניות סיסמאות שקובעת שסיסמה חייבת להכיל לפחות אות גדולה אחת, מספר אחד ולהיות באורך של 10 תווים לפחות, צריך להגדיר את הערכים הבאים בקובץ postgresql.conf:
password.enforce_complexity = ONpassword.min_uppercase_letters = 1password.min_numerical_chars = 1password.min_pass_length = 10
אחרי שמגדירים את הדגלים האלה, ניסיון להגדיר סיסמה למשתמש במסד נתונים שלא עומדת בדרישות של מדיניות הסיסמאות הזו ייכשל. לדוגמה, אם המדיניות הזו מוגדרת, הפקודה הבאה של הלקוח psql נכשלת כי הסיסמה foo קצרה מ-10 תווים ולא מכילה מספר או אות רישית.
CREATE USER USERNAME WITH PASSWORD foo;
אכיפת תפוגת תוקף של סיסמאות
כדי לאכוף את מדיניות תפוגת הסיסמאות:
מוודאים שקובץ
postgresql.confטוען מראש את ספריית אימות הסיסמה.מגדירים את הדגל
password.enforce_expirationלערךON.מגדירים את הדגל
password.expiration_in_daysלמספר הימים שאחריו הסיסמה תפוג.מגדירים את הדגל
password.notify_expiration_in_daysלמספר הימים לפני פקיעת התוקף של הסיסמה שבהם המשתמש מתחיל לקבל התראות על פקיעת התוקף של הסיסמה.
לדוגמה, כדי לאכוף מדיניות סיסמאות שקובעת שתוקף הסיסמאות יפוג אחרי 30 ימים ושהמשתמשים יקבלו התראה 15 ימים לפני שתוקף הסיסמה שלהם יפוג, צריך להגדיר את הערכים הבאים בקובץ postgresql.conf:
password.enforce_expiration = ONpassword.expiration_in_days = 30password.notify_expiration_in_days = 15
אם תוקף הסיסמה של משתמש פג, המשתמש לא יכול להתחבר ל-AlloyDB Omni. כדי לאפס את הסיסמה של משתמש:
מתחברים ל-AlloyDB Omni באמצעות
psql. לדוגמה, אם התקנתם את AlloyDB Omni באמצעות Docker, מריצים את הפקודה הבאה:sh docker exec -it CONTAINER-NAME psql -h localhost -U postgresבהנחיה
postgres=#, מריצים את הפקודה הבאה:ALTER USER USERNAME WITH 'NEW-PASSWORD';
מידע נוסף על שינוי סיסמה של משתמש זמין במאמר בנושא ALTER ROLE במסמכי התיעוד של PostgreSQL.
אי אפשר להשתמש בשמות משתמש בסיסמאות
כדי לאכוף את המדיניות שמונעת מסיסמה להכיל שם משתמש:
מוודאים שקובץ
postgresql.confטוען מראש את ספריית אימות הסיסמה.מגדירים את
password.enforce_password_does_not_contain_usernameלערךON.
לדוגמה, כדי לוודא שסיסמה לא מכילה שם משתמש כמחרוזת משנה, מגדירים את הערך הבא בקובץ postgresql.conf:
password.enforce_password_does_not_contain_username = ON
אם הדגל הזה מוגדר, הפעולה הבאה נכשלת כי הסיסמה alex-secret מכילה את שם המשתמש alex:
CREATE USER alex WITH PASSWORD 'alex-secret';