इलास्टिक्स खोज - दस्तावेज़ एपीआई

इलास्टिसर्च एकल दस्तावेज़ एपीआई और बहु-दस्तावेज़ एपीआई प्रदान करता है, जहां एपीआई कॉल क्रमशः एक दस्तावेज़ और कई दस्तावेज़ों को लक्षित कर रहा है।

सूचकांक एपीआई

यह JSON दस्तावेज़ को एक इंडेक्स में जोड़ने या अपडेट करने में मदद करता है जब विशिष्ट मैपिंग के साथ उस संबंधित इंडेक्स के लिए अनुरोध किया जाता है। उदाहरण के लिए, निम्नलिखित अनुरोध JSON ऑब्जेक्ट को इंडेक्स स्कूलों और स्कूल मैपिंग के तहत जोड़ देगा -

PUT schools/_doc/5
{
   name":"City School", "description":"ICSE", "street":"West End",
   "city":"Meerut",
   "state":"UP", "zip":"250002", "location":[28.9926174, 77.692485],
   "fees":3500,
   "tags":["fully computerized"], "rating":"4.5"
}

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 1,
   "result" : "created",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 2,
   "_primary_term" : 1
}

स्वचालित सूचकांक निर्माण

जब किसी विशेष इंडेक्स में JSON ऑब्जेक्ट को जोड़ने का अनुरोध किया जाता है और यदि वह इंडेक्स मौजूद नहीं होता है, तो यह एपीआई स्वचालित रूप से उस इंडेक्स को बनाता है और उस विशेष JSON ऑब्जेक्ट के लिए अंतर्निहित मैपिंग भी। इस कार्यक्षमता को निम्न मापदंडों के मूल्यों को गलत में बदलकर अक्षम किया जा सकता है, जो कि इलास्टिसर्च.आईएमएल फ़ाइल में मौजूद हैं।

action.auto_create_index:false
index.mapper.dynamic:false

आप इंडेक्स के ऑटो निर्माण को भी प्रतिबंधित कर सकते हैं, जहां केवल विशिष्ट पैटर्न वाले इंडेक्स नाम को निम्नलिखित पैरामीटर के मूल्य को बदलकर अनुमति दी जाती है -

action.auto_create_index:+acc*,-bank*

Note - यहां + अनुमति दी गई है और इंगित करता है - अनुमति नहीं है।

संस्करण

इलास्टिक्स खोज भी संस्करण नियंत्रण सुविधा प्रदान करती है। हम किसी विशेष दस्तावेज़ के संस्करण को निर्दिष्ट करने के लिए एक संस्करण क्वेरी पैरामीटर का उपयोग कर सकते हैं।

PUT schools/_doc/5?version=7&version_type=external
{
   "name":"Central School", "description":"CBSE Affiliation", "street":"Nagan",
   "city":"paprola", "state":"HP", "zip":"176115", "location":[31.8955385, 76.8380405],
   "fees":2200, "tags":["Senior Secondary", "beautiful campus"], "rating":"3.3"
}

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 7,
   "result" : "updated",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 3,
   "_primary_term" : 1
}

वर्जनिंग एक वास्तविक समय की प्रक्रिया है और यह वास्तविक समय के खोज कार्यों से प्रभावित नहीं होता है।

दो सबसे महत्वपूर्ण प्रकार के संस्करण हैं -

आंतरिक संस्करण

आंतरिक संस्करणकरण डिफ़ॉल्ट संस्करण है जो 1 से शुरू होता है और प्रत्येक अपडेट के साथ वेतन वृद्धि, हटाए गए शामिल हैं।

बाहरी संस्करण

इसका उपयोग तब किया जाता है जब दस्तावेजों की वर्जनिंग को किसी बाहरी सिस्टम जैसे थर्ड पार्टी वर्जनिंग सिस्टम में स्टोर किया जाता है। इस कार्यक्षमता को सक्षम करने के लिए, हमें version_type को बाहरी पर सेट करना होगा। यहां एलीटसर्चखोज संस्करण संख्या को बाहरी सिस्टम द्वारा निर्दिष्ट के रूप में संग्रहीत करेगा और उन्हें स्वचालित रूप से नहीं बढ़ाएगा।

ऑपरेशन का प्रकार

ऑपरेशन प्रकार का उपयोग एक ऑपरेशन बनाने के लिए किया जाता है। यह मौजूदा दस्तावेज़ के ओवरराइटिंग से बचने में मदद करता है।

PUT chapter/_doc/1?op_type=create
{
   "Text":"this is chapter one"
}

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "_index" : "chapter",
   "_type" : "_doc",
   "_id" : "1",
   "_version" : 1,
   "result" : "created",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 0,
   "_primary_term" : 1
}

स्वचालित आईडी पीढ़ी

जब ID अनुक्रमणिका ऑपरेशन में निर्दिष्ट नहीं होता है, तो Elasticsearch स्वचालित रूप से उस दस्तावेज़ के लिए आईडी बनाता है।

POST chapter/_doc/
{
   "user" : "tpoint",
   "post_date" : "2018-12-25T14:12:12",
   "message" : "Elasticsearch Tutorial"
}

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "_index" : "chapter",
   "_type" : "_doc",
   "_id" : "PVghWGoB7LiDTeV6LSGu",
   "_version" : 1,
   "result" : "created",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 1,
   "_primary_term" : 1
}

एपीआई प्राप्त करें

API किसी विशेष दस्तावेज़ के लिए अनुरोध प्राप्त करके JSON ऑब्जेक्ट को निकालने में मदद करता है।

pre class="prettyprint notranslate" > GET schools/_doc/5

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 7,
   "_seq_no" : 3,
   "_primary_term" : 1,
   "found" : true,
   "_source" : {
      "name" : "Central School",
      "description" : "CBSE Affiliation",
      "street" : "Nagan",
      "city" : "paprola",
      "state" : "HP",
      "zip" : "176115",
      "location" : [
         31.8955385,
         76.8380405
      ],
      "fees" : 2200,
      "tags" : [
         "Senior Secondary",
         "beautiful campus"
      ],
      "rating" : "3.3"
   }
}
  • यह ऑपरेशन वास्तविक समय है और सूचकांक की ताज़ा दर से प्रभावित नहीं होता है।

  • आप संस्करण को निर्दिष्ट भी कर सकते हैं, फिर एलीस्टेकर्च केवल दस्तावेज़ के उस संस्करण को लाएगा।

  • आप अनुरोध में _all भी निर्दिष्ट कर सकते हैं, ताकि एलेस्टिक्स खोज उस दस्तावेज़ आईडी को हर प्रकार में खोज सके और यह पहले मिलान किए गए दस्तावेज़ को वापस कर देगा।

  • आप उस विशेष दस्तावेज़ से अपने परिणाम में अपने इच्छित फ़ील्ड भी निर्दिष्ट कर सकते हैं।

GET schools/_doc/5?_source_includes=name,fees

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 7,
   "_seq_no" : 3,
   "_primary_term" : 1,
   "found" : true,
   "_source" : {
      "fees" : 2200,
      "name" : "Central School"
   }
}

आप अपने रिक्वेस्ट में सिर्फ _source हिस्सा जोड़कर अपने रिजल्ट में सोर्स पार्ट भी ला सकते हैं।

GET schools/_doc/5?_source

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "5",
   "_version" : 7,
   "_seq_no" : 3,
   "_primary_term" : 1,
   "found" : true,
   "_source" : {
      "name" : "Central School",
      "description" : "CBSE Affiliation",
      "street" : "Nagan",
      "city" : "paprola",
      "state" : "HP",
      "zip" : "176115",
      "location" : [
         31.8955385,
         76.8380405
      ],
      "fees" : 2200,
      "tags" : [
         "Senior Secondary",
         "beautiful campus"
      ],
      "rating" : "3.3"
   }
}

आप सही करने के लिए सेट रिफ्रेश पैरामीटर द्वारा ऑपरेशन करवाने से पहले शार्क को रिफ्रेश भी कर सकते हैं।

एपीआई हटाएं

आप किसी विशेष इंडेक्स, मैपिंग या डॉक्यूमेंट को डिलीट कर सकते हैं, जो एलिस्टिक्स सर्च को HTTP DELETE रिक्वेस्ट भेजकर कर सकते हैं।

DELETE schools/_doc/4

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "found":true, "_index":"schools", "_type":"school", "_id":"4", "_version":2,
   "_shards":{"total":2, "successful":1, "failed":0}
}

दस्तावेज़ के संस्करण को उस विशेष संस्करण को हटाने के लिए निर्दिष्ट किया जा सकता है। रूटिंग पैरामीटर को किसी विशेष उपयोगकर्ता से दस्तावेज़ को हटाने के लिए निर्दिष्ट किया जा सकता है और यदि दस्तावेज़ उस विशेष उपयोगकर्ता से संबंधित नहीं है, तो ऑपरेशन विफल हो जाता है। इस ऑपरेशन में, आप GET API की तरह ही रिफ्रेश और टाइमआउट विकल्प निर्दिष्ट कर सकते हैं।

एपीआई अद्यतन करें

स्क्रिप्ट का उपयोग इस ऑपरेशन को करने के लिए किया जाता है और संस्करण का उपयोग यह सुनिश्चित करने के लिए किया जाता है कि गेट और री-इंडेक्स के दौरान कोई अपडेट नहीं हुआ है। उदाहरण के लिए, आप स्क्रिप्ट का उपयोग करके स्कूल की फीस अपडेट कर सकते हैं -

POST schools/_update/4
{
   "script" : {
      "source": "ctx._source.name = params.sname",
      "lang": "painless",
      "params" : {
         "sname" : "City Wise School"
      }
   }
 }

उपरोक्त कोड चलाने पर, हमें निम्न परिणाम मिलते हैं -

{
   "_index" : "schools",
   "_type" : "_doc",
   "_id" : "4",
   "_version" : 3,
   "result" : "updated",
   "_shards" : {
      "total" : 2,
      "successful" : 1,
      "failed" : 0
   },
   "_seq_no" : 4,
   "_primary_term" : 2
}

आप अपडेट किए गए दस्तावेज़ के लिए अनुरोध प्राप्त करके अपडेट की जांच कर सकते हैं।