forked from jhipster/jhipster.github.io
-
Notifications
You must be signed in to change notification settings - Fork 0
/
using_elasticsearch.html
30 lines (28 loc) · 1.81 KB
/
using_elasticsearch.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
---
layout: default
title: Using Elasticsearch
sitemap:
priority: 0.7
lastmod: 2015-04-20T00:00:00-00:00
---
<h1><i class="icon-search"></i> Using Elasticsearch</h1>
<p>
Elasticsearch is an option that adds seach capabilities on top of your database.
</p>
<p>
This option has some limitations:
<ul>
<li>It only works with Java 8.</li>
<li>It only works with SQL databases. There should not be too much work to add this feature to the Cassandra and MongoDB options, but as Elasticsearch support is new in JHipster, we first focus on our main use case before making it available for everyone.</li>
</ul>
</p>
<p>
When the Elasticsearch option is selected:
<ul>
<li>Spring Data Elasticsearch is being used, and is automatically configured by Spring Boot.</li>
<li>By default, we use an embedded Elasticsearch in development, and try to connect to a local cluster in production. This can be configured by the standard Spring Boot properties, in the <code>application.yml</code> file.<br> When using the dev profile, the embedded Elasticsearch is configured to store data files under the target folder, a simple <code>mvn clean</code> will destroy the persisted indices.</li>
<li>The "repository" package has new subpackage, called "search", that holds all ElastiSearch repositories.</li>
<li>The "User" entity gets indexed in Elasticsearch, and you can query is using the <code>/api/_search/users/:query</code> REST endpoint.</li>
<li>When the <a href="{{ site.url }}/creating_an_entity.html">entity sub-generator</a> is used, the generated entity gets automatically indexed by Elasticsearch, and is used in the REST endpoint. Search capabilities are also added to the AngularJS user interface, so you can search your entity in the main CRUD screen.</li>
</ul>
</p>