184 похожих чатов

Всем привет! У меня в кластер кликхауса вставка данных в

виде JSON происходит постоянно небольшими батчами, примерно каждые 5-10 секунд вставляется от 1 до 100 записей. В большинстве случаев 5-10. И меня в данном случае
Проблема в том, что происходит ошибка 49 (LOGICAL_ERROR) 1% до 2% записей он для какое-то поля не смог вывести тип и пишет что оно Array(Nothing).
Случайно обнаружил, что повторная вставка тех-же данных записывается без ошибок и реализовав переотправку ровно тех-же данных в коде при возникновении этой ошибки удалось снизить количество вставок с ошибкой примерно раза в 3.

Подскажите, как мне сделать так, чтобы такая ошибка перестала возникать совсем? Делать переотправку данных до тех пор пока кликхаус их не примет тоже как-то не хочется.

17 ответов

64 просмотра

Есть формат JSON с явным описанием формата полей: https://clickhouse.com/docs/en/interfaces/formats#jsoncolumnsmonoblock

В смысле у вас колонка с типом JSON? Он экспериментальный и его не рекомендуется использовать. А ещё его признали неудачей и выпиливают, заменяя на полностью другой. Т.е. однажды при апгрейде все превратиться в тыкву. https://github.com/ClickHouse/ClickHouse/issues/54864

David
А в гринпламе с json все ок?

я не знаю, я никогда не смотрел на гриплам

Denny [Altinity]
я не знаю, я никогда не смотрел на гриплам

работали когда-нибудь с продуктовыми ивентами?

David
работали когда-нибудь с продуктовыми ивентами?

К чему этот вопрос? Я как саппорт инженер работал с тысячами разных юзкейсов

Denny [Altinity]
К чему этот вопрос? Я как саппорт инженер работал ...

хотел поинтересоваться каким образом справлялись с event_params в big query, т.к. event_params удобнее всего переливать в clickhouse в json и парсить

Михаил-Тюкавкин Автор вопроса
Denny [Altinity]
В смысле у вас колонка с типом JSON? Он эксперимен...

Да, у нас колонка JSON и я знаю, что его хотят выпилить.

David
хотел поинтересоваться каким образом справлялись с...

Ну переделать в массивы в etl или использовать JSONExtract

David
Экстракт перед кликхаусом?

функция есть JSONExtract в clickhouse из строки достает то что нужно... https://presentations.clickhouse.com/meetup40/uber.pdf вот почитайте

David
Экстракт перед кликхаусом?

Да где хотите. Я описал два разных варианта. https://kb.altinity.com/altinity-kb-schema-design/altinity-kb-jsonasstring-and-mat.-view-as-json-parser/ https://kb.altinity.com/altinity-kb-schema-design/altinity-kb-jsoneachrow-tuples-and-mvs/ https://kb.altinity.com/altinity-kb-queries-and-syntax/jsonextract-to-parse-many-attributes-at-a-time/

Slach [altinity]
функция есть JSONExtract в clickhouse из строки до...

Я понял, имею ввиду для ее применения у вас должна быть в кликхаусе json колонка, но вы сказали, что такие колонки лучше не держать. Поэтому интересуюсь, на каком этапе вы планируете экстрактить

David
Я понял, имею ввиду для ее применения у вас должна...

https://kb.altinity.com/altinity-kb-schema-design/altinity-kb-jsonasstring-and-mat.-view-as-json-parser Тип JSON vs тип String

Михаил-Тюкавкин Автор вопроса
Denny [Altinity]
Ну переделать в массивы в etl или использовать JSO...

У нас достаточно сложные JSON и писать и поддерживать решение на базе JSONExtract под каждый поток данных будет трудозатратно. А преобразовать в массивы в ETL - это как?

Михаил Тюкавкин
Да, у нас колонка JSON и я знаю, что его хотят вып...

подскажите, а почему его решили выпиливать?

Похожие вопросы

Обсуждают сегодня

Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
2
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
у меня программа тысяч на 10 строк. Там в основном моя собственная логика. А по содержанию она просто работает с файловой системой (мастер для бэкапов) и таблицей с данными о ...
Дмитрий Завгородний
5
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Карта сайта