एलेस्टिक्स खोज - एपीआई कन्वेंशन

वेब में एप्लिकेशन प्रोग्रामिंग इंटरफेस (एपीआई) उस विशेष वेब एप्लिकेशन में सॉफ्टवेयर घटक तक पहुंचने के लिए फ़ंक्शन कॉल या अन्य प्रोग्रामिंग निर्देशों का एक समूह है। उदाहरण के लिए, फेसबुक एपीआई एक डेवलपर को फेसबुक से डेटा या अन्य कार्यात्मकताओं तक पहुंच बनाने में मदद करता है; यह जन्म की तारीख या स्थिति अद्यतन हो सकता है।

इलास्टिक्सखोज एक REST API प्रदान करता है, जिसे JSON द्वारा HTTP पर एक्सेस किया जाता है। इलास्टिसर्च कुछ सम्मेलनों का उपयोग करता है जिन पर हम अब चर्चा करेंगे।

एकाधिक संकेत

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

कॉमा सेपरेटेड नोटेशन

POST /index1,index2,index3/_search

शरीर का अनुरोध करें

{
   "query":{
      "query_string":{
         "query":"any_string"
      }
   }
}

प्रतिक्रिया

इंडेक्स 1, इंडेक्स 2, इंडेक्स 3 से JSON ऑब्जेक्ट्स में कोई भी_स्ट्रिंग है।

_ सभी सूचकांकों के लिए कीवर्ड

POST /_all/_search

शरीर का अनुरोध करें

{
   "query":{
      "query_string":{
         "query":"any_string"
      }
   }
}

प्रतिक्रिया

JSON ऑब्जेक्ट्स को सभी सूचकांकों से और इसमें किसी भी_स्ट्रिंग के होने से।

वाइल्डकार्ड्स (*, +, -)

POST /school*/_search

शरीर का अनुरोध करें

{
   "query":{
      "query_string":{
         "query":"CBSE"
      }
   }
}

प्रतिक्रिया

JSON ऑब्जेक्ट्स सभी सूचकांकों से शुरू होते हैं जो स्कूल में होते हैं जिसमें CBSE होता है।

वैकल्पिक रूप से, आप निम्नलिखित कोड का उपयोग कर सकते हैं -

POST /school*,-schools_gov /_search

शरीर का अनुरोध करें

{
   "query":{
      "query_string":{
         "query":"CBSE"
      }
   }
}

प्रतिक्रिया

JSON ऑब्जेक्ट सभी सूचकांकों से शुरू होता है, जो "स्कूल" से शुरू होते हैं, लेकिन स्कूल_ओजी से नहीं और इसमें सीबीएसई होते हैं।

कुछ URL क्वेरी स्ट्रिंग पैरामीटर भी हैं -

  • ignore_unavailable- कोई त्रुटि नहीं होगी या कोई ऑपरेशन बंद नहीं किया जाएगा, अगर URL में मौजूद एक या अधिक इंडेक्स मौजूद हैं। उदाहरण के लिए, स्कूलों के सूचकांक मौजूद हैं, लेकिन बुक_ कार्यशालाएं मौजूद नहीं हैं।

POST /school*,book_shops/_search

शरीर का अनुरोध करें

{
   "query":{
      "query_string":{
         "query":"CBSE"
      }
   }
}

शरीर का अनुरोध करें

{
   "error":{
      "root_cause":[{
         "type":"index_not_found_exception", "reason":"no such index",
         "resource.type":"index_or_alias", "resource.id":"book_shops",
         "index":"book_shops"
      }],
      "type":"index_not_found_exception", "reason":"no such index",
      "resource.type":"index_or_alias", "resource.id":"book_shops",
      "index":"book_shops"
   },"status":404
}

निम्नलिखित कोड पर विचार करें -

POST /school*,book_shops/_search?ignore_unavailable = true

शरीर का अनुरोध करें

{
   "query":{
      "query_string":{
         "query":"CBSE"
      }
   }
}

प्रतिक्रिया (कोई त्रुटि नहीं)

JSON ऑब्जेक्ट्स सभी सूचकांकों से शुरू होते हैं जो स्कूल में होते हैं जिसमें CBSE होता है।

allow_no_indices

trueइस पैरामीटर के मूल्य में त्रुटि को रोका जा सकेगा, अगर वाइल्डकार्ड वाला URL कोई सूचक नहीं है। उदाहरण के लिए, ऐसा कोई इंडेक्स नहीं है जो स्कूलों के साथ शुरू होता है_परी -

POST /schools_pri*/_search?allow_no_indices = true

शरीर का अनुरोध करें

{
   "query":{
      "match_all":{}
   }
}

प्रतिक्रिया (कोई त्रुटि नहीं)

{
   "took":1,"timed_out": false, "_shards":{"total":0, "successful":0, "failed":0},
   "hits":{"total":0, "max_score":0.0, "hits":[]}
}

expand_wildcards

यह पैरामीटर तय करता है कि वाइल्डकार्ड्स को इंडेक्स खोलने या बंद इंडेक्स के लिए विस्तारित करने की आवश्यकता है या दोनों का प्रदर्शन करना है। इस पैरामीटर का मान खुला और बंद या कोई भी और सभी हो सकता है।

उदाहरण के लिए, इंडेक्स स्कूलों को बंद करें -

POST /schools/_close

प्रतिक्रिया

{"acknowledged":true}

निम्नलिखित कोड पर विचार करें -

POST /school*/_search?expand_wildcards = closed

शरीर का अनुरोध करें

{
   "query":{
      "match_all":{}
   }
}

प्रतिक्रिया

{
   "error":{
      "root_cause":[{
         "type":"index_closed_exception", "reason":"closed", "index":"schools"
      }],
      "type":"index_closed_exception", "reason":"closed", "index":"schools"
   }, "status":403
}

इंडेक्स नेम्स में डेट मैथ सपोर्ट

एलिटिक्स खोज तिथि और समय के अनुसार सूचकांकों को खोजने के लिए एक कार्यक्षमता प्रदान करती है। हमें किसी विशिष्ट प्रारूप में दिनांक और समय निर्दिष्ट करना होगा। उदाहरण के लिए, accountdetail-2015.12.30, सूचकांक 30 दिसंबर 2015 के बैंक खाते के विवरण को संग्रहीत करेगा। किसी विशेष तिथि या तिथि और समय की सीमा के विवरण प्राप्त करने के लिए गणितीय संचालन किया जा सकता है।

दिनांक गणित सूचकांक नाम के लिए प्रारूप -

<static_name{date_math_expr{date_format|time_zone}}>
/<accountdetail-{now-2d{YYYY.MM.dd|utc}}>/_search

static_name अभिव्यक्ति का एक हिस्सा है जो खाता विवरण जैसे हर दिनांक गणित सूचकांक में समान रहता है। date_math_expr में गणितीय अभिव्यक्ति शामिल है जो अब -२ डी की तरह दिनांक और समय को निर्धारित करती है। date_format में वह प्रारूप होता है जिसमें दिनांक YYYY.MM.dd जैसे सूचकांक में लिखी जाती है। यदि आज की तारीख 30 दिसंबर 2015 है, तो <accountdetail- {now-2d {YYYY.MM.dd}}> खाता-खाता-2015.12.28 वापस आ जाएगा।

अभिव्यक्ति को हल करता है
<Accountdetail- {अब-d}> accountdetail-2015/12/29
<Accountdetail- {अब एम}> accountdetail-2015/11/30
<Accountdetail- {{अब YYYY.MM}}> accountdetail-2015.12

अब हम एलिस्टिक्स खोज में उपलब्ध कुछ सामान्य विकल्पों को देखेंगे, जिनका उपयोग निर्दिष्ट प्रारूप में प्रतिक्रिया प्राप्त करने के लिए किया जा सकता है।

सुंदर परिणाम

हम एक अच्छी तरह से स्वरूपित JSON वस्तु में प्रतिक्रिया प्राप्त कर सकते हैं, बस एक यूआरएल क्वेरी पैरामीटर, यानी, सुंदर = सच जोड़कर।

POST /schools/_search?pretty = true

शरीर का अनुरोध करें

{
   "query":{
      "match_all":{}
   }
}

प्रतिक्रिया

……………………..
{
   "_index" : "schools", "_type" : "school", "_id" : "1", "_score" : 1.0,
   "_source":{
      "name":"Central School", "description":"CBSE Affiliation",
      "street":"Nagan", "city":"paprola", "state":"HP", "zip":"176115",
      "location": [31.8955385, 76.8380405], "fees":2000,
      "tags":["Senior Secondary", "beautiful campus"], "rating":"3.5"
   }
}
………………….

मानव पठनीय आउटपुट

यह विकल्प सांख्यिकीय प्रतिक्रियाओं को या तो मानव पठनीय रूप में बदल सकता है (यदि मानव = सत्य) या कंप्यूटर पठनीय रूप (यदि मानव = असत्य)। उदाहरण के लिए, यदि मानव = सत्य तो दूरी_किलोमीटर = 20KM और यदि मानव = असत्य है तो दूरी_मीटर = 20000, जब प्रतिक्रिया को किसी अन्य कंप्यूटर प्रोग्राम द्वारा उपयोग करने की आवश्यकता होती है।

प्रतिक्रिया फ़िल्टरिंग

हम फ़ील्ड_पथ पैरामीटर में उन्हें जोड़कर कम फ़ील्ड्स की प्रतिक्रिया को फ़िल्टर कर सकते हैं। उदाहरण के लिए,

POST /schools/_search?filter_path = hits.total

शरीर का अनुरोध करें

{
   "query":{
      "match_all":{}
   }
}

प्रतिक्रिया

{"hits":{"total":3}}