在本教程中,我将向您展示如何通过将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上检查项目。