המדריך הזה מיועד לאדמינים של מחבר CSV (ערכים מופרדים בפסיקים) של Google Cloud Search, שאחראים על הורדה, הגדרה, הפעלה ומעקב של המחבר.
במדריך הזה מפורטות הוראות לביצוע המשימות העיקריות הבאות:
- מורידים את תוכנת המחבר CSV של Cloud Search.
- מגדירים את המחבר למקור נתונים ספציפי בפורמט CSV.
- פורסים ומריצים את המחבר.
כדי להבין את המושגים במאמר הזה, צריך להכיר את Google Workspace, קובצי CSV ורשימות בקרת גישה (ACL).
סקירה כללית על מחבר ה-CSV של Cloud Search
מחבר ה-CSV של Cloud Search פועל עם כל קובץ טקסט של ערכים מופרדים בפסיקים (CSV). בקובץ CSV מאוחסנים נתונים בטבלה, כאשר כל שורה היא רשומה של נתונים.
המחבר מחלץ שורות מקובץ CSV ומבצע להן אינדוקס ב-Cloud Search באמצעות Indexing API. אחרי שהשורות נוספות לאינדקס, אפשר לחפש אותן באמצעות לקוחות Cloud Search או Query API. המחבר תומך גם ברשימות ACL כדי לשלוט בגישת המשתמשים לתוכן.
אפשר להתקין את המחבר ב-Linux או ב-Windows. לפני הפריסה, חשוב לוודא שיש לכם את הרכיבים הבאים:
- Java JRE 1.8 מותקן במחשב שבו פועל המחבר.
- פרטי Google Workspace להגדרת חיבורים:
- מפתח פרטי של Google Workspace (שכולל את מזהה חשבון השירות).
- מזהה מקור הנתונים של Google Workspace.
בדרך כלל, האדמין של Google Workspace בדומיין מספק את פרטי הכניסה האלה.
שלבי הפריסה
כדי לפרוס את מחבר ה-CSV של Cloud Search:
- התקנת תוכנת המחבר
- הגדרת המחבר
- הגדרת גישה למקור הנתונים של Cloud Search
- הגדרת גישה לקובץ CSV
- ציון שמות של עמודות, מפתחות ייחודיים ועמודות של תאריך ושעה
- ציון עמודות לכתובות URL של תוצאות חיפוש שאפשר ללחוץ עליהן
- הגדרת מטא-נתונים ופורמטים של עמודות
- תזמון של מעבר על נתונים
- ציון אפשרויות של רשימת ACL
1. התקנת ה-SDK
מתקינים את ה-SDK במאגר Maven המקומי.
משכפלים את מאגר ה-SDK מ-GitHub.
$ git clone https://github.com/google-cloudsearch/connector-sdk.git $ cd connector-sdk/csv
כדי לבדוק את הגרסה שבחרתם:
$ git checkout tags/v1-0.0.3
בניית המחבר:
$ mvn package
מחילוץ והתקנה של המחבר:
$ cp target/google-cloudsearch-csv-connector-v1-0.0.3.zip installation-dir $ cd installation-dir $ unzip google-cloudsearch-csv-connector-v1-0.0.3.zip $ cd google-cloudsearch-csv-connector-v1-0.0.3
2. ציון ההגדרה של מחבר ה-CSV
אתם קובעים את אופן הפעולה של המחבר באמצעות פרמטרים בקובץ ההגדרות שלו. הפרמטרים שניתן להגדיר כוללים:
- גישה למקור הנתונים.
- המיקום של קובץ ה-CSV וההגדרות שלו.
- עמודות עם מזהים ייחודיים.
- אפשרויות של מעבר בין תיקיות ורשימות ACL.
כדי ליצור קובץ תצורה:
- פותחים כלי לעריכת טקסט ונותנים לקובץ את השם
connector-config.properties. - מוסיפים פרמטרים של הגדרה כזוגות של
key=value, כשכל זוג נמצא בשורה חדשה. דוגמה לקובץ תצורה מופיעה במאמר קובץ תצורה לדוגמה.
כדי לפשט את המעקב, כדאי לשמור את קובץ התצורה באותה ספרייה שבה נמצא המחבר. כדי לוודא שהמחבר מזהה את הקובץ, מציינים את הנתיב שלו בשורת הפקודה. אחרת, המחבר יוגדר כברירת מחדל ל-connector-config.properties בספרייה המקומית. ראו הפעלת המחבר.
3. הגדרת גישה למקור הנתונים של Cloud Search
בקובץ ההגדרה צריך לציין פרמטרים לגישה למקור הנתונים של Cloud Search. צריך את מזהה מקור הנתונים, מזהה חשבון השירות והנתיב לקובץ המפתח הפרטי של חשבון השירות.
| הגדרה | פרמטר |
| מזהה מקור הנתונים | api.sourceId=1234567890abcdef
חובה. מזהה המקור ב-Cloud Search שהוגדר על ידי האדמין ב-Google Workspace. |
| הנתיב למפתח הפרטי של חשבון השירות | api.serviceAccountPrivateKeyFile=./PrivateKey.json
חובה. קובץ המפתח של חשבון השירות לגישה למחבר. |
| המזהה של מקור הזהות | api.identitySourceId=x0987654321
נדרש אם משתמשים במשתמשים ובקבוצות חיצוניים. המזהה של מקור הזהויות שהוגדר על ידי האדמין ב-Google Workspace. |
4. הגדרת פרמטרים של קובץ CSV
מאתרים את הנתיב, הפורמט והקידוד של הקובץ.
| הגדרה | פרמטר |
| הנתיב לקובץ ה-CSV | csv.filePath=./movie_content.csv
חובה. הנתיב לקובץ להוספה לאינדקס. |
| פורמט קובץ | csv.format=DEFAULT
הפורמט של הקובץ. הערכים האפשריים הם מהמחלקה CSVFormat של Apache Commons CSV. ערכי הפורמט כוללים: |
| התאמה לשאילתה של פורמט הקובץ | csv.format.withMethod=value
שינוי באופן שבו Cloud Search מטפל בקובץ. השיטות האפשריות הן מהמחלקה CSVFormat של Apache Commons CSV, והן כוללות שיטות שמקבלות תו בודד, מחרוזת או ערך בוליאני. לדוגמה, כדי לציין נקודה ופסיק כתו מפריד, משתמשים ב- |
| סוג קידוד הקובץ | csv.fileEncoding=UTF-8
קבוצת התווים של Java שבה רוצים להשתמש. ברירת המחדל היא קבוצת התווים של הפלטפורמה. |
5. ציון שמות של עמודות לאינדקס ועמודות של מפתחות ייחודיים
מספקים את פרטי העמודות בקובץ התצורה.
| הגדרה | פרמטר |
| עמודות לאינדקס | csv.csvColumns=movieId,movieTitle,description,actors,releaseDate,year,userratings...
שמות העמודות שייכללו באינדקס מקובץ ה-CSV. כברירת מחדל, השורה הראשונה בקובץ ה-CSV משמשת ככותרת. אם מציינים את |
| עמודות של מפתח ייחודי | csv.uniqueKeyColumns=movieId
העמודות שמשמשות ליצירת מזהה ייחודי. ברירת המחדל היא קוד הגיבוב (hashcode) של הרשומה. |
6. הגדרת עמודות לכתובות URL של תוצאות חיפוש שאפשר ללחוץ עליהן
הפעלת כתובות URL שניתן ללחוץ עליהן בתוצאות החיפוש.
| הגדרה | פרמטר |
| הפורמט של כתובת ה-URL של תוצאת החיפוש | url.format=https://mymoviesite.com/movies/{0}
חובה. הפורמט שמשמש ליצירת כתובת ה-URL של התצוגה. |
| פרמטרים של כתובת אתר | url.columns=movieId
חובה. שמות העמודות ב-CSV שהערכים שלהן ישמשו ליצירת כתובת ה-URL של התצוגה של הרשומה. |
| פרמטרים של כתובת URL של תוצאות חיפוש שצריך להוסיף להם תווי Escape | url.columnsToEscape=movieId
אופציונלי. שמות העמודות בקובץ ה-CSV שהערכים שלהן יעברו escape כדי ליצור כתובת URL חוקית לתצוגה. |
7. ציון מטא-נתונים, פורמטים של עמודות ואיכות החיפוש
אפשר להוסיף לקובץ התצורה פרמטרים שמציינים:
פרמטרים להגדרת מטא-נתונים
הפרמטרים האלה מתארים עמודות לאכלוס מטא-נתונים של פריטים.
| הגדרה | פרמטר |
| כותרת | itemMetadata.title.field=movieTitle
itemMetadata.title.defaultValue=Gone with the Wind
מאפיין המטא-נתונים של כותרת המסמך. ברירת המחדל היא מחרוזת ריקה. |
| כתובת URL | itemMetadata.sourceRepositoryUrl.field=url
itemMetadata.sourceRepositoryUrl.defaultValue=https://www.imdb.com/title/tt0031381/
מאפיין המטא-נתונים של כתובת ה-URL של המסמך בתוצאות החיפוש. |
| חותמת הזמן של היצירה | itemMetadata.createTime.field=releaseDate
itemMetadata.createTime.defaultValue=1940-01-17
מאפיין המטא-נתונים של חותמת הזמן של יצירת המסמך. |
| זמן השינוי האחרון | itemMetadata.updateTime.field=releaseDate
itemMetadata.updateTime.defaultValue=1940-01-17
מאפיין המטא-נתונים של חותמת הזמן של השינוי האחרון במסמך. |
| שפת המסמך | itemMetadata.contentLanguage.field=languageCode
itemMetadata.contentLanguage.defaultValue=en-US
שפת התוכן של המסמכים שמתווספים לאינדקס. |
| סוג אובייקט הסכימה | itemMetadata.objectType.field=typeitemMetadata.objectType.defaultValue=movie
סוג האובייקט שבו משתמש המחבר, כפי שמוגדר בסכימה. אם לא מציינים את המאפיין הזה, המחבר לא מוסיף לאינדקס נתונים מובְנים. |
פורמטים של תאריך ושעה
הפרמטר הזה מציין פורמטים נוספים של תאריך ושעה לניתוח של ערכי מחרוזות לשדות של תאריך או תאריך ושעה.
| הגדרה | פרמטר |
| פורמטים נוספים של תאריך ושעה | structuredData.dateTimePatterns=MM/dd/uuuu HH:mm:ssXXX
רשימה של תבניות נוספות שמופרדות באמצעות נקודה-פסיק. java.time.format.DateTimeFormatter הדפוסים האלה משמשים לניתוח של ערכי מחרוזות בשדות של תאריך או תאריך ושעה במטא-נתונים או בסכימה. ערך ברירת המחדל הוא רשימה ריקה, אבל תמיד יש תמיכה בפורמטים RFC 3339 ו-RFC 1123.
|
פורמטים של עמודות
הפרמטרים האלה מציינים איך לנתח עמודות בקובץ ה-CSV.
| הגדרה | פרמטר |
| דילוג על הכותרת | csv.skipHeaderRecord=true
מתעלמים מהשורה הראשונה. ברירת המחדל היא False. |
| עמודות עם ערכים מרובים | csv.multiValueColumns=genre,actors
שמות של עמודות עם כמה ערכים. |
| תו הפרדה לעמודות עם ערכים מרובים | csv.multiValue.genre=;
תו ההפרדה בין עמודות עם כמה ערכים. תו המפריד שמוגדר כברירת מחדל הוא פסיק. |
איכות החיפוש
המחבר משתמש בתבנית תוכן כדי לעצב רשומות. לשדה 'שם' יש את העדיפות הכי גבוהה. אפשר להקצות רמות עדיפות (גבוהה, בינונית, נמוכה) לשדות אחרים.
| הגדרה | פרמטר |
| שם התוכן |
contentTemplate.csv.title=movieTitle
שדה איכות החיפוש הגבוה ביותר הוא שם התוכן. |
| איכות חיפוש גבוהה בשדות תוכן |
contentTemplate.csv.quality.high=actors
שדות תוכן שמקבלים ערך גבוה של איכות החיפוש. ברירת המחדל היא מחרוזת ריקה. |
| איכות חיפוש נמוכה בשדות תוכן |
contentTemplate.csv.quality.low=genre
שדות תוכן שקיבלו ערך נמוך של איכות החיפוש. ברירת המחדל היא מחרוזת ריקה. |
| איכות חיפוש בינונית בשדות תוכן |
contentTemplate.csv.quality.medium=description
שדות תוכן שקיבלו ערך בינוני של איכות החיפוש. ברירת המחדל היא מחרוזת ריקה. |
| שדות תוכן שלא צוינו |
contentTemplate.csv.unmappedColumnsMode=IGNORE
איך המחבר מטפל בשדות תוכן שלא צוינו. הערכים החוקיים כוללים:
ערך ברירת המחדל הוא APPEND. |
8. תזמון של סריקת נתונים
המעבר הוא תהליך של גילוי תוכן. המחבר עובר על שורות CSV ומוסיף אותן לאינדקס באמצעות Indexing API. מחבר ה-CSV מבצע רק סריקות מלאות.
| הגדרה | פרמטר |
| מרווח בין סריקות | schedule.traversalIntervalSecs=7200
המרווח בין סריקות מלאות בשניות. ברירת המחדל היא 86,400 (יום אחד). |
| העברה בזמן ההפעלה | schedule.performTraversalOnStart=false
המחבר מבצע מעבר על כל הנתונים בהפעלה שלו, במקום לחכות לסיום המרווח הראשון. ברירת המחדל היא |
9. בחירת אפשרויות ACL
המחבר משתמש ברשימות ACL כדי לשלוט בגישה. אם המאגר מספק רשימות ACL, צריך להעלות אותן. אחרת, מגדירים רשימות ACL שמשמשות כברירת מחדל. צריך להגדיר את הערך של defaultAcl.mode לערך שונה מ-none.
| הגדרה | פרמטר |
| מצב ACL | defaultAcl.mode=fallback
חובה. המחבר תומך רק במצב חזרה. |
| שם ברירת המחדל של רשימת ACL | defaultAcl.name=VIRTUAL_CONTAINER_FOR_CONNECTOR_1
אופציונלי. ההגדרה הזו מחליפה את השם של המאגר הווירטואלי שבו המחבר משתמש עבור רשימות ACL שמוגדרות כברירת מחדל. ערך ברירת המחדל הוא |
| רשימת ACL ציבורית שמשמשת כברירת מחדל | defaultAcl.public=true
מגדיר את המאגר כולו כנחלת הכלל. ברירת המחדל היא False. |
| קבוצות נפוצות עם הרשאת קריאה ב-ACL | defaultAcl.readers.groups=google:group1, group2
|
| קוראים נפוצים ב-ACL | defaultAcl.readers.users=user1, user2, google:user3
|
| קוראים בקבוצה שנדחתה על ידי ACL נפוץ | defaultAcl.denied.groups=group3
|
| Common Acl denied readers | defaultAcl.denied.users=user4, user5
|
| גישה לכל הדומיין | כדי לציין שכל רשומה באינדקס תהיה נגישה לכל משתמש בדומיין, צריך להגדיר את שתי האפשרויות הבאות עם ערכים:
|
| רשימת ACL מוגדרת נפוצה | כדי להגדיר רשימת ACL משותפת לכל רשומה, מגדירים את הפרמטרים הבאים:
המשתמשים והקבוצות מוגדרים כמשתמשים וקבוצות מקומיים בדומיין, אלא אם הם מתחילים בקידומת משתמש או קבוצה שמוגדרים כברירת מחדל הם מחרוזת ריקה. אפשר לספק אפשרויות של משתמשים וקבוצות רק אם אם |
הגדרת סכימה
כדי לתמוך בשאילתות של נתונים מובנים, צריך להגדיר סכמה למקור הנתונים.
לדוגמה, קובץ CSV עם הפרטים הבאים על סרטים:
- movieId
- movieTitle
- תיאור
- שנה
- releaseDate
- שחקנים (כמה ערכים מופרדים בפסיק (,))
- ז'אנר (כמה ערכים)
- דירוגים
על סמך המבנה הזה, אפשר להגדיר את הסכימה הבאה למקור הנתונים:
{
"objectDefinitions": [
{
"name": "movie",
"propertyDefinitions": [
{
"name": "actors",
"isReturnable": true,
"isRepeatable": true,
"isFacetable": true,
"textPropertyOptions": {
"operatorOptions": {
"operatorName": "actor"
}
}
},
{
"name": "releaseDate",
"isReturnable": true,
"isRepeatable": false,
"isFacetable": false,
"datePropertyOptions": {
"operatorOptions": {
"operatorName": "released",
"lessThanOperatorName": "releasedbefore",
"greaterThanOperatorName": "releasedafter"
}
}
},
{
"name": "movieTitle",
"isReturnable": true,
"isRepeatable": false,
"isFacetable": false,
"textPropertyOptions": {
"retrievalImportance": {
"importance": "HIGHEST"
},
"operatorOptions": {
"operatorName": "title"
}
}
},
{
"name": "genre",
"isReturnable": true,
"isRepeatable": true,
"isFacetable": true,
"enumPropertyOptions": {
"operatorOptions": {
"operatorName": "genre"
},
"possibleValues": [
{
"stringValue": "Action"
},
{
"stringValue": "Documentary"
},
{
"stringValue": "Drama"
},
{
"stringValue": "Crime"
},
{
"stringValue": "Sci-fi"
}
]
}
},
{
"name": "userRating",
"isReturnable": true,
"isRepeatable": false,
"isFacetable": true,
"integerPropertyOptions": {
"orderedRanking": "ASCENDING",
"maximumValue": "10",
"operatorOptions": {
"operatorName": "score",
"lessThanOperatorName": "scorebelow",
"greaterThanOperatorName": "scoreabove"
}
}
}
]
}
]
}
קובץ תצורה לדוגמה
בקובץ התצורה הבא לדוגמה מוצגים זוגות הפרמטרים key=value שמגדירים את ההתנהגות של מחבר לדוגמה.
# data source access
api.sourceId=1234567890abcd
api.serviceAccountPrivateKeyFile=./PrivateKey.json
# CSV data structure
csv.filePath=./movie_content.csv
csv.csvColumns=movieId,movieTitle,description,releaseYear,genre,actors,ratings,releaseDate
csv.skipHeaderRecord=true
url.format=https://mymoviesite.com/movies/{0}
url.columns=movieId
csv.datetimeFormat.releaseDate=yyyy-mm-dd
csv.multiValueColumns=genre,actors
csv.multiValue.genre=;
contentTemplate.csv.title=movieTitle
# metadata structured data and content
itemMetadata.title.field=movieTitle
itemMetadata.createTime.field=releaseDate
itemMetadata.contentLanguage.defaultValue=en-US
itemMetadata.objectType.defaultValue=movie
contentTemplate.csv.quality.medium=description
contentTemplate.csv.unmappedColumnsMode=IGNORE
#ACLs
defaultAcl.mode=fallback
defaultAcl.public=true
הפעלת המחבר
כדי להריץ את המחבר משורת הפקודה:
$ java -jar google-cloudsearch-csv-connector-v1-0.0.3.jar -Dconfig=my.config
כברירת מחדל, יומני המחברים זמינים בפלט רגיל. אפשר להיכנס לקבצים על ידי ציון logging.properties.