SpringBoot整合ElasticSearch搜索引擎之一

1、ElasticSearch

Elasticsearch是一个基于Apache Lucene(TM)的开源搜索引擎。无论在开源还是专有领域,Lucene可以被认为是迄今为止最先进、性能最好的、功能最全的搜索引擎库。

2、添加依赖

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

3、创建ElasticSearchConfig

@Configuration
@EnableElasticsearchRepositories("com.lianggzone.springboot.action.data.elasticsearch")
public class ElasticsearchConfig2 {
 
    private String hostname = "127.0.0.1";
    private int port = 9300;
 
    @Bean
    public ElasticsearchOperations elasticsearchTemplate() {
        return new ElasticsearchTemplate(client());
    }
 
    @Bean
    public Client client() {
        TransportClient client = new TransportClient();
        TransportAddress address = new InetSocketTransportAddress(hostname, port);
 
        client.addTransportAddress(address);
        return client;
    }
}

4、创建Controller

@RestController
@RequestMapping(value="/data/elasticsearch/news")
public class NewsController {
 
    @Autowired
    private NewsService newsService;
 
    /**
     * 初始化
     * @param request
     */
    @RequestMapping(value = "/init", method = RequestMethod.POST)
    public void init(HttpServletRequest request) {
        this.newsService.init();
    }
 
    /**
     * findAll        
     * @param request
     * @return
     */
    @RequestMapping(value = "/", method = RequestMethod.GET)
    public Map<String, Object> findList(HttpServletRequest request) {
        Map<String, Object> params = new HashMap<String, Object>();
        params.put("items", this.newsService.findAll());
        return params;
    }
 
    /**
     * find      
     * @param request
     * @return
     */
    @RequestMapping(value = "/{title}", method = RequestMethod.GET)
    public Map<String, Object> search(@PathVariable String title) {
        // 构建查询条件
        QueryBuilder queryBuilder = QueryBuilders.queryString(title);
        Map<String, Object> params = new HashMap<String, Object>();
        params.put("items", this.newsService.search(queryBuilder));
        return params;
    }
}



Spring Boot是一个非常流行的Java web开发框架,Elasticsearch是一款开源的搜索引擎,两者的结合可以提供非常强大的搜索功能。下面是整合步骤: 1. 引入Elasticsearch依赖 在pom.xml文件中添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-elasticsearch</artifactId> </dependency> ``` 2. 配置Elasticsearch连接信息 在application.properties文件中添加以下配置: ```properties spring.data.elasticsearch.cluster-name=my-application spring.data.elasticsearch.cluster-nodes=localhost:9300 ``` 其中,cluster-name和cluster-nodes分别指定Elasticsearch集群名称和连接地址。 3. 定义Elasticsearch数据模型 使用@Entity注解标注Java类,将其映射到Elasticsearch中的一个数据类型。例如: ```java @Entity public class Book { @Id private String id; private String name; private String author; // getters and setters } ``` 4. 定义Elasticsearch数据访问接口 使用ElasticsearchRepository接口,继承该接口即可获得Elasticsearch数据访问的基本方法。例如: ```java public interface BookRepository extends ElasticsearchRepository<Book, String> { List<Book> findByName(String name); } ``` 5. 使用Elasticsearch数据访问接口 在业务逻辑中使用BookRepository接口中定义的方法进行数据访问。例如: ```java @Service public class BookService { @Autowired private BookRepository bookRepository; public List<Book> search(String keyword) { return bookRepository.findByName(keyword); } } ``` 以上就是Spring Boot整合Elasticsearch的基本步骤。通过以上步骤,可以快速搭建一个基于Elasticsearch的高效搜索引擎
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值