五、elasticsearch与springboot的集成

版本对应关系java

elasticsearch:5.6.0node

springboot:1.5.6spring

es依赖配置

<properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <elasticsearch.version>5.6.0</elasticsearch.version>
 </properties>

 <dependency>
            <groupId>org.elasticsearch.client</groupId>
            <artifactId>transport</artifactId>
            <version>${elasticsearch.version}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.7</version><!-- 版本号要 <= 2.7 -->

 </dependency>

 

es配置

import org.elasticsearch.client.transport.TransportClient;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.transport.InetSocketTransportAddress;
import org.elasticsearch.transport.client.PreBuiltTransportClient;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.beans.factory.FactoryBean;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;

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

/**
 * @author WangXH
 * @version V1.0
 * @Package com.wangxh.elasticsearch.esstudy.config
 * @date 2017-09-18 2017-9-18 13:29
 * @Description: ElasticSearch  5.6  配置
 */
@Configuration
public class ElasticSearchConfig implements FactoryBean<TransportClient>, InitializingBean, DisposableBean {

    private Logger logger= LoggerFactory.getLogger(this.getClass());

    //因为项目从2.2.4配置的升级到 5.4.1版本 原配置文件不想动仍是指定原来配置参数
    @Value("${spring.data.elasticsearch.cluster-nodes}")
    private String clusterNodes ;

    @Value("${spring.data.elasticsearch.cluster-name}")
    private String clusterName;

    private TransportClient client;

    @Override
    public void destroy() throws Exception {
        try {
            logger.info("Closing elasticSearch client");
            if (client != null) {
                client.close();
            }
        } catch (final Exception e) {
            logger.error("Error closing ElasticSearch client: ", e);
        }
    }

    @Override
    public TransportClient getObject() throws Exception {
        return client;
    }

    @Override
    public Class<TransportClient> getObjectType() {
        return TransportClient.class;
    }

    @Override
    public boolean isSingleton() {
        return false;
    }

    @Override
    public void afterPropertiesSet() throws Exception {
        logger.info(clusterName+"   "+clusterNodes);
        this.initClient();
    }

    private void initClient()  {
        try {

            PreBuiltTransportClient  preBuiltTransportClient = new PreBuiltTransportClient(settings());
            if (!"".equals(clusterNodes)){
                for (String nodes:clusterNodes.split(",")) {
                    String inetsocket[] = nodes.split(":");
                    String address = inetsocket[0];
                    Integer  port = Integer.valueOf(inetsocket[1]);
                    preBuiltTransportClient.addTransportAddress(new
                            InetSocketTransportAddress(InetAddress.getByName(address),port ));
                }

                client = preBuiltTransportClient;
            }
        } catch (UnknownHostException e) {
            logger.error(e.getMessage());
        }
    }

    /**
     * 初始化默认的client
     */
    private Settings settings(){
        Settings settings = Settings.builder()
                .put("cluster.name",clusterName)
                .put("client.transport.sniff",true).build();
        client = new PreBuiltTransportClient(settings);
        return settings;
    }
}

在application.yml文件中配置es的链接信息:apache

spring:
  data:
    elasticsearch:
      cluster-name: es-test
      cluster-nodes: 192.168.1.126:9300

9300是es的默认socket端口号,若是配置了多个es的slave,这里的cluster-nodes 其实也只用配置master的ip:port就能够,由于在配置中有:client.transport.sniff,true。springboot

 

总结:在集成es到springboot的步骤有如下几点app

  1. 添加es的依赖以及es的日志依赖
  2. 建立一个es的配置文件读取es链接配置,并初始化TransportClient
相关文章
相关标签/搜索