国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

使用StreamLold寫入 Starrocks報錯:Caused by org

這篇具有很好參考價值的文章主要介紹了使用StreamLold寫入 Starrocks報錯:Caused by org。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

問題描述

使用StreamLoad寫入Starrocks報錯,報這個錯誤:Caused by: org.apache.http.ProtocolException: Content-Length header already present

代碼案例

引入依賴

        <!--  Starrocks使用StreamLoad發(fā)送Http請求   -->
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpclient</artifactId>
            <version>4.5.3</version>
        </dependency>

具體demo

package com.song.starrocks;

import org.apache.commons.codec.binary.Base64;
import org.apache.http.HttpHeaders;
import org.apache.http.client.config.RequestConfig;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpPut;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.DefaultRedirectStrategy;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;

import java.io.IOException;
import java.nio.charset.StandardCharsets;
import java.util.UUID;

public class StarRocksStreamLoad {
    private final static String STARROCKS_HOST = "localhost";
    private final static String STARROCKS_DB = "starrocks_demo";
    private final static String STARROCKS_TABLE = "bitmap02";
    private final static String STARROCKS_USER = "root";
    private final static String STARROCKS_PASSWORD = "";
    private final static int STARROCKS_HTTP_PORT = 8038;

    public void sendData(String content) throws Exception {
        //String yyyyy = "id,name,age,age=to_bitmap(age)";
        String yyyyy = "id,process_time,bkey,bvalue,bvalue=to_bitmap(bvalue),create_time";
        final String loadUrl = String.format("http://%s:%s/api/%s/%s/_stream_load",
                STARROCKS_HOST,
                STARROCKS_HTTP_PORT,
                STARROCKS_DB,
                STARROCKS_TABLE);

        final HttpClientBuilder httpClientBuilder = null;

        int TIMEOUT = 3000;
        try (CloseableHttpClient client = httpClientBuilder.build()) {
            HttpPut put = new HttpPut(loadUrl);
            RequestConfig build = RequestConfig.custom()
                    .setAuthenticationEnabled(true)
                    .setCircularRedirectsAllowed(true)
                    .setRedirectsEnabled(true)
                    .setRelativeRedirectsAllowed(true)
                    .setExpectContinueEnabled(true)
                    .setConnectTimeout(30000).setConnectionRequestTimeout(TIMEOUT)
                    .setSocketTimeout(TIMEOUT).build();
            put.setConfig(build);
            StringEntity entity = new StringEntity(content, "UTF-8");
            put.setHeader(HttpHeaders.EXPECT, "100-continue");
            put.setHeader(HttpHeaders.AUTHORIZATION, basicAuthHeader(STARROCKS_USER, STARROCKS_PASSWORD));
            put.setHeader("columns", yyyyy);
            put.setHeader("column_separator", "\t");
            put.setHeader("max_filter_ratio", "0.2");
            put.setHeader("label", UUID.randomUUID().toString());
            put.setEntity(entity);

            try (CloseableHttpResponse response = client.execute(put)) {
                String loadResult = "";
                if (response.getEntity() != null) {
                    loadResult = EntityUtils.toString(response.getEntity());
                }
                final int statusCode = response.getStatusLine().getStatusCode();
                // statusCode 200 just indicates that starrocks be service is ok, not stream load
                // you should see the output content to find whether stream load is success
                if (statusCode != 200) {
                    throw new IOException(
                            String.format("Stream load failed, statusCode=%s load result=%s", statusCode, loadResult));
                }
                System.out.println("data {}" + loadResult);
            }
        }
    }

    private String basicAuthHeader(String username, String password) {
        final String tobeEncode = username + ":" + password;
        byte[] encoded = Base64.encodeBase64(tobeEncode.getBytes(StandardCharsets.UTF_8));
        return "Basic " + new String(encoded);
    }

}

測試類

注意:因為ExtRoaringBitmap是自己封裝的,所以需要換成bitmap或者RortingBitmap

    @Test
    public void testBitMapWriteStarrocks() throws Exception {
        ExtRoaringBitmap extRoaringBitmap = new ExtRoaringBitmap();
        extRoaringBitmap.set(111111);

        LongIterator longIterator = extRoaringBitmap.longIterator();
        StringBuilder stringBuilder = new StringBuilder();

        while (longIterator.hasNext()) {

            // 生成id
            Long id = 100;

            // 獲取ExtRoaringBitmap中的具體數據,也就是獲取long類型的offset
            long bitmapValue = longIterator.next();

            Date date = new Date();
            String currentDate = sdf.format(date);
            String bitmapKey = "張三" + id;

            String oneRow = id + "\t" + currentDate + "\t" + bitmapKey + "\t" + bitmapValue + "\t" + currentDate + "\n";
            stringBuilder.append(oneRow);
        }
        stringBuilder.deleteCharAt(stringBuilder.length() - 1);
        String loadData = stringBuilder.toString();
        System.out.println("loadData :{} " + loadData);

        StarRocksStreamLoad starrocksStreamLoad = new StarRocksStreamLoad();
        starrocksStreamLoad.sendData(loadData);

    }

報錯截圖

使用StreamLold寫入 Starrocks報錯:Caused by org,starrocks文章來源地址http://www.zghlxwxcb.cn/news/detail-679773.html

分析錯誤原因

     因為代碼執(zhí)行是在一個父項目中調用的子項目,把寫入Starrocks這塊封裝為一個工具類,通過其他的項目來調用, 如果個給Starrocks單獨一個項目的話,是可以正常執(zhí)行的 , 一旦放入到整個項目中,通過其他的項目來進行調用,就會報錯,經過排查 ,錯誤的原因是因為父項目中也有用到依賴httpclient這個依賴,但是版本不是4.5.3的,是其他的版本 ,雖然我子項目中有這個httpclient4.5.3的依賴,但是在項目啟動的時候,父項目的依賴把子項目的依賴覆蓋了,導致無法使用httpclient4.5.3的依賴,所以項目一直報Caused by: org.apache.http.ProtocolException: Content-Length header already present。

解決辦法

1.在idea中安裝maven的插件:Maven Helper ,通過這個可以查到里面所有的依賴;
2.在父項目中也添加這個httpclient4.5.3的依賴就可以正常寫入數據了;

到了這里,關于使用StreamLold寫入 Starrocks報錯:Caused by org的文章就介紹完了。如果您還想了解更多內容,請在右上角搜索TOY模板網以前的文章或繼續(xù)瀏覽下面的相關文章,希望大家以后多多支持TOY模板網!

本文來自互聯(lián)網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。如若轉載,請注明出處: 如若內容造成侵權/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經查實,立即刪除!

領支付寶紅包贊助服務器費用

相關文章

  • [starrocks BE] 啟動報錯問題記錄

    [starrocks BE] 啟動報錯問題記錄

    starrocks部署在沒有AVX2指令集的機器上導致部署失敗,解決方式更換支持AVX2指令集的機器。 ? 官方說明: ? starrocks所有進程都是在同一個不支持avx2指令集的宿主機上部署啟動的,表象是看似FE啟動了,但BE異常,但按照官方說法FE和BE服務應該都啟動不起來。 通過啟動命令:

    2024年02月08日
    瀏覽(122)
  • StarRocks案例4: Spark load第二次運行報錯

    需求背景: CDH集群 Spark版本 2.4.0 StarRocks版本 2.5.5 使用Spark 2.4.0客戶端會報錯,java.lang.NoClassDefFoundError: org/slf4j/Logger 看StarRocks lib下面使用的是Spark 2.4.6版本的jar包 于是使用Spark 2.4.6版本的客戶端。 遇到的問題: 第二次使用resource 的時候, label很快就顯示報錯這個 ErrorMsg: type:E

    2024年02月09日
    瀏覽(13)
  • Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException

    Caused by: org.springframework.beans.factory.NoSuchBeanDefinitionException

    修改為: ? ?解決辦法: BookDao層中添加@Mapper, 告訴springboot這是一個mybatis代理接口類型, 快來掃描我!, 由此生成代理對象 原因三:?? 測試類ModuleSetApplicationTests和引導程序ModuleSetApplication沒有在同名包下, 例如下圖, ModuleSetApplication類在com.itheima下ModuleSetApplicationTests沒有直接在com

    2024年02月11日
    瀏覽(26)
  • Caused by: org.gradle.workers.internal.DefaultWorkerExecutor$WorkExecutionEx

    Caused by: org.gradle.workers.internal.DefaultWorkerExecutor$WorkExecutionEx

    集成ARouter報錯 在gradle.properties添加 android.useAndroidX=true android.enableJetifier=true

    2024年02月11日
    瀏覽(25)
  • 解決caused by: org.gradle.api.internal.artifacts.ivyservice錯誤

    解決caused by: org.gradle.api.internal.artifacts.ivyservice錯誤

    報的錯誤如下: 可以點開下面這些小報錯的總報錯看一下 ?看到報錯后面集成的sdk 說明這個sdk沖突了,可能是as版本或者gradle版本不匹配等,可以根據現在as的版本選擇合適的版本,再sync now,如果這個sdk不需要了,也可以直接刪掉或注釋掉。 注:出現這個錯誤時,當as版本

    2024年02月13日
    瀏覽(24)
  • 已解決Caused by: org.gradle.api.internal.artifacts.ivyservice.DefaultLenientConfiguration

    已解決Caused by: org.gradle.api.internal.artifacts.ivyservice.DefaultLenientConfiguration Caused by: org.gradle.api.internal.artifacts.ivyservice.DefaultLenientConfiguration 這個錯誤通常是由于 Gradle 配置中存在依賴沖突或者缺失的依賴引起的。 下滑查看解決方法 以下是一些可能的解決方法: 清除并重新構建項

    2024年02月08日
    瀏覽(49)
  • <已解決>Caused by: java.lang.ClassNotFoundException: org.springframework.boot.context.properties

    <已解決>Caused by: java.lang.ClassNotFoundException: org.springframework.boot.context.properties

    在學習spring cloud 的項目知識中,遇到了許多小bug,在學習過程中以一套流程 創(chuàng)建新模塊module-往pom.xml里面導入依賴-修改yml文件-主啟動類springbootApplication-業(yè)務邏輯Controller-測試,這一套流程中往往卡在依賴導入這一部分,我遇到的問題就是springboot和springcloud版本不兼容的問題

    2024年02月04日
    瀏覽(144)
  • Caused by: java.lang.UnsupportedClassVersionError: org/mybatis/spring/boot/autoconfigure/MybatisDepe

    最近搭建了Maven+Springboot項目,啟動報錯

    2024年02月12日
    瀏覽(122)
  • Caused by: org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean wit

    是因為沒有掃描到 mapper,在啟動類或者配置類中@MapperScan配置包掃描,或者使用@Mapper注解Mapper接口

    2024年02月16日
    瀏覽(32)
  • StarRocks 中的數據模型和索引使用

    StarRocks 中的數據模型和索引使用

    StarRocks 支持四種數據模型,分別是明細模型 ( Duplicate Key Model )、聚合模型 ( Aggregate Key Model )、更新模型 ( Unique Key Model ) 和主鍵模型 ( Primary Key Model )。 1.1 明細模型 明細模型是默認的建表模型。如果在建表時未指定任何模型,默認創(chuàng)建的是明細類型的表。排序列使用稀疏索引

    2024年02月07日
    瀏覽(29)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領取紅包,優(yōu)惠每天領

二維碼1

領取紅包

二維碼2

領紅包