转载

Solr与Spring Boot集成 - Viithiisys

在本教程中,我将向您展示如何通过将Solr与Spring Boot集成来改进搜索。 Spring-data-solr 是Spring Data的扩展,用于将Solr与Spring Boot starter集成。

什么是Solr

Apache Solr既是搜索引擎又是支持SQL的分布式文档数据库。Solr核心是个搜索引擎,但远不止于此。它是一个具有事务支持的NoSQL数据库。

步骤:

  • 配置Solr
  • 创建Solr文档
  • 创建Solr存储库

注意: github项目中 提供了Solr REST API的完整示例。

配置Solr

你可以 在这里 下载Solr 

基本Solr命令:

Directory solr/solr-5.3.1
Start Solr: ./bin/solr start
Stop Solr: ./bin/solr stop
Check Logs: tail -f server/logs/solr.log
Start Solr on a different port: ./bin/solr start -p 2000

运行Solr:

cd solr/solr-5.3.1
./bin/solr start

创建Core:

./bin/solr create -c user_core

与Spring Boot Project集成

添加依赖项Maven:

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-data-solr</artifactId>
  </dependency>

Gradle:

implementation('org.springframework.boot:spring-boot-starter-data-solr')

创建Solr文档:

Solr文档是使用@SolrDocument注释创建的,其核心是在其中定义的。

@Indexed注释用于字段以使其可搜索。

<b>import</b> org.springframework.data.annotation.Id;
<b>import</b> org.springframework.data.solr.core.mapping.Indexed;
<b>import</b> org.springframework.data.solr.core.mapping.SolrDocument;

<font><i>/**
 * @author anuragdhunna
 */</i></font><font>

@SolrDocument(solrCoreName = </font><font>"user_core"</font><font>)
<b>public</b> <b>class</b> UserDoc {

    @Id
    @Indexed
    <b>private</b> String id;

    @Indexed(name = </font><font>"username"</font><font>, type = </font><font>"string"</font><font>)
    <b>private</b> String username;

    @Indexed(name = </font><font>"email"</font><font>, type = </font><font>"string"</font><font>)
    <b>private</b> String email;

    @Indexed(name = </font><font>"phone_number"</font><font>, type = </font><font>"string"</font><font>)
    <b>private</b> String phoneNumber;

    </font><font><i>// Getter Setters </i></font><font>
}
</font>

创建Solr仓储:

<b>import</b> com.anuragdhunna.solrIntegration.documents.UserDoc;
<b>import</b> org.springframework.beans.factory.annotation.Qualifier;
<b>import</b> org.springframework.data.solr.repository.Query;
<b>import</b> org.springframework.data.solr.repository.SolrCrudRepository;
<b>import</b> org.springframework.stereotype.Repository;

<b>import</b> java.util.List;

<font><i>/**
 * @author anuragdhunna
 */</i></font><font>

@Repository
@Qualifier(</font><font>"userSolrRepo"</font><font>)
<b>public</b> <b>interface</b> UserSolrRepo <b>extends</b> SolrCrudRepository<UserDoc, String> {

    @Query(value = </font><font>"*:*"</font><font>)
    List<UserDoc> getUsers();

}
</font>

注意:如果Solr在不同的端口上运行(8983),请在application.properties文件中添加一个属性:

spring.data.solr.host = http:<font><i>//127.0.0.1:3000/solr</i></font><font>
</font>

对于完整的API参考,您可以在Github上检查项目。

原文  https://www.jdon.com/51618
正文到此结束
Loading...