Elasticsearch

Elasticsearch — тиражируемая свободная программная поисковая система, по состоянию на середину 2010-х годов — самая популярная в своей категории[2][неавторитетный источник?]. Написана на Java, распространяется по лицензии SSPL, в основе использует библиотеку Lucene (так же как и вторая по популярности поисковая система — Solr), официальные клиенты доступны на Java, .NET (C#), Python, Groovy и ряде других языков.

Elasticsearch
Логотип программы Elasticsearch
Тип Поиск и индексация
Автор Шай Банон[d]
Разработчик Шай Бейнон
Написана на Java
Операционная система Кроссплатформенная
Первый выпуск 8 февраля 2010
Аппаратная платформа Java Virtual Machine
Последняя версия
Состояние Active
Лицензия Эластичная с двойной лицензией (проприетарная; источник доступен) and Server Side Public License (проприетарный; источник доступен)
Сайт elastic.co/products/elasticsearch
Логотип Викисклада Медиафайлы на Викискладе
Шай Банон в Берлине на Buzzwords 2010

Разрабатывается компанией Elastic вместе со связанными проектами — механизмом сбора данных и анализа журналов Logstash и платформой аналитики и визуализации Kibana; эти три продукта предназначены для использования в качестве интегрированного решения, называемого «Elastic Stack»[3].

Среди крупных сайтов, использующих Elasticsearch, отмечаются Wikimedia, StumbleUpon, Quora, Foursquare, SoundCloud, GitHub и Netflix. Amazon, IBM, Qbox и компания Elastic предлагают подписчикам Elasticsearch в качестве управляемого сервиса[4][5][6], большинство таких публично-облачных управляемых услуг также включают поддержку Kibana[7].

ИсторияПравить

В 2004 году Шай Бейнон (Shay Banon) создал предшественника Elasticsearch — систему Compass[en][8]. Разрабатывая третью версию Compass, Бейнон пришёл к выводу, что для создания масштабируемой версии системы, необходимо создавать программу «с нуля», в результате в феврале 2010 года была выпущена первая версия Elasticsearch[9].

Для коммерциализации проекта Бейнон в 2012 году основал нидерландскую компанию Elasticsearch BV[10]. В июне 2014 года компания объявила о привлечении $70 млн в рамках цикла финансирования серии C, отбор проходил под руководством New Enterprise Associates (NEA), дополнительными спонсорами стали Benchmark Capital и Index Ventures, в результате раунд принёс фирме общее финансирование $104 млн[11].

В марте 2015 года компания Elasticsearch изменила свое название на Elastic[12].

ВозможностиПравить

Обеспечивает горизонтально масштабируемый поиск, поддерживает многопоточность. Поисковые индексы можно разделить на сегменты, каждый сегмент может иметь несколько реплик, на каждом узле может быть размещено несколько сегментов, при том каждый узел действует как координатор для делегирования операций правильному сегменту, перебалансировка и маршрутизация выполняются автоматически. Связанные данные часто хранятся в одном и том же индексе, который состоит из одного или нескольких первичных сегментов и, возможно, нескольких реплик. После создания индекса количество первичных сегментов нельзя изменить[13].

Все функции Lucene системы доступны через прикладные интерфейсы на JSON и Java.

Другая особенность — так называемый «шлюз», обеспечивающий долгосрочное сохранение индекса; например, индекс может быть восстановлен из шлюза в случае сбоя сервера. Система поддерживает запросы GET в реальном времени. Система не поддерживает распределённые транзакции[14].

Коммерческая частьПравить

В коммерческой версии поисковой системы реализован ряд функций, не включённых в свободный вариант программы, в том числе, ролевая модель для пользователей, механизм уведомлений пользователей о событиях в системе, движки машинного обучения и графового анализа. Платная часть поставляется в форме годовой подписки.

ПримечанияПравить

  1. Release 7.13.2 — 2021.
  2. DB-Engines Ranking - popularity ranking of search engines (недоступная ссылка). db-engines.com. Дата обращения: 10 января 2016. Архивировано 19 октября 2018 года.
  3. The Elastic Stack. Elastic.co. Дата обращения: 28 марта 2019.
  4. Elastic Cloud. Elastic.co. Дата обращения: 16 октября 2016.
  5. Hosted Elasticsearch. qbox.io. Дата обращения: 16 октября 2016.
  6. Elasticsearch on IBM Cloud. www.bluemix.net. Дата обращения: 25 января 2017.
  7. Elasticsearch Setup (недоступная ссылка). ctovision.com. Дата обращения: 16 октября 2016. Архивировано 21 августа 2018 года.
  8. Banon, Shay The Future of Compass & ElasticSearch.
  9. Banon, Shay You Know, for Search (8 февраля 2010). Архивировано 16 января 2013 года.
  10. Immediate Insight from Data Matters. elastic.co. Дата обращения: 25 марта 2015.
  11. ElasticSearch Scores $70M In Series C To Fund Growth Spurt. TechCrunch. AOL. Дата обращения: 25 марта 2015.
  12. Elasticsearch Changes Name to Elastic to Reflect Wide Adoption Beyond Search. Elastic. Дата обращения: 19 октября 2016.
  13. How to monitor Elasticsearch performance (недоступная ссылка). Дата обращения: 12 мая 2017. Архивировано 18 декабря 2018 года.
  14. No transaction support (недоступная ссылка). Elasticsearch-users.115913.n3.nabble.com (8 июля 2010). Дата обращения: 4 февраля 2014. Архивировано 6 октября 2018 года.

ЛитератураПравить

  • Берримен Дж., Тарнбулл Д. Релевантный поиск с использованием Elasticsearch и Solr = Relevant Search. — ДМК-Пресс, 2018. — 408 с. — ISBN 978-5-97060-592-9.

СсылкиПравить