在本教程中,我将向您展示如何通过将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注释用于字段以使其可搜索。
import org.springframework.data.annotation.Id;
import org.springframework.data.solr.core.mapping.Indexed;
import org.springframework.data.solr.core.mapping.SolrDocument;
/**
* @author anuragdhunna
*/
@SolrDocument(solrCoreName = "user_core")
public class UserDoc {
@Id
@Indexed
private String id;
@Indexed(name = "username", type = "string")
private String username;
@Indexed(name = "email", type = "string")
private String email;
@Indexed(name = "phone_number", type = "string")
private String phoneNumber;
// Getter Setters
}
|
创建Solr仓储:
import com.anuragdhunna.solrIntegration.documents.UserDoc;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.data.solr.repository.Query;
import org.springframework.data.solr.repository.SolrCrudRepository;
import org.springframework.stereotype.Repository;
import java.util.List;
/**
* @author anuragdhunna
*/
@Repository
@Qualifier("userSolrRepo")
public interface UserSolrRepo extends SolrCrudRepository<UserDoc, String> {
@Query(value = "*:*")
List<UserDoc> getUsers();
}
|
注意:如果Solr在不同的端口上运行(8983),请在application.properties文件中添加一个属性:
spring.data.solr.host = http://127.0.0.1:3000/solr
|
对于完整的API参考,您可以在Github上检查项目。