آموزش مقدماتی الستیک سرچ و کیبانا
همانطور که قبلاً هم در این سایت توضیح داده ام، الاستیک سرچ یکی از بهترین بانکهای اطلاعاتی سندمحور (منظور از سند، دادهای است که به شکل جیسان نمایش داده میشود) و همچنین جزء بهترین کتابخانه های جستجوی متن است که بر پایه کتابخانه معروف لوسین بنا شده است و علاوه بر سرعت بسیار بالا در پاسخگویی به انواع پرس و جوهای موردنیاز، توزیع شوندگی راحت در شبکه و سهولت بسیار زیاد در ورود داده، امروزه با افزودن داشبورد مدیریتی کیبانا و امکانات یادگیری ماشین و نیز ماژول هایی مانند LogStash
و HeartBeat
که به جمع آوری اطلاعات و لاگ ها از سرورهای مختلف می پردازد به یک گزینه بسیار ایده آل برای ذخیره و پردازش و مانیتورینگ داده های در جریان سیستم های عملیاتی معاصر تبدیل شده است.
اگر به لیست بانکهای اطلاعاتی برتر دنیا هم در سایت db-engines نگاهی بیندازید، این بانک را جزء ده بانک اطلاعاتی مطرح امروزین خواهید یافت.
در این آموزش ، قصد داریم به صورت خیلی سریع، شما را با این بانک اطلاعاتی سندمحور، از طریق ورود ۲۰ میلیون داده امتیاز فیلم و نمایش آن در کیبانا و تحلیل اولیه آنها آشنا کنیم.
بر اساس کارهای انجام شده در این نوشتار، یک فیلم آموزشی کوتاه تهیه شده است که میتوانید از آن استفاده کنید.
دانلود و راه اندازی سرور الاستیک سرچ و کیبانا
قبل از هر چیز باید الاستیک سرچ و کیبانا را به صورت جداگانه دانلود کرده، آنها را از حالت زیپ خارج و با تنظیمات پیش فرض اجرا کنید.
قبل از هر چیز، مطمئن شوید که نسخه ۸ (نسخه ۸ الاستیک نیاز به نسخه ۱۱ به بعد جاوا دارد) جاوا روی سیستمتان نصب و متغیر محیطی JAVA_HOME در ویندوز هم تنظیم شده است. برای نصب جاوا به این آدرس و برای تنظیم متغیر محیطی فوق به این مقاله، مراجعه کنید.
دو فایل دانلود شده فوق را از حالت زیپ درآورید . سپس با ورود به پوشه اصلی الاستیک سرچ، پوشه bin را باز کرده، بر روی elasticsearch.bat کلیک کنید (فایل دوم ).
اگر مشکلی رخ ندهد که معمولاً اگر رم کمی داشته باشید ممکن است، اجرای الاستیک با مشکل مواجه شود، تصویر زیر را خواهید دید (اگر پنجره ای باز شود و از شما سوال کرد که به این فایل اجازه دسترسی به شبکه را بدهد گزینه Allow را انتخاب کنید) :
بهتر است ابتدا خط فرمان ویندوز (Command Prompt) را باز کرده ، به پوشه bin در الاستیک رفته و با تایپ elasticsearch.bat و زدن اینتر، الاستیک را اجرا کنید تا اگر خطایی پیش آمد، بتوانید با بررسی آن و جستجو در گوگل ، مشکل خود را حل کنید.
برای اطمینان از آماده بودن الاستیک سرچ، در مرورگر آدرس زیر را تاپپ کنید (۹۲۰۰ پورت پیش فرض الاستیک است) :
با این کار، اطلاعات کلی الاستیک مانند شماره نسخه آن به شما نمایش داده خواهد شد :
در مرحله بعد، برای کار با الاستیک، با توجه به اینکه الاستیک، از طریق پروتکل HTTP درخواستها را دریافت و آنها را پاسخ می دهد (یعنی API آن از نوع REST است) نیاز به ابزاری برای ارسال درخواستهای HTTP داریم . یکی از بهترین این ابزار، نرم افزار PostMan است که امکانات بسیار کاملی مانند ذخیره تک تک کوئری ها و تنظیمات نمایشی مختلف را داراست (نرم افزار Insomnia هم محیط گرافیکی جذاب و امکانات متنوعی دارد که می توانید از آن هم استفاده کنید.). اما خود محیط کیبانا که داشبورد تحلیل داده الاستیک است، این امکان را در اختیار توسعه گران و تحلیل گران قرار می دهد.ما هم با کیبانا کار خواهیم کرد.
نکته
در بسیاری از مستندات الاستیک سرچ بخصوص مستندات اصلی الاستیک سرچ، برای ارسال درخواست به الاستیک و مشاهده نتایج از کتابخانه خط فرمان curl استفاده شده است که فایلهای اجرایی آن در ویندوز، در آدرس ریپوزیتوری گیت هاب این آموزش، موجود است و می توانید با ورود به خط فرمان، دستورات ورود داده این آموزش و همچنین جستجو ها را طبق دستورات این منبع، انجام بدهید. دقت کنید دستورات curl هنگام اجرا در محیط های گرافیکی باید تغییر مختصری بکنند مثلاً به جای XPUT همان PUT باید استفاده شود و نیز به جای d- برای ورود داده ها به صورت جی سان، خود داده ها بدون این پارامتر وارد شوند.
اگر با پاورشل ویندوز کار میکنید می توانید به جای curl از این دستور استفاده کنید :Invoke-RestMethod http://localhost:9200
وارد پوشه کیبانا شده ، درون پوشه bin فایل kibana.bat
(فایل اول) را اجرا (ترجیحاً از خط فرمان) کنید. کمی طول خواهد کشید و اگر مشکل رم نداشته باشید، صفحه زیر را مشاهده خواهید کرد :
همانطور که مشاهده میکنید کیبانا پشت پورت ۵۶۰۱ منتظر پاسخگویی به درخواستهای کاربران است. بنابراین در مرورگر این آدرس را تایپ کنید :
اگر صفحه زیر را مشاهده کردید، همه چیز خوب پیش رفته است :
با برخی از این امکانات امروز آشنا خواهیم شد. برای شروع و ورود چند داده، بر روی گزینه Console در پنل سمت راست کلیک کنید. ( یا منوی Dev Tools)
در صفحه فوق که کنسول تحت وب کیبانا برای کار با الاستیک محسوب می شود، دو پنل مشاهده می کنید. پنل سمت چپ برای نوشتن کوئری ها و اجرای آنها با زدن دکمه مثلث سبز رنگ و پنل سمت راست برای مشاهده نتایج است.
اکنون همه چیز برای شروع به کار با الاستیک سرچ آماده است.
ورود داده
به عنوان اولین گام در کار با الاستیک سرچ، باید چند داده وارد کنیم تا بتوانیم امکانات مختلف الاستیک سرچ را بررسی نمائیم. در پنل سمت چپ ، کدهای زیر را تایپ کرده، آنها دکمه سبز رنگ جلوی آنرا بزنید تا اجرا شود :
نتیجه زیر را مشاهده خواهید نمود :
چند نکته در مورد دستور فوق و نتیجه آن :
- برای ورود داده در الاستیک لازم نیست قبل از آن، دیتابیسی ساخته شود یا تنظیمی صورت گیرد. کافیست با ذکر نام ایندکس یا همان دیتابیس، نام جدول یا گروه داده و نهایتاً یک شماره، از الاستیک بخواهید که داده های شما را ذخیره کند. اگر این ایندکس یا گروه داده درون آن ایندکس، وجود نداشت، به طور خودکار ساخته خواهد شد.
- داده ها باید به شکل جی سان باشند.
- هنگام ارسال دستور به الاستیک سرچ درون کیبانا آدرس سرور ضروری نیست اما در محیط هایی مانند PostMan باید آدرس به صورت کامل نوشته شود: http://localhost:9200/movies/movie/1
- بخش پرس و جوی کیبانا به صورت هوشمند، مثالهای موجود با curl و نیز آدرس کامل وب سرور الاستیک را اصلاح کرده و نسخه بدون ایرادی از کوئری را به شما تحویل می دهد. بنابراین با خیال جمع، کوئری های خود را از مستندات و آموزش های مختلف الاستیک درون این محیط کپی کرده، اجرا کنید.
- ذکر شماره شناسه هنگام درج یک داده جدید، ضروریست .
- در نوشتن دستورات، کیبانا به شما کمک خواهد کرد. کافیست ابتدای یک ایندکس یا یک گروه یا یک دستور را بنویسید تا برایتان پیشنهاد مناسب نمایش داده شود و یا کلید
CTRL+SPACE
را بزنید تا به شما پیشنهاد مناسب را نشان دهد. - اگر خطایی در دستور اجرایی وجود داشته باشد، مثلاً شناسه را ذکر نکرده باشید، خطا به صورت کد HTTP و یک توضیح معمولاً مناسب ، برگشت داده می شود.
- سمت راست که نتیجه اجرای یک کوئری است همان جی سانی است که سرور به عنوان خروجی به ما برمی گرداند.برخی از این فیلد ها در زیر مشخص شده اند :
قبل از اینکه به سراغ جستجو و ارسال کوئری برویم ، دوباره دکمه سبز رنگ اجرایی را بزنید. یعنی همین دستور را دوباره اجرا کنید. بدون هیچ خطایی اجرا می شود و همان نتایج قبلی نمایش داده می شود با دو تغییر مهم : اول اینکه نسخه رکورد، به شماره ۲ تغییر می یابد و دوم اینکه نوع عملیات می شود به روزرسانی . اگر فیلد جدیدی به داده ها اضافه کنید و یا یکی از خصوصیات داده را تغییر دهید و درخواست را با دکمه سبزرنگ اجرا، به سرور ارسال کنید، یک نسخه جدید از داده ها ایجاد و ذخیره خواهد شد. می توانید هنگام تعیین کنید که نسخه های مختلف یک رکورد نگهداری شود یا نه .
نکته : برای به روزرسانی و ایجاد رکورد از هر دو دستور PUT و POST می توانید استفاده کنید اما بهتر است برای ایجاد از PUT و برای به روزرسانی از POST استفاده کنید. در حالت کلی،اگر آی دی و شناسه یک رکورد مشخص باشد، از PUT
استفاده کنید (هم برای ایجاد و هم به روز رسانی ) و اگر می خواهید شناسه را خود الستیک سرچ اختصاص دهد از پست به صورت زیر استفاده کنید :
در این صورت، یک ID
به صورت خودکار به این سند افزوده میشود اما این عمل تکرار پذیر نیست یعنی به ازای هر بار اجرای آن، سند جدیدی در دیتابیس ذخیره میشود بنابراین تنها زمانی از این حالت استفاده کنید که مطمئن باشید نیاز به تکرار عملیات نخواهید داشت.
قبل از ادامه آموزش، مقادیر زیر را هم وارد کنید تا برای جستجو، تعدادی داده داشته باشیم (منبع داده ها) :
نکته : می توانید همه دستورات را کپی و در پنل دستورات، بچسبانید اما هر دستور را جداگانه باید اجرا کنید. بنابراین نیاز به پاک کردن هر دستور و نوشتن دستور بعدی نیست و در ادامه لیست دستورات می توانید کار با الاستیک را ادامه دهید.
جستجو و بازیابی اطلاعات
هدف از این آموزش، کار با کیبانا است اما بهتر است چند کوئری ساده از الاستیک را هم با هم مرور کنیم. ابتدا می خواهیم اطلاعات یک فیلم خاص با شناسه مشخص را جستجو کنیم. از دستور زیر بهره می بریم :
GET /movies/_doc/1
نتیجه جستجوی یک شناسه خاص به صورت زیر نمایش داده می شود. ابتدا نام ایندکس ، نام گروه ، شناسه درخواستی ، نتیجه جستجو و در صورت پیدا کردن رکورد مورد نظر ، نتیجه به صورت پیش فرض درون فیلد source_ قرار می گیرد :
برای جستجوی اطلاعات معمولاً از ساختار زیر استفاده می کنیم :
در جلوی عبارت query به زبان DSL (Domain Specific Language) که زبان توصیف پرس و جوهای الاستیک سرچ است، به ورود مشخصات داد های مورد نظر خود می پردازیم.
در ادامه چند پرس و جوی رایج را در الاستیک سرچ با هم بررسی می کنیم.
جستجو به کمک query_string
یکی از ساده ترین راه ها برای جستجو در الاستیک بخصوص زمانی که جستجوی متن برای ما اهمینت دارد، استفاده از پرس و جوی query_string است. این نوع از پرس و جو، بسیار انعطاف پذیر بوده و به کمک تنها یک رشته، تمام نیازهای جستجوی ما را به راحتی برآورده می کند. کافیست درون فیلد query از این پرس و جو، کلمه یا عبارت مورد نظر خود برای یافتن را وارد کنیم و همزمان، شرطها و فیلترهای خود را هم درون رشته جستجو، به الاستیک ارسال نمائیم.
با یک مثال ساده شروع می کنیم. می خواهیم هر فیلمی که در آن کلمه kill
به کار رفته باشد (در هر فیلدی) را بیابیم . ذستور زیر را اجرا می کنیم :
این پرس و جو کلمه kill
را در تمامی فیلدهای گروه movie
جستجو نموده و به هر رکورد یک امتیاز اختصاص می دهد و نهایتاً طبق آن، به ترتیب، نتایج را به ما نشان خواهد داد. پنجره نتیجه شما باید حاوی داده های زیر باشد که فیلدهای اصلی آن در خود شکل توضیح داده شده است :
چند نکته در باره کوئری فوق :
- در انتهای جستجوها و کوئری ها از پایانگر
_search
استفاده می کنیم. پایانگرها یاEndPoint
ها، مشخص کننده نوع درخواست ارسالی به الاستیک هستند. - اگر بخواهیم در تمامی گروه های ایندکس
movies
جستجو کنیم، نام گروه را باید حذف کنیم و اگر بخواهیم در تمامی ایندکس ها (همه دیتابیس ها) جستجو کنیم، نام ایندکس را هم حذف می کنیم و به جای آن از_all
استفاده میکنیم. در این حالت دستور اصلی کوئری ما به این شکل خواهد بود:POST _all/_search
- در صورت اجرای چند باره کوئری فوق، زمان پاسخگویی کاهش می یابد که نشاندهنده این نکته است که کوئری ها در حافظه کش می شوند و اجرای مجدد همان کوئری بسیار سریعتر از اجرای اولیه آن خواهد بود.
اگر بخواهیم جستجوی خود را به یک فیلد خاص محدود کنیم مثلاً فقط در عنوان فیلم ها جستجو کند، از ساختار زیر استفاده می کنیم :
با اجرای دستور فوق که جستجوی کلمه ford است و این کلمه هم در فیلد کارگردان و هم در عنوان فیلم آمده است، تنها یک فیلم ظاهر خواهد شد که با شرایط تعیین شده کاملاً مطابق است. می توانید در لیست [“title”] بقیه فیلدهای مد نظر خود را هم وارد نمایید که با ویرگول از هم جدا شده اند.
مثال فوق را به راحتی می توانیم به صورت زیر هم بازنویسی کنیم :
"query_string" : {"query" : "title:ford"}
تمام فیلمهایی که در نام آنها kill یا ford به کار رفته است : (AND و OR و TO و سایر عملگرها با حروف بزرگ نوشته می شوند)
"query_string" : {"query" : "title:ford OR kill"}
تمام فیلم هایی که عنوان kill داشته و کارگردان آنها Tarantino است :
"query_string" : { "query": "(title:kill) AND (director:Tarantino)" }
تمام فیلم های ژانر درام در سال ۱۹۶۲ :
"query_string" : { "query":"(genres:Drama) AND (year:1962 )" }
تمام فیلم های ژانر درام تا سال ۲۰۰۵ (می توانید به جای * ابتدای بازه را قرار دهید) :
"query_string" : { "query":"(genres:Drama) AND (year:[* TO 2005] )" }
تمام فیلم های درام یا فیلم هایی که در نام آنها کلمه kill به کار رفته باشد :
"query_string" : {"query": "(genres:Drama) OR (title:kill)" }
اگر بخواهیم در مثال بالا، به عناوین حاوی kill اولویت بیشتری بدهیم از عملگر ^ که عملگر Boost نامیده می شود استفاده می کنیم. با اینکار در محاسبه امتیاز نهایی هر رکورد و اولویت نمایش دادن آن، امتیاز عنوان را بیشتر در نظر می گیرد و فیلمی بیشترین امتیاز را خواهد داشت که هم ژانر درام باشد و هم در عنوان آن kill به کار رفته باشد :
"query_string" : {"query": "(genres:Drama) OR (title:kill^2)" }
برای مشاهده مثالهای بیشتر به مستندات اصلی الاستیک سرچ در خصوص Query_Srting مراجعه نمایید.
ساخت یک درخت جستجو
روش دیگر برای ساخت یک پرس و جو، ایجاد درخت جستجو به صورت مرحله به مرحله و فیلد به فیلد است. در این حالت معمولاً خود جستجو روی یک داده خاص را با عبارت match
که برابری یک فیلد را با یک مقدار بررسی میکند و اعمال فیلتر روی رکوردها را قبل از بررسی و جستجو، با عبارت filter
انجام میدهیم.
دستور زیر تمام فیلم های ژانر درام را بر می گرداند :
دستور فوق تمامی فیلمها را بررسی کرده و فیلد genres
آنها را با کلمه Drama
مقایسه می کند. این دستور در حالت کلی تر به صورت زیر نوشته میشود که امکان افزودن تنظیماتی را به هر فیلد به صورت جزییتر به ما میدهد :
عبارت جلوی match
، آنالیز شده و سپس جستجو می شود یعنی تک تک کلمات آن جدا شده، ایست واژه ها (مانند از، به، که و …) حذف و سپس کلمات با همدیگر OR می شوند یعنی هر کدام از آنها مطابقت داشت، فیلم مورد نظر جزء خروجی قرار خواهد گرفت. برای تغییر این روال و تعیین حداقل تعداد کلمات مطابقت داده شده و یا AND
کردن آنها به مستندات match مراجعه کنید.
مثال زیر، عملگر را هم هنگام جستجو برای لغات داخل کوئری مشخص میکند :
اگر بخواهیم همزمان بر روی دو فیلد یا بیشتر جستجو انجام دهیم، می توانیم از عبارت multi_match
به صورت زیر استفاده کنیم :
در دستور فوق اولویت عنوان فیلم را سه برابر نام کارگردان، تعیین کرده ایم.
روش دیگر برای انجام کوئری فوق، ترکیب چند عبارت match
با عمگرهای OR
و AND
است که در کوئری زیر که یک کوئری Boolean
با کلید واژه مهم bool، نشان داده شده است :
دقت کنید که در دستور فوق، تمامی رکوردهای جدول فیلم بررسی می شود و دنبال فیلم های درام با عنوانی شامل kill می گردد.
نکته مهم : در عبارات منطقی و ساخت جستجوهای پیشرفته، must را معادل AND ، عبارت should را معادل OR و must_not را معادل NOT در نظر بگیرید. با این توصیف دستور زیر تمامی فیلم هایی که در
( عنوان آنها کلمه Ford یا Kill به کار رفته است ) و ( ژانر آنها اسرارآمیز نیست)
را بر می گرداند.
نکته دیگر اینکه درون یک عبارت bool هر کدام از عبارت های must، must_not و should تنها یک بار باید ظاهر شود.
جستجوی فیلدهای غیرمتنی
برای جستجوی فیلدهای غیر متنی از نوع کوئری Term
استفاده میکنیم .
البته اگر دقیقا به دنبال یک عبارت یا کلمه باشیم، میتوانیم از کوئریهای Term
برای فیلدهای متنی هم استفاده کنیم. مثلا نام یک شهر، میتواند با این نوع کوئری ، جستجو شود.
اعمال فیلتر در جستجو
بسیاری از اوقات می خواهیم، رکوردها و داده های جستجو شونده را محدود کنیم مثلاً دنبال فیلم های سال ۱۹۷۲ هستیم که فلان کارگردان نوشته است. در این حالت، علاوه بر اینکه باید پرس و جو را به نام کارگردان محدود کنیم و در بالا به آن اشاره شده است، گام دیگری که باید برداریم، این است که تنها در داده های این سال جستجو را آغاز کنیم. فیلترینگ، سرعت جستجو را بسیار بالا می برد چون تعداد سندهای لازم برای جستجو را کاهش می دهد. اعمال محدودیت روی رکوردهای مورد جستجو را فیلترینگ می نامیم و به صورت زیر آنرا اعمال می کنیم :
دستور فوق ابتدا تمام فیلم های تولید شده بعد از سال ۱۹۶۰ و از ژانر درام را فیلتر کرده ، سپس به دنبال فیلمهایی که عنوان آنها شامل kill باشد، می گردد.
میتوانیم کوئری فوق را به صورت خلاصه شده زیر هم بنویسیم یعنی عبارت filter
را حذف کنیم اما در حالت کلی، جستجوهای ما در الستیک سرچ از دو بخش اصلی تشکیل شده اند : بخش متنی و بخش غیرمتنی که فیلتر ما را تشکیل میدهد و ابتدا دادهها بر اساس این فیلتر، انتخاب شده و سپس فرآیند بازیابی متن و امتیازدهی به نتایج انجام میشود.
در مثال فوق، اگر بخواهیم تنها بر اساس ژانر و سال یعنی بخش داخل فیلتر ، داده ها را جستجو کنیم و جستجوی متن، انجام ندهیم، دو راه داریم : اول اینکه داخل بخش must که همان پرس و جوی اصلی ما بعد از اعمال فیلتر است، اعلام کنیم که همه داده ها را برگرداند :
و یا اینکه کلا بخش پرس و جو را حذف کنیم و جستجوی ما بر اساس مقادیر فیلدها مانند سال و رشته و ژانر و … باشد.
دقت کنید که در بخش فیلتر ما معمولاً از عبارت term یا terms برای بررسی برابری یک فیلد با یک یا چند مقدار استفاده می کنیم. دقت کنید که برای فیلدهای متنی در صورتی از term استفاده کنید که یا تنها یک کلمه باشد و یا نوع آن فیلد را keyword تعیین کنید که در ادامه توضیح داده خواهد شد.
چند دستور کاربردی
اگر بخواهیم غلطهای املایی در کلمات مورد جستجو را هم الاستیک بخواهیم در نظر بگیرد و یک جستجوی فازی (تقریبی) به ما برگرداند از عبارت “fuzziness”: “AUTO” مشابه با کوئری زیر که در آن فیلم پدرخوانده به اشتباه به صورت godfater
آمده است، بهره می بریم :
خیلی از اوقات به دنبال یک عبارت هستیم مثلاً می خواهیم فیلم های kill bill
را دقیقاً به همین شکل بیابیم. کوئری زیر به الاستیک اعلام می کند که به دنبال یک عبارت هستیم و باید دقیقاً کلمات ذکر شده پشت سرهم ظاهر شده باشند و نهایتاً سه فضای خالی بین هر کلمه تا بعدی را می توانیم قبول کنیم :
یک اشکال رایج
اگر شما به دنبال جستجوی کارگردانی با نام Francis Ford Coppola باشید و آنرا به صورت زیر جستجو کنید، علیرغم اینکه این مقدار در دیتابیس شما وجود دارد، اما جوابی به شما برگشت نخواهد کرد.
دلیل این موضوع هم این است که الاستیک سرچ به صورت پیش فرض، متن ها را آنالیز و پردازش کرده، آنها را به کلمات تشکیل دهنده شان تجزیه و تک تک کلمات را جداگانه شاخص زنی می کند. اگر می خواهید کل متن را یکجا ایندکس کنید، باید نوع آنرا keyword قرار دهید. با انجام اینکار دیگر روی تک تک کلمات آن فیلد، امکان جستجو نخواهید داشت که این هم خود مشکلی دیگر است.
راه حل الاستیک برای حل این مشکل، تعیین فیلدهای چندمقداره است که علاوه بر مقدار اصلی آنها، می توان نوع دومی را هم به با نام دیگری به آنها اضافه کرد تا هر یک جداگانه آنالیز و ایندکس شوند. دستور زیر یک نام دوم original با نوع keyword برای کارگردان تعیین می کند. (به پایانگر mapping در انتهای دستور اصلی توجه کنید )
البته برای اعمال این تغییرات احتمالا نیاز به عملیات reindex خواهید داشت (انتقال داده ها به یک جدول جدید) و یا ابتدا این دستور را برای یک جدول جدید اجرا کرده و سپس عملیات ورود داده را از ابتدا روی آن انجام دهید . روش ساده تری برای حل این مشکل در ادامه ،بیان شده است که می توانید از آن استفاده کنید.
حال کافیست اگر بخواهیم نام کامل کارگردان را جستجو کنیم، به صورت زیر عمل نماییم :
راه ساده تر این کار استفاده از field.keyword
بود که برای همه فیلدها در دسترس است و نیاز به استفاده از فیلدهای چندمقداره برای کارگردان هم نبود. یعنی در مثال فوق کافی بود به جای "director":"Francis Ford Coppola"
و بدون تغییر در نوع داده، عبارت "director.keyword":"Francis Ford Coppola"
را بنویسیم .
برای مشاهده و مرور دقیق تر این دستورات و نیز آشنایی اولیه با چند دستور کاربردی دیگر از الاستیک سرچ می توانید از این مقاله آموزشی هم استفاده کنید.
در تهیه این آموزش از مثالهای این سایت استفاده شده است.
پی نوشت :
در نسخه ۶٫۳٫۰ الاستیک، قابلیت نوشتن کوئری به زبان SQL هم به الاستیک سرچ افزوده شده است که برای علاقهمندان این موتور جستجو، میتواند اطمینان خاطری باشد در پاسخگویی سریع به نیازهای جستجوی روزانه .
سلام تشکر عالی بود بحث امنیت الستیک به چه روال هست ؟
الاستیک سرچ که روی سرورهای داخلی شرکت نصب میشود و تنظیمات امنیتی اون دست شماست . چون معمولاً از طریق ای پی آی و برنامههای خودتون درون سرور محلی به اون وصل میشید، کافیه پورت های پیش فرض اون را روی سرور اصلی تون ببندید که از بیرون قابل دسترسی نباشه.
احراز هویت کاربر را هم از طریق برنامه و سرویس اصلی تون می تونید انجام بدید.
سلام
خیلی ممنون از آموزشتون خیلی به به دردم خورد.
اگر میشه در مورد نحوه استفاده و پیکربندی کیبانا هم آموزش بذارید ممنون.
سلام
من میخوام وقتی مثلا عبارت «علی رضا» جستجو میشه، نتایج «علی رضا» و «علیرضا» اول نمایش داده بشن،
«علی» و «رضا» بعد از اونا
و «محمدعلی» و «امیررضا» و سایر عبارات ترکیبی در آخر.
میتونین یه راهنمایی کنین؟؟؟
ممنونم از آموزش خوبتون
واقعا ممنون از آموزش خوب و با کیفیت شما
تشکر از آموزش کامل شما
سلام
باتشکر از سایت بسیار عالی شما
بیان مطالب بسیار عالی هست
فقط یک انتقاد دارم از تبلیغ کاشت مو کنار صفحه
خیلی تصویر مشمئز کننده ای داره. خواهشا تبلیغاتی که مثل این تصویر زشت و زننده ای دارند را قرار ندهید.
سلام. حق باشماست و به زودی تمام این تبلیغات از سایت حذف خواهند شد.
یک دنیا سپاس
از این خوبتر نمیشد یاد داد الستیک رو