חשבון שירות הוא חשבון Google מיוחד לא אנושי שאפליקציות, תהליכים אוטומטיים או עומסי עבודה, כמו מכונה של Compute Engine, משתמשים בו כדי לבצע קריאות מורשות ל-API. בניגוד לחשבונות משתמשים, חשבון שירות מזוהה רק באמצעות כתובת האימייל הייחודית שלו.
אפליקציות משתמשות בחשבונות שירות כדי לבצע אימות ולקבל גישה למשאבים ב-Google Cloud . כשאפליקציה מבצעת אימות באמצעות חשבון שירות, היא מקבלת גישה למשאבים שהוקצו לחשבון השירות הרשאות מפורשות לניהול זהויות והרשאות גישה (IAM). השיטה הזו מספקת אימות מאובטח, ניתן לביקורת ומרכזי של מכונה למכונה.
ב-Secure Web Proxy, חשבונות שירות ממלאים תפקיד חשוב בהרשאה ובאכיפת מדיניות. כשמשתמשים בחשבון שירות כדי לזהות את מקור התנועה של עומס עבודה, אפשר ליצור מדיניות מפורטת של Secure Web Proxy שמאפשרת או חוסמת תנועת אינטרנט באופן ספציפי על סמך הזהות של האפליקציה, ולא רק על סמך כתובת ה-IP שלה.
בדף הזה מוסבר איך:
- יצירת מופע של Secure Web Proxy עם מדיניות ריקה
- יצירה של חשבון שירות והקצאת תפקידים ב-IAM
- יצירת כללים של Secure Web Proxy
- בדיקת הקישוריות של כל ההגדרה של Secure Web Proxy
לפני שמתחילים
משלימים את השלבים להגדרה הראשונית.
שולחים בקשה למנהל חשבון ארגוני לתת לכם גישה לחשבון שירות.
מוודאים שמותקנת אצלכם גרסה 406.0.0 או גרסה מתקדמת יותר של Google Cloud CLI:
gcloud version | head -n1אם מותקנת אצלכם גרסה קודמת של ה-CLI של gcloud, צריך לעדכן את הגרסה:
gcloud components update --version=406.0.0
יצירת מופע של Secure Web Proxy עם מדיניות ריקה
כדי ליצור מופע של Secure Web Proxy, צריך קודם ליצור מדיניות אבטחה ריקה ואז ליצור פרוקסי אינטרנט שמשתמש במדיניות הזו.
יצירה של מדיניות אבטחה ריקה
המסוף
נכנסים לדף SWP Policies במסוף Google Cloud .
לוחצים על יצירת מדיניות.
בשדה Name, מזינים שם למדיניות, כמו
myswppolicy.בשדה Description (תיאור) מזינים תיאור למדיניות, למשל
My new swp policy.בקטע אזורים, בוחרים את האזור שבו רוצים ליצור את המדיניות, כמו
us-central1.לוחצים על יצירה.
Cloud Shell
משתמשים בעורך הטקסט המועדף כדי ליצור קובץ
policy.yaml.מוסיפים את הטקסט הבא לקובץ
policy.yamlשיצרתם:name: projects/PROJECT_NAME/locations/REGION/gatewaySecurityPolicies/POLICY_NAME description: POLICY_DESCRIPTIONמחליפים את מה שכתוב בשדות הבאים:
PROJECT_NAME: שם הפרויקט
REGION: האזור שבו נוצרה המדיניות, למשלus-central1
POLICY_NAME: שם המדיניות
POLICY_DESCRIPTION: תיאור המדיניות
מייבאים את מדיניות האבטחה באמצעות הפקודה
gcloud network-security gateway-security-policies import:gcloud network-security gateway-security-policies import POLICY_NAME \ --source=POLICY_FILE.yaml \ --location=REGION
יצירת שרת proxy לאינטרנט
המסוף
נכנסים לדף Web Proxies במסוף Google Cloud .
לוחצים על יצירת שרת proxy מאובטח לאינטרנט.
בשדה Name, מזינים שם לשרת ה-proxy לאינטרנט, למשל
myswp.בשדה Description (תיאור) מזינים תיאור לשרת ה-proxy לאינטרנט, כמו
My new swp.בקטע מצב ניתוב, בוחרים באחת מהאפשרויות הבאות:
- מפורש: פריסת מופע Secure Web Proxy במצב שרת proxy מפורש.
- הצעד הבא: פריסת מופע Secure Web Proxy במצב 'הצעד הבא'.
בקטע Regions (אזורים), בוחרים את האזור שבו רוצים ליצור את שרת ה-proxy לאינטרנט, כמו
us-central1.בקטע רשת, בוחרים את הרשת שבה רוצים ליצור את שרת ה-proxy לאינטרנט.
בשדה Subnetwork (תת-רשת), בוחרים את תת-הרשת של ה-VPC שיצרתם במהלך ההגדרה הראשונית.
אופציונלי: בשדה כתובת ה-IP של שרת ה-proxy לאינטרנט, מזינים את כתובת ה-IP של Secure Web Proxy.
אפשר להזין כתובת IP מתוך טווח כתובות ה-IP של Secure Web Proxy שנמצאות ברשת המשנה שיצרתם בשלב הקודם. אם לא תזינו את כתובת ה-IP, המופע של Secure Web Proxy יבחר באופן אוטומטי כתובת IP מתוך תת-הרשת שנבחרה.
בקטע Certificate, בוחרים את האישור שרוצים להשתמש בו כדי ליצור את פרוקסי האינטרנט.
בקטע מדיניות, בוחרים את המדיניות שיצרתם כדי לשייך את שרת ה-proxy לאינטרנט.
לוחצים על יצירה.
Cloud Shell
משתמשים בעורך הטקסט המועדף כדי ליצור קובץ
gateway.yaml.מוסיפים את הטקסט הבא לקובץ
gateway.yaml:name: projects/PROJECT_NAME/locations/REGION/gateways/GATEWAY_NAME type: SECURE_WEB_GATEWAY ports: [GATEWAY_PORT_NUMBERS] certificateUrls: [CERTIFICATE_URLS] gatewaySecurityPolicy: projects/PROJECT_NAME/locations/REGION/gatewaySecurityPolicies/POLICY_NAME network: projects/PROJECT_NAME/global/networks/NETWORK_NAME subnetwork: projects/PROJECT_NAME/regions/REGION/subnetworks/SUBNETWORK routingMode: ROUTING_MODE addresses: [GATEWAY_IP_ADDRESS] scope: samplescopeמחליפים את מה שכתוב בשדות הבאים:
GATEWAY_NAME: השם של מופע Secure Web Proxy
GATEWAY_PORT_NUMBERS: רשימה של מספרי יציאות לשער הזה, למשל[80,443]
CERTIFICATE_URLS: רשימה של כתובות URL של אישורי SSL
SUBNETWORK: רשת משנה של VPC שיצרתם במהלך ההגדרה הראשונית
ROUTING_MODE: מציינים את מצב הניתוב הנדרש של שרת ה-Proxy לאינטרנט:-
EXPLICIT_ROUTING_MODE: פריסת מופע Secure Web Proxy במצב שרת proxy מפורש -
NEXT_HOP_ROUTING_MODE: פריסת מופע Secure Web Proxy במצב next hop
-
GATEWAY_IP_ADDRESS: רשימה אופציונלית של כתובות IP של מופעי Secure Web Proxy ברשתות המשנה של ה-proxy שיצרתם קודם בשלבי ההגדרה הראשוניתאם אתם בוחרים לא לפרט כתובות IP, אל תמלאו את השדה כדי לאפשר לשרת ה-proxy לבחור כתובת IP בשבילכם.
יוצרים את מופע Secure Web Proxy באמצעות הפקודה
gcloud network-services gateways import:gcloud network-services gateways import GATEWAY_NAME \ --source=gateway.yaml \ --location=REGION
בדיקת הקישוריות
כדי לבדוק את הקישוריות, משתמשים בפקודה curl מכל מופע של מכונה וירטואלית (VM) ברשת הענן הווירטואלי הפרטי (VPC):
curl -x https://GATEWAY_IP_ADDRESS:PORT_NUMBER https://www.example.com --proxy-insecure
אם הכול פועל בצורה תקינה, מופע Secure Web Proxy מחזיר קוד סטטוס 403 Forbidden. השגיאה הזו מאשרת את הפרטים הבאים:
הפריסה של מופע Secure Web Proxy הושלמה בהצלחה והוא מקבל תנועה באופן פעיל.
מדיניות Secure Web Proxy אוכפת בצורה נכונה את מצב האבטחה שמוגדר כברירת מחדל, שבו כל התנועה נדחית עד שמגדירים כללי
allowספציפיים בקטעים הבאים.
יצירה של חשבון שירות והקצאת תפקידי IAM
יצירת חשבון שירות: משתמשים בפקודה
gcloud iam service-accounts createכדי ליצור חשבון שירות בשםmy-swp-saבפרויקט Google Cloud.gcloud iam service-accounts create my-swp-sa \ --display-name="Secure Web Proxy service account" \ --description="Service account for Secure Web Proxy instances"
הקצאת תפקידי IAM לחשבון השירות: משתמשים בפקודה
gcloud projects add-iam-policy-bindingכדי להקצות את תפקידי ה-IAM הנדרשים לחשבון השירות, כדי שהוא יוכל לנהל משאבים ב Google Cloud פרויקט או להשתמש בהם.לדוגמה, כדי לאפשר לחשבון השירות להשתמש במשאבי רשת, צריך לתת לו את התפקיד Compute Network User (
roles/compute.networkUser).gcloud projects add-iam-policy-binding PROJECT_ID \ --member="serviceAccount:my-swp-sa@PROJECT_ID.iam.gserviceaccount.com" \ --role="roles/compute.networkUser"
מחליפים את
PROJECT_IDבמזהה שלGoogle Cloud הפרויקט.
יצירת כלל של Secure Web Proxy
המסוף
נכנסים לדף SWP Policies במסוף Google Cloud .
לוחצים על שם המדיניות שיצרתם קודם, למשל
myswppolicy.לוחצים על הוספת כלל.
לכל כלל, מבצעים את הפעולות הבאות:
בשדה עדיפות, מזינים את סדר ההערכה המספרי של הכלל. הכללים מוערכים מהעדיפות הגבוהה ביותר לנמוכה ביותר, כאשר
0היא העדיפות הגבוהה ביותר.בשדה Name, מזינים שם לכלל.
בשדה Description (תיאור), מזינים תיאור לכלל.
בקטע פעולה, בוחרים באחת מהאפשרויות הבאות:
- אישור: כדי לאשר בקשות לחיבור שתואמות לכלל.
- Deny: כדי לדחות בקשות לחיבור שתואמות לכלל.
בשדה סטטוס, בוחרים אחת מהאפשרויות הבאות לאכיפת הכלל:
- מופעלת: כדי לאכוף את הכלל במופע Secure Web Proxy.
- מושבת: כדי לא לאכוף את הכלל במופע של Secure Web Proxy.
בקטע Session Match, מציינים את כתובת האימייל של חשבון השירות שיצרתם קודם. לדוגמה:
sessionMatcher: "source.matchServiceAccount(SERVICE_ACCOUNT) && host() == 'example.com'"מידע נוסף על התחביר של
SessionMatcherזמין במאמר הפניה לשפת ההתאמה של CEL.בקטע Application Match, מציינים את הקריטריונים להתאמת הבקשה.
לוחצים על הוספת כלל.
כדי להוסיף עוד כלל, לוחצים על הוספת כלל.
Cloud Shell
משתמשים בעורך הטקסט המועדף כדי ליצור את הקובץ
rule.yaml.כדי לאפשר גישה לכתובת URL מחשבון השירות המתאים, מוסיפים את הקוד הבא לקובץ
rule.yamlשיצרתם:name: projects/PROJECT_NAME/locations/REGION/gatewaySecurityPolicies/POLICY_NAME/rules/RULE_NAME description: RULE_DESCRIPTION enabled: true priority: RULE_PRIORITY sessionMatcher: CEL_EXPRESSION basicProfile: ALLOWמחליפים את מה שכתוב בשדות הבאים:
-
RULE_NAME: השם של הכלל -
RULE_DESCRIPTION: תיאור הכלל -
RULE_PRIORITY: העדיפות של הכלל הזה. מספר נמוך יותר מייצג עדיפות גבוהה יותר. -
CEL_EXPRESSION: ביטוי של Common Expression Language (CEL). מידע נוסף זמין במאמר בנושא הפניה לשפת ההתאמה של CEL.
לדוגמה, כדי לאפשר גישה ל-
example.comמהמשאב עם חשבון השירות הנדרש, מוסיפים את השורות הבאות לקובץ ה-YAML שיצרתם עבורsessionMatcher:```yaml sessionMatcher: "source.matchServiceAccount('SERVICE_ACCOUNT') && host() == 'example.com'" ```מחליפים את
SERVICE_ACCOUNTבחשבון השירות שרוצים לאפשר. זו חייבת להיות כתובת האימייל של חשבון השירות.-
מייבאים את הכללים שיצרתם באמצעות הפקודה
gcloud network-security gateway-security-policies rules import:gcloud network-security gateway-security-policies rules import RULE_NAME \ --source=RULE_FILE.yaml \ --location=REGION \ --gateway-security-policy=POLICY_NAME
בדיקת הקישוריות
אפשר לבדוק שוב את הקישוריות כדי לוודא שכל ההגדרות של Secure Web Proxy – כולל חשבון השירות, כללי מדיניות האבטחה והשער – פועלות כמצופה.
כדי לבדוק את הקישוריות, משתמשים בפקודה curl מהמשאב – כמו מכונת VM – עם SERVICE_ACCOUNT המצורף:
curl -x https://IPv4_ADDRESS:443 http://example.com
--proxy-insecure
מחליפים את IPv4_ADDRESS בכתובת ה-IPv4 של מופע Secure Web Proxy.
אם הכול פועל כמו שצריך, תקבלו קוד סטטוס 200 OK. קוד הסטטוס הזה מאשר את התוצאות העיקריות הבאות:
הרשאה מוצלחת: מוכיחה שהתנועה שמגיעה מהמשאב מזוהה בצורה נכונה על ידי חשבון השירות שהוקצה, ושהזהות הזו תואמת לכלל
allowשהוספתם למדיניות האבטחה.פונקציונליות מקצה לקצה: המערכת בודקת שהתנועה עוברת בצורה תקינה בנתיב שהוגדר – מהמשאב > למופע של Secure Web Proxy > עוברת את מדיניות האבטחה > ומגיעה ליעד החיצוני.