आपके बैच फ़ीड में, किसी इकाई के वर्शन को
फ़ीड के लिफ़ाफ़े में dateModified
फ़ील्ड:
{
"@context": "http://schema.googleapis.com",
"dateModified": "2018-12-28T06:30:00:123-07:00",
"@type": "DataFeed",
"dataFeedElement": [
/* All the items that are part of this feed go here */
]
}
dataFeedElement
फ़ील्ड में दी गई सभी इकाइयों का टाइमस्टैंप एक ही होगा.
जैसा कि एनवेलप में दर्ज है.
उदाहरण के लिए, आपके पास इस फ़ीड में दो इकाइयां हो सकती हैं:
{
"@context": "http://schema.googleapis.com",
"@type": "DataFeed",
"dateModified": "2018-12-28T06:30:00:123-07:00",
"dataFeedElement": [
{
"@type": "Restaurant",
"@id": "http://www.provider.com/somerestaurant",
...
},
{
"@type": "Menu",
"@id": "http://www.provider.com/somerestaurant/menu/1"
...
}
]
}
मिलने और प्रोसेस हो जाने के बाद, मेन्यू और रेस्टोरेंट की इकाइयां अलग-अलग वर्शन "2018-12-28T06:30:00:123-07:00" के तौर पर सेव किया गया है.
समय-समय पर अपडेट के साथ वर्शन बनाना
इन्वेंट्री अपडेट का इस्तेमाल करके किसी इकाई को भेजते समय, वर्शन को
update_time
फ़ील्ड (जोड़ें/अपडेट करें कॉल के मामले में) या delete_time
फ़ील्ड (मिटाने के लिए कॉल के मामले में) का उपयोग कर सकते है. ये फ़ील्ड ज़रूरी नहीं हैं. इसलिए,
डिफ़ॉल्ट टाइमस्टैंप, Google को कॉल आने के समय पर सेट होता है.
पहला उदाहरण: updated_time साफ़ तौर पर सेट करें
मान लें कि 28-12-2018T06:30:10:123-07:00 पर इंक्रीमेंटल कॉल आया है एक पूरी तरह से नए रेस्टोरेंट के लिए. इकाई के लिए एचटीटीपी पीओएसटी अनुरोध यह रहा यह मानते हुए कि डेटा फ़ीड v1 इन्वेंट्री स्कीमा:
POST v2/apps/provider-project/entities/http%3A%2F%2Fwww.provider.com%2Fnewrestaurant:push
Host: actions.googleapis.com
Content-Type: application/ld+json
नीचे, JSON पेलोड के मुख्य हिस्से में update_time
फ़ील्ड शामिल है. इस इकाई के साथ
आईडी "http://www.provider.com/somerestaurant" इस इकाई के नतीजे
6:30:00 रूप में वर्शन किया गया था और उस समय नहीं जब यह मिला था (10 सेकंड बाद में
6:30:10):
{
// This envelope is to be used for incremental.
"entity": {
// Note: "data" is not serialized as a string in our example for readability.
"data": "[entity in JSON format serialized as a string]",
"vertical": "FOODORDERING&q
uot;
},
"update_time":"2018-12-28T06:30:00:123-07:00"
}
दूसरा उदाहरण: updated_time इंप्लिसिट रूप से सेट
मान लें कि 28-12-2018T06:30:10:123-07:00 पर इंक्रीमेंटल कॉल आया है एक पूरी तरह से नए रेस्टोरेंट के लिए. इकाई के लिए एचटीटीपी पीओएसटी अनुरोध यह रहा माना जाएगा कि फ़ीड v1 का उपयोग करती है. इन्वेंट्री स्कीमा:
POST v2/apps/provider-project/entities/http%3A%2F%2Fwww.provider.com%2Fnewrestaurant:push
Host: actions.googleapis.com
Content-Type: application/ld+json
नीचे, JSON पेलोड बॉडी में update_time
फ़ील्ड नहीं है. कॉन्टेंट बनाने
"http://www.provider.com/somerestaurant" आईडी वाली इकाई इसलिए,
इस इकाई का वर्शन 6:30:10 वर्शन में है:
{
// This envelope is to be used for incremental.
"entity": {
//Note: "data" is not serialized as a string in our example for readability.
"data": "[entity in JSON format serialized as a string]"
;,
"vertical": "FOODORDERING"
}
}
बैच और इंंक्रीमेंटल के बीच वर्शन बनाना
Google को भेजी गई इकाई को सिर्फ़ तब प्रोसेस और दिखाया जाता है, जब उसके पास सबसे नया वर्शन हो वर्शन है. ध्यान दें कि बैच के ज़रिए भेजी गई इकाइयों में आम तौर पर कुछ दिन लगते हैं प्रोसेस की जाती है, जबकि इंक्रीमेंटल एपीआई की मदद से भेजी गई इकाइयां प्रोसेस होती हैं तुरंत.
सबसे सही तरीके
update_time
औरdateModified
फ़ील्ड को इंंक्रीमेंटल और बैच में सेट करें, आपके सिस्टम में इकाई को कब बदला गया था, उसके हिसाब से.- अगर किसी बैच फ़ीड (फ़ाइल) में एक से ज़्यादा टॉप लेवल इकाइयां हैं (उदाहरण के लिए, अपने रेस्टोरेंट को सेवाओं और मेन्यू से जोड़ें), इसके बाद टाइमस्टैंप किसी इकाई का डेटा अपडेट हो जाता है.
- इंक्रीमेंटल कॉल में, हमारा सुझाव है कि आप
update_time
फ़ील्ड. - यह ज़रूरी है कि इंक्रीमेंटल कॉल करने पर, उससे जुड़ा फ़ीड
इससे पहले कि Google इसे दोबारा फ़ेच करे, टाइमस्टैंप (
dateModified
) भी अपडेट हो जाता है.
उदाहरण
Google पूरी तरह से नई फ़ाइल के लिए, 28-12-2018 को सुबह 11 बजे इस फ़ाइल को फ़ेच करता है रेस्टोरेंट:
{
"@context": "http://schema.googleapis.com",
"@type": "DataFeed",
"dateModified": "2018-12-28T06:30:00-07:00",
"dataFeedElement": [
{
"@type": "Restaurant",
"@id": "http://www.provider.com/newrestaurant",
...
},
{
"@type": "Menu",
"@id": "http://www.provider.com/newrestaur
ant/menu/1"
...
}
{
"@type": "Service",
"@id": "http://www.provider.com/newrestaurant/service/1"
...
}
]
}
ये इकाइयां प्रोसेस हो जाती हैं और इनके वर्शन "2018-12-28T06:30:00-07:00". बैच फ़ीड को प्रोसेस होने में समय लगता है, इसलिए ये आम तौर पर दो दिन बाद दिखाए जाते हैं.
हालांकि, दोपहर 1 बजे, रेस्टोरेंट के पार्टनर के सिस्टम को रेस्टोरेंट के फ़ोन पर अपडेट हो जाएगा इससे नीचे दिया गया इंक्रीमेंटल कॉल होता है, जो Google को मिलता है 13:05 पर (5 सेकंड बाद):
POST v2/apps/provider-project/entities/http%3A%2F%2Fwww.provider.com%2Fnewrestaurant:push
Host: actions.googleapis.com
Content-Type: application/ld+json
{
// This envelope is to be used for incremental.
"entity": {
//Note: "data" is not serialized as a string in our example for readability.
"data": "[entity in JSON format serialized as a string]",
"vertical": "FOODORDERI
NG"
},
"update_time":"2018-12-28T13:00:00-07:00"
}
update_time
को साफ़ तौर पर दिया गया है और यह
पिछला वर्शन (उसी दिन की सुबह 6:30 बजे), इसलिए रेस्टोरेंट इकाई अब
"2018-12-28T13:00:00-07:00" के तौर पर वर्शन किया गया है. हालांकि, मेन्यू और सेवा इकाइयां
अब भी "2018-12-28T06:30:00-07:00" के तौर पर वर्शन बने हैं.
ज़रूरत के मुताबिक कॉल आने की वजह से, बैच फ़ीड को नए वर्शन के साथ अपडेट किया गया संबंधित टाइमस्टैंप. साथ ही, संबंधित बदलाव संबंधित इकाइयां (रेस्टोरेंट की इकाई का फ़ोन नंबर अपडेट हो.)
{
"@context": "http://schema.googleapis.com",
"@type": "DataFeed",
"dateModified": "2018-12-28T13:00:00-07:00",
"dataFeedElement": [
{
"@type": "Restaurant",
"@id": "http://www.provider.com/newrestaurant",
...
},
{
"@type": "Menu",
"@id": "http://www.provider.com/newrestaur
ant/menu/1"
...
}
{
"@type": "Service",
"@id": "http://www.provider.com/newrestaurant/service/1"
...
}
]
}
अगले दिन (29-12-2018) को रात 11 बजे, फ़ीड को फिर से फ़ेच किया जाता है. रेस्टोरेंट अब भी यही वर्शन है (28 दिसंबर को दोपहर 1 बजे), इसलिए इस इकाई को हटा दिया जाता है और मौजूदा वर्शन को बनाए रखा जाता है. हालांकि, मेन्यू और सेवा इकाइयां नए वर्शन के साथ अपडेट किया गया है.
साइटमैप के टाइमस्टैंप
साइटमैप में last-modified
रिस्पॉन्स हेडर को प्रभावित नहीं करता
इकाई का वर्शन. इससे यह तय होता है कि Google, फ़ीड को कब फ़ेच करता है.
सबसे सही तरीके
- रिस्पॉन्स हेडर को सिर्फ़ तब अपडेट करें, जब सभी फ़ाइलें अप-टू-डेट हों और मिल जाएगा.
- बढ़ोतरी के दौरान,
update_time
औरdelete_time
का साफ़ तौर पर इस्तेमाल करें. update_time
,delete_time
, औरdateModified
को डेटा में बदलाव होने पर सेट करें को भी ट्रैक किया जा सकता है.