栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 前沿技术 > 大数据 > 大数据系统

【烦人的ElasticSearch】Es7 如何判断索引是否存在(Java版本)

【烦人的ElasticSearch】Es7 如何判断索引是否存在(Java版本)

Es 搭建请自行寻找搭建方法

import org.elasticsearch.client.indices.GetIndexRequest;
import org.elasticsearch.client.RequestOptions;

public class EsServiceImpl implements EsService {

    @Resource
    private RestHighLevelClient restHighLevelClient;
    
	public boolean checkEsIndex(String esIndex) throws Exception {
        GetIndexRequest request = new GetIndexRequest(esIndex);
        return restHighLevelClient.indices().exists(request, RequestOptions.DEFAULT);
    }
}

附 RestHighLevelClient 配置

// 配置文件中新增配置
es:
  nodes: [ { "host": "127.0.0.1","port": 9200 } ]

// 新增 EsClientConfig 类
import com.bobft.fairy.vo.EsNodeVo;
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;

import java.util.List;


@Data
@Configuration
@ConfigurationProperties(prefix = "es")
public class EsClientConfig {

    private String clusterName;
    private List nodes;
}


// 新增EsClient类
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.collections4.CollectionUtils;
import org.apache.http.HttpHost;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestClientBuilder;
import org.elasticsearch.client.RestHighLevelClient;
import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;

import javax.annotation.Resource;
import java.io.IOException;
import java.net.UnknownHostException;


@Slf4j
@Component
public class EsClient {

    @Resource
    private EsClientConfig esClientConfig;

    
    @Bean
    public RestHighLevelClient restHighLevelClient() throws IOException {

        if (CollectionUtils.isEmpty(esClientConfig.getNodes())) {
            throw new UnknownHostException();
        }
        HttpHost[] httpHosts = esClientConfig.getNodes().stream().map(esNodeVo ->
                new HttpHost(esNodeVo.getHost(), esNodeVo.getPort(), "http")).toArray(HttpHost[]::new);
        RestClientBuilder builder = RestClient.builder(httpHosts);
        builder.setRequestConfigCallback(requestConfigBuilder -> requestConfigBuilder.setSocketTimeout(10000));
        return new RestHighLevelClient(builder);
    }
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/676881.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号