java 读取 带密码的 elasticsearch scroll翻页

java 读取 带密码的 elasticsearch scroll翻页

带密码的elasticsearch需要在访问时输入密码,故这里我们选择使用Curl工具的形式访问
首先我们定义一下工具类
相关的依赖可以在我之前的博客里查看
java 解析hiveserver2日志 解析HiveSQL 获取表的使用次数 热度
curl的工具类如下:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;

public class TestCurl {

	//输入curl命令,如果空格则以空格为分割以数据形式进行传递
    public static String execCurl(String[] cmds) {
        ProcessBuilder process = new ProcessBuilder(cmds);
        Process p;
        try {
            p = process.start();
            BufferedReader reader = new BufferedReader(new InputStreamReader(p.getInputStream()));
            StringBuilder builder = new StringBuilder();
            String line = null;
            while ((line = reader.readLine()) != null) {
                builder.append(line);
                builder.append(System.getProperty("line.separator"));
            }
            return builder.toString();
        } catch (IOException e) {
            System.out.print("error");
            e.printStackTrace();
        }
        return null;
    }
}

然后定义一下scroll的网址

String scrollUrl="http://" + ip + ":"+port+"/" + index + "/_search?scroll=1m&size=5000&pretty";

scroll=1m是指程序设置的内存
size=5000是5000行的意思,这个可以适度调大
然后我们使用curl工具执行以下

String[] cmds={"curl","-u", "xxx:xxx",  "-XGET", scrollUrl};
String pageResult =TestCurl.execCurl(cmds);

第一个xxx是账号
第二个xxx是密码

scroll主要是需要一次请求后记录下_scroll_id的值,好在下次请求时带上
首先第一次解析

JSONObject resultJson = JSONObject.parseObject(pageResult);
if (resultJson.isEmpty()) {
            return;
        }
String scrollId = resultJson.getString("_scroll_id");

然后第二次请求时

String url = "http://" + ip + ":" + port + "/_search/scroll?scroll=1m&scroll_id=" + scrollId + "&pretty";

然后再次使用curl命令请求即可

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MIDSUMMER_yy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值