Solr与Spring Boot集成 - Viithiisys

19-01-29 banq
              

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