ElasticSearch6.x 基于SpringBoot 实现ElasticSearch连接功能封装

第一步:基于SpringBoot2.1.2,依赖ElasticSearch jar 包

<!--elasticsearch 依赖  -->
  <dependencies>
  		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-data-elasticsearch</artifactId>
		</dependency>
  </dependencies>

第二步:封装ElasticSearch 连接参数实体对象(ElasticSearchConfigEntity.java)

功能描述:声明ElasticSearchConfigEntity.java 为组件,实现读取application.properties 配置文件中涉及elasticsearch 服务器连接参数。

package com.zzg.ela.entity;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;

/**
 * ElasticSearch 实例化对象
 * @author zzg
 *
 */
@Component
public class ElasticSearchConfigEntity {
	// 集群名称
	@Value("${com.zzg.ela.cluster_name}")
	private String cluster_name;

	
	// 是否开启本地存储
	@Value("${com.zzg.ela.enable}")
	private String enable;
	
	// ip地址
	@Value("${com.zzg.ela.ip}")
	private String ip;
	
	// port 地址
	@Value("${com.zzg.ela.port}")
	private String port;
	
	// set 和 get
	public String getCluster_name() {
		return cluster_name;
	}

	public void setCluster_name(String cluster_name) {
		this.cluster_name = cluster_name;
	}

	public String getEnable() {
		return enable;
	}

	public void setEnable(String enable) {
		this.enable = enable;
	}

	public String getIp() {
		return ip;
	}

	public void setIp(String ip) {
		this.ip = ip;
	}

	public String getPort() {
		return port;
	}

	public void setPort(String port) {
		this.port = port;
	}
}

第三步:application.properties 配置涉及elasticsearch 服务器相关配置参数,截图如下:

第四步:编写ElasticSearch 配置参数对象(ElasticSearchConfig.java)

功能说明:注入ElasticSearchConfigEntity对象,实例化TransportClient对象。

package com.zzg.ela.config;

import java.net.InetAddress;
import java.net.UnknownHostException;

import javax.annotation.PostConstruct;

import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.transport.TransportAddress;
import org.elasticsearch.transport.client.PreBuiltTransportClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import com.zzg.ela.entity.ElasticSearchConfigEntity;

/**
 * ElasticSearch 配置
 * 
 * @author zzg
 *
 */
@Configuration
public class ElasticSearchConfig {
	@Autowired
	private ElasticSearchConfigEntity entity;

	@PostConstruct
	void init() {
		System.setProperty("es.set.netty.runtime.available.processors", "false");
	}

	/**
	 * ela 连接实列化对象
	 * 
	 * @return
	 */
	@Bean
	public TransportClient getTransportClient() {
		// 9300是es的tcp服务端口
		TransportAddress node = null;

		try {
			node = new TransportAddress(InetAddress.getByName(entity.getIp()), Integer.valueOf(entity.getPort()));
		} catch (NumberFormatException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (UnknownHostException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}

		// 设置es节点的配置信息
		Settings settings = Settings.builder().put("cluster.name", entity.getCluster_name()).build();

		// 实例化es的客户端对象
		TransportClient client = new PreBuiltTransportClient(settings);
		client.addTransportAddress(node);

		return client;
	}
}

第五步:编写ElasticSearchUtil工具类对象

功能说明:注入TransportClient, 封装elasticsearch 搜索引擎的通用操作。

@Component
public class ElasticSearchIndexUtil {
	// 引入 Ela 连接实列化对象
	@Autowired
	private TransportClient client;

    /**其他功能待补充**/

}

 

在Spring Boot中引入Elasticsearch主要包括两个方面的内容。首先是使用ElasticsearchTemplate进行操作的方式,其主要包括创建Elasticsearch工程和引入相关依赖。其次是使用ElasticsearchRepository进行操作的方式,它是基于ElasticsearchTemplate封装的一个接口,用于更方便地操作Elasticsearch。 在创建Spring Boot项目时,需要引入Elasticsearch的相关依赖。可以在项目的pom.xml文件中添加如下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-elasticsearch</artifactId> </dependency> ``` 这样就可以通过Spring Boot来使用Elasticsearch了。 通过以上的步骤,你就成功地在Spring Boot项目中引入了Elasticsearch,可以开始使用ElasticsearchTemplate或ElasticsearchRepository来进行相关操作了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Spring Boot整合Elasticsearch详细教程!官方工具类该如何使用?一篇文章搞定!](https://blog.csdn.net/hzj_java/article/details/118096157)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [springboot引入Elasticsearch](https://blog.csdn.net/huang2802033667/article/details/129420627)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值