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

А как сделать, чтобы он все сообщение в одной поле

вставлял без парсера? JSONAsString?

13 ответов

12 просмотров

да JSONAsString CREATE TABLE Test.queue ( j String ) ENGINE = Kafka('localhost:9092', 'TestData', 'group1', 'JSONAsString')

Ekaterina- Автор вопроса
Denny [Altinity]
да JSONAsString CREATE TABLE Test.queue ( j S...

получилось, спасибо, я зациклилась на том, что поля - это структура сообщения kafka timestamp, level, message, хотя level меня несколько смущал 😁

Ekaterina
получилось, спасибо, я зациклилась на том, что пол...

но вообще kafka engine сам может разобрать сообщение JSONEachRow CREATE TABLE Test.queue ( UserUid String, Time UInt64, Country String ) ENGINE = Kafka('localhost:9092', 'TestData', 'group1', 'JSONEachRow') в mativew просто нужно будет преобразовать toUUIDOrZero(UserUid) , toDateTime(Time) ....

Ekaterina- Автор вопроса
Denny [Altinity]
но вообще kafka engine сам может разобрать сообщен...

Ну, да, я поняла. Заодно, поделитесь мнением, пожалуйста,благонадежно этим движком пользоваться? Или лучше отдельный сервис использовать для загрузки сообщение из кафки в клик?

Ekaterina
Ну, да, я поняла. Заодно, поделитесь мнением, пожа...

ИМХО конечно нельзя пользоваться kafka=engine. НО десятки тысяч пользователей КХ абсолютно счастливо используют kafka=engine

Ekaterina- Автор вопроса
Denny [Altinity]
ИМХО конечно нельзя пользоваться kafka=engine. Н...

Спасибо ) примерно это и ожидала услышать.

Denny [Altinity]
ИМХО конечно нельзя пользоваться kafka=engine. Н...

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

Никита Ильин
Добрый день, перечитываю чат в рамках обучения. По...

Есть классная тема, если из Кафки приходит столбец с названием channelid, то там данных в КХ не будет.

Никита Ильин
Добрый день, перечитываю чат в рамках обучения. По...

Гарантирует только at least once. Иногда будут дубли, и если данные критичны, придётся что-то с этим делать(писать уникальный id записи например + replacing использовать)

Никита Ильин
Добрый день, перечитываю чат в рамках обучения. По...

он не очень гибкий. Не очень удобно поддерживать обработку ошибок в сообщениях, если есть топики из разных брокеров и таких брокеров много это все сложно настраивать и нужен рестарт КХ, он не умеет exactly once. Но exactly once почти вообще никто не умеет из коробки для КХ. Тут дело такое. Я как Альтинити инженер на первом же митинге с новым клиентом, рассказываю: что kafka engine убог и вообще говно, вы такие умные используете spark и понятно что json ужасен из-за дичайшего оверхеда, давайте сделаем POC kafka engine+JSONEachRow, а потом вы перепилите все без kafka engine и перейдете на TSV вместо JSON. Делаем POC, все всем нравится, и в итоге в прод большинство прям так и идут, пофиг и на оверхед по CPU и трафику и на что есть дубли в 0.00001% случаев. Я конечно в жизни не стал бы использовать kafka engine в проде, это безумие, но я и в distributed таблицы не вставляю. Мне проще кода нафигачить или других заставить сделать как я хочу, а не как проще.

Serge Paschanin
Есть классная тема, если из Кафки приходит столбец...

ну это баг, это надо репортить, исправить это минут 5 займет и я бы проверил что у вас в слове channelid , все буквы латиницей,потому что в коде КХ и librd я не вижу channelid. Есть _channel_id в engine=rabbit

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

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

Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
База данных не поможет. Шифрование не поможет. Какие там ещё варианты? Накидывайте.
КТ315
20
А табстоп это сообщение от окна или от элемента управления?
The Bird of Hermes
18
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Открыл свой двухкилобайтный экзешник в x32dbg, а тут какая-то хрень. Смущает кнопка "выполнить до пользовательского кода", а что ещё может быть в файле помимо него ?
НѣкъиⰘижєжєиꙁъвьсєсвѣтьноѣсѣтиѥсть•
11
Мне были интересны дишные хаки и я нашёл любопытный способ на форуме через __traits, что-то вроде int delegate(int) fac = (int n) => n == 0 ? 1 : n * __traits(parent, {})(n - ...
Constantin F.
1
Всем привет, подскажите/посоветуйте пожалуйста. Фаердак компоненты, имею одно место где бизнес хочет видеть при открытии формы список всех клиентов, это порядка 30к. Мои дово...
Sasha Sch
14
Вопрос тем кто смотрит видео и слушает подкасты - как вы потом ищете нужную вам информацию? Вот статью я прочитал, потом могу искать нужную мне часть банальным поиском. Пропус...
Aleksandr Druzhinin
4
Ребят, если кто в курсе - скажите, а в загранке такое же засилье маркетплейсов? или там простые сермяжные интернет-магазины живут попроще?
Андрей [aharito] Харитонов
14
Хотел бы спросить у знающих, правильную ли я выбрал книгу для начала изучения ассемблера Юрова В.И ? Или есть более лучшие книги для начала обучения?
Botsman
31
Карта сайта