java 使用RestHighLevelClient获取ES的所有索引名

工作有个业务需求是需要获取ES中的所有索引名,之前是使用TransportClent去获取,但是ES加密了,而且TransportClient官方也不推荐使用,所以用了RestHighLevelClient去获取。

版本如下:

jdk版本:1.8

elasticsearch.client版本:6.4.0

 

附上代码:

这是获取高级客户端的方法

@Getter @Setter
private static RestHighLevelClient restClient  = null;

public static RestHighLevelClient getClient() {
	try {
		if(restClient != null){
			return restClient;
		}
		synchronized (ESConnection.class) {
			if(restClient != null){
				return restClient;
			}
				
			// 用户认证对象 
			final CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
			// 设置账号密码 
			credentialsProvider.setCredentials(AuthScope.ANY, new UsernamePasswordCredentials("账号", "密码"));
			// 创建rest client对象 
			RestClientBuilder builder = RestClient.builder(new HttpHost("ES的IP地址", ES的端口,不是节点端口))
						.setHttpClientConfigCallback(new HttpClientConfigCallback() {
						@Override
						public HttpAsyncClientBuilder customizeHttpClient(HttpAsyncClientBuilder httpClientBuilder) {
								return httpClientBuilder.setDefaultCredentialsProvider(credentialsProvider);
						}
					});
			restClient = new RestHighLevelClient(builder);
			return restClient;
		}
			
	} catch (Exception e) {
		e.printStackTrace();
	}
	return null;
}

 

以下是查询方法

public static void main(String[] args) {
	RestHighLevelClient restClient = getClient();
	try {
		GetAliasesRequest request = new GetAliasesRequest();
		GetAliasesResponse getAliasesResponse =  restClient.indices().getAlias(request,RequestOptions.DEFAULT);
		Map<String, Set<AliasMetaData>> map = getAliasesResponse.getAliases();
		Set<String> indices = map.keySet();
		for (String key : indices) {
			System.out.println(key);
		}
	} catch (IOException e) {
			e.printStackTrace();
	} 
		
}

运行结果如图:

以上就是使用HighLevelClient获取所有索引名字的方法。

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 12
    评论
使用Elasticsearch的Java REST客户端restHighLevelClient获取一个索引的全部数据可以通过以下步骤实现: 1. 创建restHighLevelClient客户端实例: ``` RestHighLevelClient client = new RestHighLevelClient( RestClient.builder(new HttpHost("localhost", 9200, "http"))); ``` 2. 构建一个SearchRequest对象,设置索引名称和查询条件: ``` SearchRequest searchRequest = new SearchRequest("index_name"); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); searchSourceBuilder.query(QueryBuilders.matchAllQuery()); searchRequest.source(searchSourceBuilder); ``` 3. 执行查询并处理结果: ``` SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); SearchHits hits = searchResponse.getHits(); for (SearchHit hit : hits.getHits()) { Map<String, Object> sourceAsMap = hit.getSourceAsMap(); // 处理每个文档的数据 } ``` 完整代码示例: ``` RestHighLevelClient client = new RestHighLevelClient( RestClient.builder(new HttpHost("localhost", 9200, "http"))); SearchRequest searchRequest = new SearchRequest("index_name"); SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); searchSourceBuilder.query(QueryBuilders.matchAllQuery()); searchRequest.source(searchSourceBuilder); SearchResponse searchResponse = client.search(searchRequest, RequestOptions.DEFAULT); SearchHits hits = searchResponse.getHits(); for (SearchHit hit : hits.getHits()) { Map<String, Object> sourceAsMap = hit.getSourceAsMap(); // 处理每个文档的数据 } client.close(); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值