实现Java的es客户端RestHighLevelClient

#客户端基本配置
elasticsearch-client.hosts=http://localhost:9200
elasticsearch-client.username=elastic
elasticsearch-client.password=123321
@ConfigurationProperties(prefix = "elasticsearch-client")
public class ElasticsearchClientBean {
	private List<String> hosts;

    private String username;

    private String password;

    public List<String> getHosts() {
        return hosts;
    }

    public void setHosts(List<String> hosts) {
        this.hosts = hosts;
    }

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    @Override
    public String toString() {
        return "ElasticsearchClientBean{" +
                "hosts=" + hosts +
                ", username='" + username + '\'' +
                ", password='" + password + '\'' +
                '}';
    }
}
@Configuration
public class ElasticsearchClientConfig {


    @Autowired
    private ElasticsearchClientBean properties;

    private RestHighLevelClient client;
    private RestClient restClient;

    @Bean
    public RestHighLevelClient getRestHighLevelClient() {
        HttpHost[] hosts = properties.getHosts().stream().map(h -> HttpHost.create(h)).toArray(HttpHost[]::new);
        //TODO 基础身份验证 设置账户密码时打开
        final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
        credentialsProvider.setCredentials(AuthScope.ANY,
                new UsernamePasswordCredentials(properties.getUsername(), properties.getPassword()));
        client = new RestHighLevelClient(
                RestClient.builder(hosts)
                        //TODO 身份验证 设置账户密码时打开
                        .setHttpClientConfigCallback(httpClientBuilder -> httpClientBuilder.disableAuthCaching()
                                .setDefaultCredentialsProvider(credentialsProvider)
                                .setDefaultIOReactorConfig(IOReactorConfig.custom().setIoThreadCount(8).build())
                        )
                        .setRequestConfigCallback(requestConfigBuilder ->
                                requestConfigBuilder.setConnectTimeout(300000)
                                        .setSocketTimeout(300000)
                                        .setConnectionRequestTimeout(300000)
                        )
        );
        System.out.println("Connecting Elasticsearch...");
        while (true) {
            try {
                if (client.ping(RequestOptions.DEFAULT)) {
                    break;
                }
            } catch (Exception e) {
                System.out.println("Connecting Elasticsearch Failed, Retry in 10 seconds...");
                try {
                    Thread.sleep(10000);
                } catch (InterruptedException e1) {
                    e.printStackTrace();
                }
            }
        }
        System.out.println("Elasticsearch Connected!");
        return client;
    }

    public void close() {
        if(client != null) {
            try {
                client.close();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    }
    public RestClient getLowLevelClient() {
        if (restClient == null && client != null){
            restClient = client.getLowLevelClient();
        }
        return restClient;
    }
    public boolean connectionEs() {
        try {
            List<String> esHttp = properties.getHosts();
            for (String http : esHttp) {
                String text = HttpClientUtil.get(properties.getUsername(),properties.getPassword(),http + "/_cluster/health");
                if(text == null || StringUtils.isEmpty(text)){
                    System.out.println("Start:connectionEs: "+http+":Error");
                    continue;
                }
                return true;
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return false;
    }
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值