בדף הזה מוסבר איך ליצור, להציג ולמחוק מסדי נתונים של SQL Server במכונת Cloud SQL.
למופע שנוצר יש מסד נתונים sqlserver.
במאמר בנושא יצירת מופעים מוסבר איך מגדירים ערך ברירת מחדל לסוג אוסף הכללים (collation) שמשמש למסדי הנתונים במופע.
לפני שמתחילים
לפני שמבצעים את המשימות בדף הזה, צריך:
- יצירת מכונה של Cloud SQL. מידע נוסף זמין במאמר יצירת מופעים.
אם אתם מתכננים להשתמש בלקוח sqlcmd כדי ליצור או לנהל את מסדי הנתונים, אתם צריכים:
- הגישה הוגדרה והמכונה מחוברת ללקוח
sqlcmd.
יצירת מסד נתונים במכונה של Cloud SQL
המסוף
-
נכנסים לדף Cloud SQL Instances במסוף Google Cloud .
- כדי לפתוח את הדף סקירה כללית של מכונה, לוחצים על שם המכונה.
- בתפריט הניווט של SQL, בוחרים באפשרות מסדי נתונים.
- לוחצים על יצירת מסד נתונים.
- בתיבת הדו-שיח מסד נתונים חדש, מציינים את שם מסד הנתונים.
- לוחצים על יצירה.
gcloud
מידע נוסף זמין במאמר gcloud
sql databases create.
מידע על כללי השוואה ב-SQL Server זמין במאמר Collation and Unicode Support (כללי השוואה ותמיכה ב-Unicode) במסמכי העזרה של SQL Server.
gcloud sql databases create DATABASE_NAME \ --instance=INSTANCE_NAME \ [--charset=CHARSET] \ [--collation=COLLATION]
Terraform
כדי ליצור מסד נתונים, משתמשים במשאב של Terraform.
החלה של השינויים
כדי להחיל את ההגדרות של Terraform בפרויקט ב- Google Cloud , מבצעים את השלבים בקטעים הבאים.
הכנת Cloud Shell
- מפעילים את Cloud Shell.
-
מגדירים את פרויקט ברירת המחדל שבו רוצים להחיל את ההגדרות של Terraform. Google Cloud
תצטרכו להריץ את הפקודה הזו רק פעם אחת לכל פרויקט, ותוכלו לעשות זאת בכל ספרייה.
export GOOGLE_CLOUD_PROJECT=PROJECT_ID
אם תגדירו ערכים ספציפיים בקובץ התצורה של Terraform, הם יבטלו את ערכי ברירת המחדל של משתני הסביבה.
הכנת הספרייה
לכל קובץ תצורה של Terraform צריכה להיות ספרייה משלו (שנקראת גם מודול ברמה הבסיסית).
-
יוצרים ספרייה חדשה ב-Cloud Shell ובה יוצרים קובץ חדש. שם הקובץ חייב לכלול את הסיומת
.tf, למשלmain.tf. במדריך הזה, הקובץ נקראmain.tf.mkdir DIRECTORY && cd DIRECTORY && touch main.tf
-
אם אתם עוקבים אחרי המדריך, תוכלו להעתיק את הקוד לדוגמה בכל קטע או שלב.
מעתיקים את הקוד לדוגמה בקובץ
main.tfהחדש שיצרתם.לחלופין, אפשר גם להעתיק את הקוד מ-GitHub. כדאי לעשות את זה כשקטע הקוד של Terraform הוא חלק מפתרון מקצה לקצה.
- בודקים את הפרמטרים לדוגמה ומשנים אותם בהתאם לסביבה שלכם.
- שומרים את השינויים.
-
מפעילים את Terraform. צריך לעשות זאת רק פעם אחת לכל ספרייה.
terraform init
אופציונלי: תוכלו לכלול את האפשרות
-upgrade, כדי להשתמש בגרסה העדכנית ביותר של הספק של Google:terraform init -upgrade
החלה של השינויים
-
בודקים את ההגדרות ומוודאים שהמשאבים שמערכת Terraform תיצור או תעדכן תואמים לציפיות שלכם:
terraform plan
מתקנים את ההגדרות לפי הצורך.
-
מריצים את הפקודה הבאה ומזינים
yesבהודעה שמופיעה, כדי להחיל את הגדרות Terraform:terraform apply
ממתינים עד שב-Terraform תוצג ההודעה "Apply complete!".
- פותחים את Google Cloud הפרויקט כדי לראות את התוצאות. במסוף Google Cloud , נכנסים למשאבים בממשק המשתמש כדי לוודא שהם נוצרו או עודכנו ב-Terraform.
מחיקת השינויים
כדי למחוק את השינויים:
- כדי להשבית את ההגנה מפני מחיקה, בקובץ התצורה של Terraform מגדירים את הארגומנט
deletion_protectionלערךfalse.deletion_protection = "false"
- מריצים את הפקודה הבאה ומזינים
yesבהודעה שמופיעה, כדי להחיל את הגדרות Terraform המעודכנות:terraform apply
-
כדי להסיר משאבים שהוחלו בעבר על הגדרות Terraform, מריצים את הפקודה הבאה ומזינים
yesבהודעה שמופיעה:terraform destroy
REST v1
בדוגמה הבאה נעשה שימוש בשיטה databases:insert כדי ליצור מסד נתונים חדש במופע שצוין.
לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:
- project-id: מזהה הפרויקט
- instance-id: מזהה המכונה
- database-name: השם של מסד נתונים בתוך מכונת Cloud SQL
ה-method של ה-HTTP וכתובת ה-URL:
POST https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases
תוכן בקשת JSON:
{
"project": "project-id",
"instance": "instance-id",
"name": "database-name"
}
כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:
אתם אמורים לקבל תגובת JSON שדומה לזו:
REST v1beta4
בדוגמה הבאה נעשה שימוש בשיטה databases:insert כדי ליצור מסד נתונים חדש במופע שצוין.
לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:
- project-id: מזהה הפרויקט
- instance-id: מזהה המכונה
- database-name: השם של מסד נתונים בתוך מכונת Cloud SQL
ה-method של ה-HTTP וכתובת ה-URL:
POST https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases
תוכן בקשת JSON:
{
"project": "project-id",
"instance": "instance-id",
"name": "database-name"
}
כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:
אתם אמורים לקבל תגובת JSON שדומה לזו:
הצגת רשימת מסדי הנתונים
כדי להציג רשימה של כל מסדי הנתונים במופע:
המסוף
-
נכנסים לדף Cloud SQL Instances במסוף Google Cloud .
- כדי לפתוח את הדף סקירה כללית של מכונה, לוחצים על שם המכונה.
- בתפריט צד, לוחצים על מסדי נתונים. בדף Databases מופיעה רשימה של מסדי נתונים, לצד סוג ההשוואה, ערכת התווים וסוג מסד הנתונים.
gcloud
מידע נוסף זמין במאמר gcloud
sql databases list.
gcloud sql databases list \ --instance=INSTANCE_NAME
REST v1
הבקשה הבאה משתמשת בשיטה databases:list כדי להציג את רשימת מסדי הנתונים של מופע.
כשמציגים את רשימת מסדי הנתונים באמצעות ה-API, רואים מסדי נתונים נוספים של תבניות ומסד נתונים של המערכת שלא מוצגים במסוף. אי אפשר למחוק את מסד הנתונים של המערכת או לנהל אותו.
לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:
- project-id: מזהה הפרויקט
- instance-id: מזהה המכונה
ה-method של ה-HTTP וכתובת ה-URL:
GET https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases
כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:
אתם אמורים לקבל תגובת JSON שדומה לזו:
REST v1beta4
הבקשה הבאה משתמשת בשיטה databases:list כדי להציג את רשימת מסדי הנתונים של מופע.
כשמציגים את רשימת מסדי הנתונים באמצעות ה-API, רואים מסדי נתונים נוספים של תבניות ומסד נתונים של המערכת שלא מוצגים במסוף. אי אפשר למחוק את מסד הנתונים של המערכת או לנהל אותו.
לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:
- project-id: מזהה הפרויקט
- instance-id: מזהה המכונה
ה-method של ה-HTTP וכתובת ה-URL:
GET https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases
כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:
אתם אמורים לקבל תגובת JSON שדומה לזו:
שינוי הבעלים של מסד נתונים
אם רוצים להסיר את פרטי הכניסה של משתמש שמשויך לבעלים של מסד נתונים שכבר לא פעיל, צריך קודם להקצות בעלים חדש למסד הנתונים.
כדי להוסיף בעלים חדש למסד הנתונים:
gcloud
- מתחברים למסד הנתונים ויוצרים שני חשבונות הדגמה:
create login TEST_LOGIN with password='TEST_PASSWORD' create login REPORT_USER with password='REPORT_USER_PASSWORD' GRANT CREATE ANY DATABASE TO TEST_LOGIN AS [CustomerDbRootRole]
מחליפים את הפרטים הבאים:
- TEST_LOGIN: השם של חשבון הבדיקה, למשל
test-login. - TEST_PASSWORD: הסיסמה של חשבון הבדיקה.
- REPORT_USER: השם של חשבון משתמש שני, כמו
report-user. החשבון הזה הופך לבעלים החדש של מסד הנתונים. - REPORT_USER_PASSWORD: הסיסמה של חשבון המשתמש השני.
- TEST_LOGIN: השם של חשבון הבדיקה, למשל
- מתחברים למסד הנתונים באמצעות חשבון הבדיקה שיצרתם. לאחר מכן, יוצרים מסד נתונים לבדיקה באמצעות הפקודה הבאה:
CREATE DATABASE TEST_DB
מחליפים את הפרטים הבאים:
- TEST_DB: השם של מסד הנתונים לבדיקה שרוצים ליצור, למשל
test-database - TEST_LOGIN: השם של חשבון הבדיקה, למשל
test-login.
הבעלים של מסד הנתונים מוגדר אוטומטית לחשבון הבדיקה.
- TEST_DB: השם של מסד הנתונים לבדיקה שרוצים ליצור, למשל
- מתחברים למסד הנתונים באמצעות פרטי ההתחברות ל-SQL Server. לאחר מכן, מריצים את הפקודה הבאה כדי לנסות להסיר את פרטי הכניסה
TEST_LOGIN:drop login TEST_LOGIN
מחליפים את TEST_LOGIN בשם של חשבון הבדיקה, למשל
test-login.הפעולה נכשלת ומוחזרת השגיאה הבאה:
- מתחברים למסד הנתונים
TEST_DBבתור חשבוןREPORT_USERומעניקים לחשבון הרשאות שתואמות להרשאות של הבעלים הקיים.GRANT IMPERSONATE on LOGIN::REPORT_USER to TEST_LOGIN
- מתחברים למסד הנתונים בתור חשבון הבדיקה. לאחר מכן, מריצים את הפקודה הבאה כדי להעניק לחשבון השני הרשאה כבעלים של מסד הנתונים:
ALTER AUTHORIZATION ON DATABASE::TEST_DB TO REPORT_USER
- מתחברים למסד הנתונים בתור
REPORT_USERומסירים את כל ההרשאות שניתנו.REVOKE IMPERSONATE on LOGIN::REPORT_USER to TEST_LOGIN
- מתחברים למסד הנתונים בתור חשבון SQL Server. לאחר מכן, מריצים את הפקודה הבאה כדי להסיר את פרטי הכניסה של
TEST_LOGIN: בסיום, מוחזרת ההודעה הבאה:DROP LOGIN TEST_LOGIN
DROP LOGIN for TEST_LOGIN by sqlserver(sqlserver) is successful.
מחיקה של מסד נתונים
כדי למחוק מסד נתונים במכונת Cloud SQL:
המסוף
-
נכנסים לדף Cloud SQL Instances במסוף Google Cloud .
- כדי לפתוח את הדף סקירה כללית של מכונה, לוחצים על שם המכונה.
- בתפריט צד, לוחצים על מסדי נתונים.
- ברשימת מסדי הנתונים, מוצאים את מסד הנתונים שרוצים למחוק ולוחצים על סמל האשפה.
- בתיבת הדו-שיח מחיקת מסד נתונים, מזינים את שם מסד הנתונים ולוחצים על מחיקה.
gcloud
מידע נוסף זמין במאמר gcloud
sql databases delete.
gcloud sql databases delete DATABASE_NAME \ --instance=INSTANCE_NAME
REST v1
בדוגמה הבאה של בקשה נעשה שימוש בשיטה databases:delete כדי למחוק את מסד הנתונים שצוין.
לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:
- project-id: מזהה הפרויקט
- instance-id: מזהה המכונה
- database-name: השם של מסד נתונים בתוך מכונת Cloud SQL
ה-method של ה-HTTP וכתובת ה-URL:
DELETE https://sqladmin.googleapis.com/v1/projects/project-id/instances/instance-id/databases/database-name
כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:
אתם אמורים לקבל תגובת JSON שדומה לזו:
REST v1beta4
בדוגמה הבאה של בקשה נעשה שימוש בשיטה databases:delete כדי למחוק את מסד הנתונים שצוין.
לפני שמשתמשים בנתוני הבקשה, צריך להחליף את הנתונים הבאים:
- project-id: מזהה הפרויקט
- instance-id: מזהה המכונה
- database-name: השם של מסד נתונים בתוך מכונת Cloud SQL
ה-method של ה-HTTP וכתובת ה-URL:
DELETE https://sqladmin.googleapis.com/sql/v1beta4/projects/project-id/instances/instance-id/databases/database-name
כדי לשלוח את הבקשה צריך להרחיב אחת מהאפשרויות הבאות:
אתם אמורים לקבל תגובת JSON שדומה לזו:
פתרון בעיות
אם סימון נתונים שהשתנו (CDC) מופעל במסד נתונים, ואתם מנסים למחוק אותו מהמופע, הפעולה תיכשל. יכול להיות שתקבלו גם הודעת שגיאה לא ידועה. אם זה קורה, צריך לבצע את השלבים הבאים:
- משתמשים בהליך המאוחסן
msdb.dbo.gcloudsql_cdc_disable_dbכדי להשבית את CDC עבור מסד הנתונים. - בודקים אם שרת מקושר מוגדר למסד הנתונים. אם יש כזה, משמיטים אותו.
- מפעילים שוב את פעולת המחיקה.
מידע נוסף זמין במאמר בנושא מחיקת מסד נתונים של CDC.
המאמרים הבאים
- ניהול משתמשים במופע.
- מייבאים נתונים למופע.
- יצירת טבלאות (Database Engine).
נסו בעצמכם
אנחנו ממליצים למשתמשים חדשים ב-Google Cloud ליצור חשבון כדי שיוכלו להעריך את הביצועים של Cloud SQL בתרחישים מהעולם האמיתי. לקוחות חדשים מקבלים בחינם גם קרדיט בשווי 300 $להרצה, לבדיקה ולפריסה של עומסי העבודה.
להתנסות ב-Cloud SQL בחינם