Elasticsearch学习(1) Spring boot整合Elasticsearch

转自https://www.cnblogs.com/daijiting/p/10169258.html

本文的Spring Boot版本为1.5.9,Elasticsearch版本为2.4.4,话不多说,直接上代码。

一、启动Elasticsearch

  在官网上下载Elasticsearch后,打开bin目录下的elasticsearch.bat,出现下面的图,就证明成功启动了。

 

二、新建项目,添加依赖

  在创建spring boot项目中,可以在nosql中选择添加Elasticsearch的依赖,完整的依赖如下:

View Code

  需要注意的是:

  1.spring boot2.X版本必须使用Elasticsearch 5.X版本

  2.Elasticsearch 2.X的版本必须使用spring boot1.5版本

  3.目前spring-boot-starter-data-elasticsearch还不支持Elasticsearch 6.X版本

  如果出现版本不兼容,这会出现下面的错误:

NoNodeAvailableException[None of the configured nodes are available: [{#transport#-1}{729dgKKVSF-ti27v2_w68g}{127.0.0.1}{127.0.0.7:9300}]]

三、Elasticsearch的配置文件

  和操作数据库一样,我们需要配置好配置文件,才能访问Elasticsearch,配置文件如下:

##端口号
server.port=8888
##es地址
spring.data.elasticsearch.cluster-nodes =127.0.0.1:9300

四、Elasticsearch的实体类

  在Elasticsearch中,我们需要创建一个实体类作为索引,简单的理解就是在Elasticsearch中创建数据库和表。

   利用@Document注解可以创建数据库和表。其中Document中的参数意义为:

   indexName:索引名称 可以理解为数据库名 必须为小写不然会报org.elasticsearch.indices.InvalidIndexNameException异常

        type:类型 可以理解为表名

    代码如下:  

View Code

五、创建一个数据访问层

  同样,和其他的数据库访问操作一样,我们需要创建一个dao层来操作Elasticsearch,这个dao层类似于mongodb的操作,只需要继承ElasticsearchRepository接口就能实现。

View Code

六、创建controller层测试

View Code

在添加几条数据后我们访问head插件---ES管理界面可以看到我们添加的数据库在页面上

在数据浏览界面中可以看到我们添加的数据

在基本查询中可以根据表名和条件,查询我们刚才插入的数据

七、项目中出现的错误

   直接上错误代码:

复制代码

Description:

Cannot determine embedded database driver class for database type NONE

Action:

If you want an embedded database please put a supported one on the classpath. 
If you have database settings to be loaded from a particular profile you may need to active it (no profiles are currently active).

复制代码

          这个错误是由于打开了spring boot的自动配置数据,但是没有配置数据源,所以报错,解决的方案是直接关闭数据源自动配置,

   只需要在启动类上加入:@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})即可

复制代码

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;

@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
public class ElasticsearchApplication {

    public static void main(String[] args) {
        SpringApplication.run(ElasticsearchApplication.class, args);
    }
}

复制代码

八、小结 

  这就是spring boot1.5整合ElasticSearch 2.X的操作,本文作为初级学习起来还是有帮助,但是ElasticSearch 中的一些高级操作如:同步数据库,分词器,高亮等都将在后面的文章中进行书写。ElasticSearch 6.X、ElasticSearch 5.X的API方式也和ElasticSearch 2.X不同,我也会放在后面进行讲解。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值