在本教程中,我将向您展示如何通过将Solr与Spring Boot集成来改进搜索。 Spring-data-solr 是Spring Data的扩展,用于将Solr与Spring Boot starter集成。
什么是Solr
Apache Solr既是搜索引擎又是支持SQL的分布式文档数据库。Solr核心是个搜索引擎,但远不止于此。它是一个具有事务支持的NoSQL数据库。
步骤:
注意: 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上检查项目。