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