Springboot 配置使用 Elasticsearch

一、安装Elasticsearch

1、Windows安装

Windows安装比较简单,ES官网Download Elasticsearch | Elastic下载压缩包,解压出来, bin 目录下有个elasticsearch.bat,双击,就运行起来了。

然后在浏览器输入localhost:9200验证,成功会返回下面的图片。

二、开始写代码

我的springboot版本是2.7.5,ES是7.17.3

官方文档

项目结构如下:

1、引入依赖

xml 复制代码
<!-- spring data es -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-elasticsearch</artifactId>
        </dependency>
        <!-- https://mvnrepository.com/artifact/jakarta.json/jakarta.json-api -->
        <dependency>
            <groupId>jakarta.json</groupId>
            <artifactId>jakarta.json-api</artifactId>
            <version>2.0.1</version>
        </dependency>

2、配置文件

两种方式
(1)yaml配置文件

yaml 复制代码
server:
  port: 8081
spring:
  elasticsearch:
    # elasticsearch地址
    uris: localhost:9200
    connection-timeout: 30000
    socket-timeout: 50000
    socket-keep-alive: false

(2)api 方式

会覆盖掉yml

java 复制代码
import co.elastic.clients.elasticsearch.ElasticsearchClient;
import co.elastic.clients.json.jackson.JacksonJsonpMapper;
import co.elastic.clients.transport.ElasticsearchTransport;
import co.elastic.clients.transport.rest_client.RestClientTransport;
import org.apache.http.HttpHost;
import org.elasticsearch.client.RestClient;
import org.springframework.boot.SpringBootConfiguration;
import org.springframework.context.annotation.Bean;

/**
 * @author 
 */
@SpringBootConfiguration
public class ElasticSearchConfig {
    @Bean
    public ElasticsearchClient elasticsearchClient(){
        RestClient client = RestClient.builder(new HttpHost("localhost", 9200))
                .setRequestConfigCallback(requestConfigBuilder -> requestConfigBuilder
                        .setConnectTimeout(30000)
                        .setSocketTimeout(50000))
                .build();
        ElasticsearchTransport transport = new RestClientTransport(client, new JacksonJsonpMapper());
        return new ElasticsearchClient(transport);
    }

}

3、新建 User 实体类

id这个字段一定要有,作为主键索引,这个@Document里面的indexName就相当于mysql里面的表名,在elasticsearch里面叫索引。

java 复制代码
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.data.annotation.Id;
import org.springframework.data.elasticsearch.annotations.Document;

@Data
@AllArgsConstructor
@NoArgsConstructor
@Document(indexName = "user")
public class User {
    @Id
    private String id;
    private String name;
    private String sex;
    private Integer age;
}

4、新建 UserRepository

java 复制代码
import com.example.demo.document.User;
import org.springframework.data.elasticsearch.repository.ElasticsearchRepository;

/**
 * @author 
 */
public interface UserRepository extends ElasticsearchRepository<User, String> {
}

5、新建 Controller

java 复制代码
import com.example.demo.document.User;
import com.example.demo.repository.UserRepository;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/user")
public class UserController {
    private final UserRepository userRepository;

    public UserController(UserRepository userRepository){
        this.userRepository = userRepository;
    }

    /**
     * 添加
     */
    @RequestMapping("/insert")
    public String insert() {
        User user = new User();
        user.setId("1");
        user.setName("徐一杰");
        user.setSex("男");
        user.setAge(22);
        userRepository.save(user);
        return "success";
    }

    /**
     * 删除
     */
    @RequestMapping("/delete")
    public String delete() {
        User user = userRepository.findById("1").get();
        userRepository.delete(user);
        return "success";
    }

    /**
     * 局部更新
     */
    @RequestMapping("/update")
    public String update() {
        User user = userRepository.findById("1").get();
        user.setName("泡泡");
        userRepository.save(user);
        return "success";
    }
    /**
     * 查询
     */
    @RequestMapping("/get")
    public User get() {
        User user = userRepository.findById("1").get();
        System.out.println(user);
        return user;
    }

    @RequestMapping("/getAll")
    public Page<User> getAll() {
        Pageable pageable = PageRequest.of(1,20);
        Page<User> user = userRepository.findAll(pageable);
        System.out.println(user);
        return user;
    }
}

6、测试

(1) 启动项目

可以看到,我们的user索引自动添加到elasticsearch里面了。


(2) 查询索引

我们用postman请求 http://localhost:8081/user/getAll,可以看到,返回了 user 的信息。

相关推荐
咖啡啡不加糖10 分钟前
RabbitMQ 消息队列:从入门到Spring Boot实战
java·spring boot·rabbitmq
玩代码17 分钟前
Java线程池原理概述
java·开发语言·线程池
NE_STOP20 分钟前
SpringBoot--如何给项目添加配置属性及读取属性
java
水果里面有苹果22 分钟前
20-C#构造函数--虚方法
java·前端·c#
%d%d226 分钟前
python 在运行时没有加载修改后的版本
java·服务器·python
金銀銅鐵32 分钟前
[Kotlin] 单例对象是如何实现的?
java·kotlin
泰勒疯狂展开33 分钟前
Java研学-MongoDB(三)
java·开发语言·mongodb
zzywxc78739 分钟前
AI技术通过提示词工程(Prompt Engineering)正在深度重塑职场生态和行业格局,这种变革不仅体现在效率提升,更在重构人机协作模式。
java·大数据·开发语言·人工智能·spring·重构·prompt
张先shen1 小时前
Elasticsearch RESTful API入门:索引的增删改查完全指南
java·大数据·elasticsearch·搜索引擎·架构·全文检索·restful
天天摸鱼的java工程师1 小时前
工作八年,如果现在让我重做“教务系统”毕业设计,我会这样答...
java·后端