התבנית Cloud Storage to Elasticsearch היא צינור (pipeline) של אצווה שקורא נתונים מקובצי CSV שמאוחסנים בקטגוריה של Cloud Storage וכותב את הנתונים ל-Elasticsearch כמסמכי JSON.
הדרישות לגבי צינורות עיבוד נתונים
- הקטגוריה של Cloud Storage צריכה להתקיים.
- צריך שיהיה קיים מארח Elasticsearch במופע של Google Cloud Platform או ב-Elasticsearch Cloud שאפשר לגשת אליו מ-Dataflow.
- צריכה להיות קיימת טבלה ב-BigQuery לפלט של שגיאות.
סכימת CSV
אם קובצי ה-CSV מכילים כותרות, צריך להגדיר את פרמטר התבנית containsHeaders
לערך true.
אחרת, יוצרים קובץ סכימת JSON שמתאר את הנתונים. מציינים את ה-URI של Cloud Storage של קובץ הסכימה בפרמטר התבנית jsonSchemaPath. בדוגמה הבאה מוצגת סכימת JSON:
[{"name":"id", "type":"text"}, {"name":"age", "type":"integer"}]
לחלופין, אפשר לספק פונקציה בהגדרת המשתמש (UDF) שמנתחת את טקסט ה-CSV ומפיקה מסמכי Elasticsearch.
פרמטרים של תבניות
פרמטרים נדרשים
- deadletterTable: טבלת ה-dead-letter ב-BigQuery שאליה יישלחו הוספות שנכשלו. לדוגמה,
your-project:your-dataset.your-table-name. - inputFileSpec: תבנית הקובץ ב-Cloud Storage לחיפוש קובצי CSV. לדוגמה,
gs://mybucket/test-*.csv. - connectionUrl: כתובת ה-URL של Elasticsearch בפורמט
https://hostname:[port]. אם משתמשים ב-Elastic Cloud, צריך לציין את CloudID. לדוגמה,https://elasticsearch-host:9200. - apiKey: מפתח ה-API בקידוד Base64 שמשמש לאימות.
- index: האינדקס של Elasticsearch שאליו מופנות הבקשות. לדוגמה,
my-index.
פרמטרים אופציונליים
- inputFormat: הפורמט של קובץ הקלט. ברירת המחדל היא
CSV. - containsHeaders: קובצי ה-CSV של הקלט מכילים רשומת כותרת (true/false). נדרש רק אם קוראים קובצי CSV. ברירת המחדל היא: false.
- delimiter: תו ההפרדה בין העמודות בקובצי הטקסט של הקלט. ברירת מחדל:
,לדוגמה,,. - csvFormat: מפרט של פורמט CSV לשימוש בניתוח רשומות. ברירת המחדל היא:
Default. פרטים נוספים זמינים בכתובת https://commons.apache.org/proper/commons-csv/apidocs/org/apache/commons/csv/CSVFormat.html. השם חייב להיות זהה בדיוק לפורמט שמופיע בכתובת: https://commons.apache.org/proper/commons-csv/apidocs/org/apache/commons/csv/CSVFormat.Predefined.html. - jsonSchemaPath: הנתיב לסכימת ה-JSON. ברירת המחדל היא
null. לדוגמה,gs://path/to/schema. - largeNumFiles: מגדירים את הערך true אם מספר הקבצים הוא עשרות אלפים. ברירת המחדל היא
false. - csvFileEncoding: פורמט קידוד התווים של קובץ ה-CSV. הערכים המותרים הם
US-ASCII,ISO-8859-1,UTF-8ו-UTF-16. ברירת המחדל היא UTF-8. - logDetailedCsvConversionErrors: מגדירים את הערך
trueכדי להפעיל רישום מפורט של שגיאות ביומן כשהניתוח של קובץ ה-CSV נכשל. שימו לב: יכול להיות שהפעולה הזו תחשוף מידע אישי רגיש ביומנים (לדוגמה, אם קובץ ה-CSV מכיל סיסמאות). ברירת מחדל:false. - elasticsearchUsername: שם המשתמש ב-Elasticsearch לאימות. אם מציינים את המאפיין
apiKey, המערכת מתעלמת מהערך שלו. - elasticsearchPassword: סיסמת Elasticsearch לאימות. אם מציינים את המאפיין
apiKey, המערכת מתעלמת מהערך שלו. - batchSize: גודל האצווה במספר המסמכים. ברירת המחדל היא
1000. - batchSizeBytes: גודל הקבוצה במספר בייטים. ברירת המחדל היא
5242880(5MB). - maxRetryAttempts: המספר המקסימלי של ניסיונות חוזרים. הערך חייב להיות גדול מאפס. ברירת המחדל היא
no retries. - maxRetryDuration: משך הניסיון החוזר המקסימלי באלפיות השנייה. הערך חייב להיות גדול מאפס. ברירת המחדל היא
no retries. - propertyAsIndex: המאפיין במסמך שמבוצע בו אינדוקס, שהערך שלו מציין מטא-נתונים של
_indexשייכללו במסמך בבקשות בכמות גדולה. מקבל עדיפות על פני UDF של_index. ברירת המחדל היאnone. - javaScriptIndexFnGcsPath: הנתיב ב-Cloud Storage למקור של פונקציית JavaScript UDF שמציינת מטא-נתונים של
_indexשייכללו במסמך בבקשות בכמות גדולה. ברירת המחדל היאnone. - javaScriptIndexFnName: השם של פונקציית ה-JavaScript של ה-UDF שמציינת מטא-נתונים של
_indexשיש לכלול במסמך בבקשות בכמות גדולה. ברירת המחדל היאnone. - propertyAsId: מאפיין במסמך שמבצעים עליו אינדוקס, שהערך שלו מציין
_idמטא-נתונים שייכללו עם המסמך בבקשות בכמות גדולה. מקבל עדיפות על פני UDF של_id. ברירת המחדל היאnone. - javaScriptIdFnGcsPath: הנתיב ב-Cloud Storage למקור של פונקציית ה-UDF ב-JavaScript, שמציין מטא-נתונים של
_idשייכללו במסמך בבקשות בכמות גדולה. ברירת המחדל היאnone. - javaScriptIdFnName: השם של פונקציית ה-UDF ב-JavaScript שמציינת את המטא-נתונים של
_idשייכללו במסמך בבקשות בכמות גדולה. ברירת המחדל היאnone. - javaScriptTypeFnGcsPath: הנתיב ב-Cloud Storage למקור של פונקציית JavaScript UDF שמציינת מטא-נתונים מסוג
_typeשיש לכלול במסמכים בבקשות בכמות גדולה. ברירת המחדל היאnone. - javaScriptTypeFnName: השם של פונקציית ה-JavaScript של ה-UDF שמציינת את המטא-נתונים של
_typeשיש לכלול במסמך בבקשות בכמות גדולה. ברירת המחדל היאnone. - javaScriptIsDeleteFnGcsPath: הנתיב ב-Cloud Storage למקור של פונקציית ה-UDF ב-JavaScript, שקובעת אם למחוק את המסמך במקום להוסיף או לעדכן אותו. הפונקציה מחזירה מחרוזת עם הערך
trueאוfalse. ברירת המחדל היאnone. - javaScriptIsDeleteFnName: השם של פונקציית ה-JavaScript של ה-UDF שקובעת אם למחוק את המסמך במקום להוסיף או לעדכן אותו. הפונקציה מחזירה מחרוזת עם הערך
trueאוfalse. ברירת המחדל היאnone. - usePartialUpdate: האם להשתמש בעדכונים חלקיים (עדכון במקום יצירה או הוספה לאינדקס, שמאפשרים מסמכים חלקיים) בבקשות Elasticsearch. ברירת המחדל היא
false. - bulkInsertMethod: האם להשתמש ב-
INDEX(index, allows upserts) או ב-CREATE(create, errors on duplicate _id) עם בקשות בכמות גדולה של Elasticsearch. ברירת המחדל היאCREATE. - trustSelfSignedCerts: האם לתת אמון באישור בחתימה עצמית או לא. יכול להיות שמופע Elasticsearch שהותקן כולל אישור בחתימה עצמית. כדי לעקוף את האימות של אישור ה-SSL, צריך להגדיר את האפשרות הזו כ-True. (ברירת המחדל:
false). - disableCertificateValidation: אם הערך הוא
true, המערכת נותנת אמון באישור ה-SSL בחתימה עצמית. יכול להיות שלמופע Elasticsearch יש אישור בחתימה עצמית. כדי לעקוף את האימות של האישור, מגדירים את הפרמטר הזה לערךtrue. ברירת המחדל היאfalse. - apiKeyKMSEncryptionKey: מפתח Cloud KMS לפענוח מפתח ה-API. חובה לכלול את הפרמטר הזה אם הערך של
apiKeySourceהואKMS. אם הפרמטר הזה מסופק, צריך להעביר מחרוזתapiKeyמוצפנת. הצפנת פרמטרים באמצעות נקודת הקצה להצפנה ב-KMS API. למפתח, משתמשים בפורמטprojects/<PROJECT_ID>/locations/<KEY_REGION>/keyRings/<KEY_RING>/cryptoKeys/<KMS_KEY_NAME>. למידע נוסף: https://cloud.google.com/kms/docs/reference/rest/v1/projects.locations.keyRings.cryptoKeys/encrypt לדוגמה,projects/your-project-id/locations/global/keyRings/your-keyring/cryptoKeys/your-key-name. - apiKeySecretId: המזהה הסודי ב-Secret Manager של מפתח ה-API. אם הערך של
apiKeySourceהואSECRET_MANAGER, צריך לספק את הפרמטר הזה. משתמשים בפורמטprojects/<PROJECT_ID>/secrets/<SECRET_ID>/versions/<SECRET_VERSION>. For example,projects/your-project-id/secrets/your-secret/versions/your-secret-version`. - apiKeySource: המקור של מפתח ה-API. הערכים המותרים הם
PLAINTEXT, KMSאוSECRET_MANAGER. חובה להשתמש בפרמטר הזה כשמשתמשים ב-Secret Manager או ב-KMS. אם הערך שלapiKeySourceהואKMS, צריך לספק אתapiKeyKMSEncryptionKeyואת מפתח ה-API המוצפן. אם הערך שלapiKeySourceהואSECRET_MANAGER, צריך לספק את הערך שלapiKeySecretId. אם הערך שלapiKeySourceהואPLAINTEXT, צריך לספק את הערך שלapiKey. ברירת המחדל היא: PLAINTEXT. - socketTimeout: אם ההגדרה הזו מוגדרת, היא מחליפה את ברירת המחדל של הזמן הקצוב לתפוגה של הניסיון החוזר ואת ברירת המחדל של הזמן הקצוב לתפוגה של שקע (30,000 אלפיות שנייה) ב-Elastic RestClient.
- javascriptTextTransformGcsPath: ה-URI של Cloud Storage של קובץ ה- .js שמגדיר את הפונקציה בהגדרת המשתמש (UDF) ב-JavaScript שבה רוצים להשתמש. לדוגמה,
gs://my-bucket/my-udfs/my_file.js. - javascriptTextTransformFunctionName: השם של פונקציית JavaScript בהגדרת המשתמש (UDF) שבה רוצים להשתמש. לדוגמה, אם קוד הפונקציה ב-JavaScript הוא
myTransform(inJson) { /*...do stuff...*/ }, אז שם הפונקציה הואmyTransform. דוגמאות לפונקציות מוגדרות על ידי המשתמש (UDF) ב-JavaScript זמינות במאמר UDF Examples (https://github.com/GoogleCloudPlatform/DataflowTemplates#udf-examples).
פונקציות בהגדרת המשתמש
התבנית הזו תומכת בפונקציות בהגדרת המשתמש (UDF) בכמה נקודות בצינור, כפי שמתואר בהמשך. למידע נוסף, ראו יצירת פונקציות מוגדרות על ידי המשתמש לתבניות Dataflow.
פונקציית שינוי טקסט
הופך את נתוני ה-CSV למסמך Elasticsearch.
פרמטרים של תבניות:
-
javascriptTextTransformGcsPath: ה-URI של קובץ ה-JavaScript ב-Cloud Storage. -
javascriptTextTransformFunctionName: השם של פונקציית JavaScript.
מפרט הפונקציה:
- קלט: שורה אחת מקובץ CSV של קלט.
- פלט: מסמך JSON שהומר למחרוזת להוספה ל-Elasticsearch.
פונקציית אינדקס
מחזירה את האינדקס שאליו המסמך שייך.
פרמטרים של תבניות:
-
javaScriptIndexFnGcsPath: ה-URI של Cloud Storage של קובץ ה-JavaScript. -
javaScriptIndexFnName: השם של פונקציית JavaScript.
מפרט הפונקציה:
- קלט: מסמך Elasticsearch שעבר סריאליזציה כמחרוזת JSON.
- Output: הערך של שדה המטא-נתונים
_indexבמסמך.
הפונקציה Document ID
מחזירה את מזהה המסמך.
פרמטרים של תבניות:
-
javaScriptIdFnGcsPath: ה-URI של קובץ ה-JavaScript ב-Cloud Storage. -
javaScriptIdFnName: השם של פונקציית JavaScript.
מפרט הפונקציה:
- קלט: מסמך Elasticsearch שעבר סריאליזציה כמחרוזת JSON.
- Output: הערך של שדה המטא-נתונים
_idבמסמך.
פונקציה למחיקת מסמכים
קובע אם למחוק מסמך. כדי להשתמש בפונקציה הזו, צריך להגדיר את מצב ההוספה בכמות גדולה ל-INDEX ולספק פונקציה של מזהה מסמך.
פרמטרים של תבניות:
-
javaScriptIsDeleteFnGcsPath: ה-URI של קובץ ה-JavaScript ב-Cloud Storage. -
javaScriptIsDeleteFnName: השם של פונקציית JavaScript.
מפרט הפונקציה:
- קלט: מסמך Elasticsearch שעבר סריאליזציה כמחרוזת JSON.
- פלט: מחזירה את המחרוזת
"true"כדי למחוק את המסמך, או את המחרוזת"false"כדי לעדכן או להוסיף (upsert) את המסמך.
פונקציית מיפוי סוג
מחזירה את סוג המיפוי של המסמך.
פרמטרים של תבניות:
-
javaScriptTypeFnGcsPath: ה-URI של Cloud Storage של קובץ ה-JavaScript. -
javaScriptTypeFnName: השם של פונקציית JavaScript.
מפרט הפונקציה:
- קלט: מסמך Elasticsearch שעבר סריאליזציה כמחרוזת JSON.
- Output: הערך של שדה המטא-נתונים
_typeבמסמך.
הפעלת התבנית
המסוף
- עוברים לדף Dataflow Create job from template (יצירת משימה מתבנית). כניסה לדף Create job from template
- בשדה שם המשימה, מזינים שם ייחודי למשימה.
- אופציונלי: בשדה Regional endpoint (נקודת קצה אזורית), בוחרים ערך מהתפריט הנפתח. אזור ברירת המחדל הוא
us-central1.רשימת האזורים שבהם אפשר להריץ משימת Dataflow מופיעה במאמר מיקומי Dataflow.
- בתפריט הנפתח Dataflow template (תבנית של העברת נתונים), בוחרים באפשרות the Cloud Storage to Elasticsearch template.
- בשדות הפרמטרים שמופיעים, מזינים את ערכי הפרמטרים.
- לוחצים על הפעלת העבודה.
gcloud
במעטפת או בטרמינל, מריצים את התבנית:
gcloud dataflow flex-template run JOB_NAME \ --project=PROJECT_ID\ --region=REGION_NAME \ --template-file-gcs-location=gs://dataflow-templates-REGION_NAME/VERSION/flex/GCS_to_Elasticsearch \ --parameters \ inputFileSpec=INPUT_FILE_SPEC,\ connectionUrl=CONNECTION_URL,\ apiKey=APIKEY,\ index=INDEX,\ deadletterTable=DEADLETTER_TABLE,\
מחליפים את מה שכתוב בשדות הבאים:
-
PROJECT_ID: מזהה הפרויקט שבו רוצים להריץ את משימת Dataflow Google Cloud -
JOB_NAME: שם ייחודי של המשימה לפי בחירתכם -
VERSION: הגרסה של התבנית שבה רוצים להשתמשאפשר להשתמש בערכים הבאים:
-
latestכדי להשתמש בגרסה העדכנית של התבנית, שזמינה בתיקיית ההורה ללא תאריך בדלי – gs://dataflow-templates-REGION_NAME/latest/ - שם הגרסה, כמו
2023-09-12-00_RC00, כדי להשתמש בגרסה ספציפית של התבנית, שאפשר למצוא אותה בתיקיית האב המתאימה עם התאריך בדלי – gs://dataflow-templates-REGION_NAME/
-
-
REGION_NAME: האזור שבו רוצים לפרוס את עבודת Dataflow, לדוגמה:us-central1 -
INPUT_FILE_SPEC: התבנית של הקובץ ב-Cloud Storage. -
CONNECTION_URL: כתובת ה-URL של Elasticsearch. -
APIKEY: מפתח ה-API שלכם בקידוד base64 לאימות. -
INDEX: האינדקס של Elasticsearch. -
DEADLETTER_TABLE: הטבלה שלכם ב-BigQuery.
API
כדי להריץ את התבנית באמצעות API בארכיטקטורת REST, שולחים בקשת HTTP POST. מידע נוסף על ה-API ועל היקפי ההרשאות שלו זמין במאמר projects.templates.launch.
POST https://dataflow.googleapis.com/v1b3/projects/PROJECT_ID/locations/LOCATION/flexTemplates:launch { "launch_parameter": { "jobName": "JOB_NAME", "parameters": { "inputFileSpec": "INPUT_FILE_SPEC", "connectionUrl": "CONNECTION_URL", "apiKey": "APIKEY", "index": "INDEX", "deadletterTable": "DEADLETTER_TABLE" }, "containerSpecGcsPath": "gs://dataflow-templates-LOCATION/VERSION/flex/GCS_to_Elasticsearch", } }
מחליפים את מה שכתוב בשדות הבאים:
-
PROJECT_ID: מזהה הפרויקט שבו רוצים להריץ את משימת Dataflow Google Cloud -
JOB_NAME: שם ייחודי של המשימה לפי בחירתכם -
VERSION: הגרסה של התבנית שבה רוצים להשתמשאפשר להשתמש בערכים הבאים:
-
latestכדי להשתמש בגרסה העדכנית של התבנית, שזמינה בתיקיית ההורה ללא תאריך בדלי – gs://dataflow-templates-REGION_NAME/latest/ - שם הגרסה, כמו
2023-09-12-00_RC00, כדי להשתמש בגרסה ספציפית של התבנית, שאפשר למצוא אותה בתיקיית האב המתאימה עם התאריך בדלי – gs://dataflow-templates-REGION_NAME/
-
-
LOCATION: האזור שבו רוצים לפרוס את עבודת Dataflow, לדוגמה:us-central1 -
INPUT_FILE_SPEC: התבנית של הקובץ ב-Cloud Storage. -
CONNECTION_URL: כתובת ה-URL של Elasticsearch. -
APIKEY: מפתח ה-API שלכם בקידוד base64 לאימות. -
INDEX: האינדקס של Elasticsearch. -
DEADLETTER_TABLE: הטבלה שלכם ב-BigQuery.