/springboot-indexinghibernatesearch

spring-boot and indexing with hibernate-search. Hibernate Search will transparently index every entity persisted, updated, or removed through Hibernate Core. However, you have to trigger initial indexing to populate the Lucene index with the data already present in your database.

Primary LanguageJava

Spring Boot and Indexing with Hibernate-Search

Hibernate Search (Full-text search for entities):

Hibernate Search automatically extracts data from Hibernate ORM entities to push it to local Apache Lucene indexes or remote Elasticsearch indexes. It features:

  • Declarative mapping of entity properties to index fields, either through annotations or a programmatic API.
  • On-demand mass indexing of all entities in the database, to initialize the indexes with pre-existing data.
  • On-the-fly automatic indexing of entities modified through a Hibernate ORM session, to always keep the indexes up-to-date.
  • A Search DSL to easily build full-text search queries and retrieve the hits as Hibernate ORM entities.

Apache Lucene and Solr:

  • Lucene Core is a Java library providing powerful indexing and search features, as well as spellchecking, hit highlighting and advanced analysis/tokenization capabilities.
  • SolrTM is a high performance search server built using Lucene Core. Solr is highly scalable, providing fully fault tolerant distributed indexing, search and analytics. It exposes Lucene's features through easy to use JSON/HTTP interfaces or native clients for Java and other languages.

Elasticsearch and Kibana:

  • Elasticsearch is a distributed, RESTful search and analytics engine capable of addressing a growing number of use cases. As the heart of the Elastic Stack, it centrally stores your data for lightning fast search, fine‑tuned relevancy, and powerful analytics that scale with ease.
  • Kibana is a free and open user interface that lets you visualize your Elasticsearch data and navigate the Elastic Stack. Do anything from tracking query load to understanding the way requests flow through your apps.

Implementation:

  • In order to use Hibernate Search, you should be familiar with the Hibernate ORM APIs, or the JPA APIs
  • Hibernate Search is not released as part of Hibernate ORM, so its version number will often be different.
  • Hibernate Search can be run in any environment able to run Hibernate ORM. (Java SE, Java EE containers, OSGi containers, Apache Tomcat, within Spring )

Default Values in Configuration:

org.hibernate.search.annotations.Store.NO
org.hibernate.search.annotations.Index.YES
org.hibernate.search.annotations.Analyze.YES

Lucene Version:

further references:

Project Descriptions:

please see application.properties files in resources folder and select a active profile "dev" or "com" to run project. you can check test methods too.

IntellliJ IDEA Configurations:

  • IntelijIDEA: Help -> Edit Custom Vm Options -> add these two line:
    • -Dfile.encoding=UTF-8
    • -Dconsole.encoding=UTF-8
  • IntelijIDEA: File -> Settings -> Editor -> File Encodings-> Project Encoding: form "System default" to UTF-8. May be it affected somehow.
  • IntelijIDEA: File -> Settings -> Editor -> General -> Code Completion -> check "show the documentation popup in 500 ms"
  • IntelijIDEA: File -> Settings -> Editor -> General -> Auto Import -> check "Optimize imports on the fly (for current project)"
  • IntelijIDEA: File -> Settings -> Editor -> Color Scheme -> Color Scheme Font -> Scheme: Default -> uncheck "Show only monospaced fonts" and set font to "Tahoma"
  • IntelijIDEA: Run -> Edit Configuration -> Spring Boot -> XXXApplication -> Configuration -> Environment -> VM Options: -Dspring.profiles.active=dev
  • IntelijIDEA: Run -> Edit Configuration -> Spring Boot -> XXXApplication -> Code Coverage -> Fix the package in include box