כברירת מחדל, התקנת Cassandra מתבצעת ללא הפעלת אימות. כלומר, כל אחד יכול לגשת ל-Cassandra. אפשר להפעיל את האימות אחרי התקנת Edge, או כחלק מתהליך ההתקנה.
אפשר להוסיף, להסיר ולשנות משתמשים באמצעות הצהרות CREATE/ALTER/DROP USER
של Cassandra. מידע נוסף זמין במאמר פקודות מעטפת של Cassandra SQL.
הפעלת אימות Cassandra במהלך ההתקנה
אפשר להפעיל את אימות Cassandra בזמן ההתקנה.
כדי להפעיל את האימות של Cassandra בזמן ההתקנה, צריך לכלול את המאפיין CASS_AUTH
בקובץ התצורה של כל צמתים של Cassandra:
CASS_AUTH=y # The default value is n.
רכיבי Edge הבאים ניגשים ל-Cassandra:
- שרת ניהול
- מעבדי הודעות
- נתבים
- שרתי Qpid
- שרתי Postgres
כשמתקינים את הרכיבים האלה, צריך להגדיר שם משתמש וסיסמה בקובץ התצורה:
CASS_USERNAME=cassandra_username CASS_PASSWORD=cassandra_password
אפשר לשנות את פרטי הכניסה ל-Cassandra אחרי שתתקינו את Cassandra. עם זאת, אם כבר התקנתם את שרת הניהול, מעבדי ההודעות, הנתב, שרתי Qpid או שרתי Postgres, תצטרכו לעדכן גם את הרכיבים האלה כדי להשתמש בפרטי הכניסה החדשים.
כדי לשנות את פרטי הכניסה ל-Cassandra אחרי התקנת Cassandra:
- מתחברים לצומת אחד של Cassandra באמצעות הכלי
cqlsh
ופרטי הכניסה שמוגדרים כברירת מחדל. צריך לשנות את הסיסמה רק בצומת אחד, והיא תשודר לכל הצמתים של Cassandra ב-ring:/opt/apigee/apigee-cassandra/bin/cqlsh
cassIP 9042 -ucassandra_username -pcassandra_password כאשר:
- cassIP היא כתובת ה-IP של צומת Cassandra.
- 9042 היא יציאת ברירת המחדל של Cassandra.
- כדי לעדכן את הסיסמה, מריצים את הפקודה הבאה בהודעה
cqlsh>
:ALTER USER
cassandra_username/var> WITH PASSWORD ' new_cassandra_password '; - יוצאים מהכלי
cqlsh
, כמו בדוגמה הבאה:exit
- אם עדיין לא התקנתם את שרת הניהול, מעבדי ההודעות, הנתב, שרתי Qpid או שרתי Postgres, צריך להגדיר את המאפיינים הבאים בקובץ התצורה ואז להתקין את הרכיבים האלה:
CASS_USERNAME=
cassandra_username CASS_PASSWORD=new_cassandra_password - אם כבר התקנתם את שרת הניהול, מעבדי ההודעות, הנתב, שרתי Qpid או שרתי Postgres, תוכלו לעיין במאמר איפוס סיסמאות של Edge כדי לעדכן את הרכיבים האלה כך שישתמשו בסיסמה החדשה.
הפעלת אימות Cassandra אחרי ההתקנה
כדי להפעיל אימות אחרי התקנה:
- מתעדכנים את כל רכיבי Edge שמתחברים ל-Cassandra עם שם המשתמש והסיסמה של Cassandra.
- מפעילים אימות בכל צמתים של Cassandra ומגדירים את שם המשתמש והסיסמה של Cassandra בצומת כלשהו. צריך לשנות את פרטי הכניסה רק בצומת אחד של Cassandra, והם ישודרו לכל צומתי Cassandra ב-ring.
עדכון רכיבי Edge שמתחברים ל-Cassandra
כדי לעדכן את פרטי הכניסה החדשים בכל רכיבי Edge שמתקשרים עם Cassandra, מבצעים את התהליך הבא. חשוב לזכור לבצע את השלב הזה לפני שמעדכנים בפועל את פרטי הכניסה של Cassandra:
- בצומת של שרת הניהול, מריצים את הפקודה הבאה:
/opt/apigee/apigee-service/bin/apigee-service edge-management-server store_cassandra_credentials -u
cassandra_username -pcassandra_password אפשר גם להעביר קובץ לפקודה שמכיל את שם המשתמש והסיסמה החדשים:
apigee-service edge-management-server store_cassandra_credentials -f
configFile כאשר השדה configFile מכיל את הפרטים הבאים:
CASS_USERNAME=
cassandra_username # Default is cassandra CASS_PASSWORD='cassandra_password ' # Default is cassandra; wrap in single quotes if it includes special charsהפקודה הזו מפעילה מחדש את שרת הניהול באופן אוטומטי.
- חוזרים על שלב 1 לכל אחד מהשירותים הבאים:
- כל מעבדי ההודעות
- כל הנתב
- כל שרתי Qpid (edge-qpid-server)
- שרתי Postgres (edge-postgres-server)
כשחוזרים על שלב 1 לכל שירות, מחליפים את הערך
edge-management-server
בפקודה שלמעלה בשם השירות המתאים. לדוגמה, כשמבצעים את השלב של שירות Router, משתמשים בפקודה הבאה:/opt/apigee/apigee-service/bin/apigee-service edge-router store_cassandra_credentials -u cassandra -p cassandra
הפעלת אימות
כדי להפעיל את האימות ב-Cassandra ולהגדיר את שם המשתמש והסיסמה:
- יוצרים קובץ תצורה ללא תצוגה עם התוכן הבא:
# Specify IP address or DNS name of cassandra node IP1=192.168.1.1 IP2=192.168.1.2 IP3=192.168.1.3 # Must resolve to IP address or DNS name of host HOSTIP=$(hostname -i) # Set to ‘y’ to enable Cassandra authentication. CASS_AUTH=y # Possible values are ‘y/n’ # Cassandra username. If it does not exist, this user would be created as a SUPERUSER CASS_USERNAME=
cassandra_username # Default value is cassandra - don't use for production # Cassandra Password. If CASS_USERNAME does not exist, create SUPERUSER with this as password CASS_PASSWORD=cassandra_password # Default value is cassandra - don't use for production # Space-separated IP/DNS names of the Cassandra hosts CASS_HOSTS="$IP1:1,1 $IP2:1,1 $IP3:1,1" # Username of an existing C* user. Only needed if you have disabled or changed details of the default cassandra user(‘cassandra’) CASS_EXISTING_USERNAME=existing_cassandra_username # Password of an existing C* user. Only needed if you have disabled or change password of the default cassandra user(‘cassandra’) CASS_EXISTING_PASSWORD=existing_cassandra_password # Cassandra port CASS_PORT=9042 # The default port is 9042. מתחברים לצומת Cassandra הראשון ומריצים את הפקודה הבאה:
apigee-service apigee-cassandra enable_cassandra_authentication -f CONFIG
לחלופין, אפשר להעביר את המאפיינים כארגומנטים של פקודות לסקריפט, כפי שמוצג בדוגמה הבאה:
CASS_AUTH=y HOSTIP=$(hostname -i) CASS_PORT=9042 CASS_EXISTING_USERNAME=
existing_cassandra_username CASS_EXISTING_PASSWORD=existing_cassandra_password CASS_USERNAME=cassandra_username CASS_PASSWORD=cassandra_password CASS_HOSTS="192.168.1.1:1,1 192.168.1.2:1,1 192.168.1.3:1,1" apigee-service apigee-cassandra enable_cassandra_authenticationהערות:
- לפרטי הכניסה שמוגדרים כברירת מחדל ב-Cassandra, הפקודה שלמעלה מפעילה את האימות ב-Cassandra ומפעילה מחדש את Cassandra.
- אם פרטי הכניסה הם לא ברירת המחדל, הפקודה גם משנה את גורם הרפליקציה, יוצרת סופר-משתמש ומריצה תיקון ב-
system_auth keyspace
.
- חוזרים על שלבים 1 ו-2 בכל צמתים של Cassandra.