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

Подскажите как лучше посчитать скорость изменения счётчика. Условно есть монотоннорастущий

счётчик , мне необходимо получать скорость его изменения за промежуток времени ( в идеале в значений в секунду). По сути нужен некий аналог оконных lag/lead функций ( ну или increase promql) Я нашел в документации, что есть оконные функции, но они вроде помечены экспериментальными.

Навскидку приходит простейшая конструкция типа group by по временным интервалам (например в две секунды) и вычисления разности между агрегатами max и min. Но возможно есть более правильный способ?

9 ответов

13 просмотров

Если вы можете апгрейднутся до 21.3 и использовать оконки, то проще использовать оконки

Aleksey-Ryabkov Автор вопроса
Dmitry [Altinity] Titov
Если вы можете апгрейднутся до 21.3 и использовать...

Ещё раз пересмотрел доку. Там написано, что помимо этого lag все равно не поддерживается :(. Так что похоже оконки не вариант

Aleksey Ryabkov
Ещё раз пересмотрел доку. Там написано, что помимо...

там можно съэмулировать лаг через any, либо в 21.4 есть уже обычный лаг

Aleksey-Ryabkov Автор вопроса
Dmitry [Altinity] Titov
там можно съэмулировать лаг через any, либо в 21.4...

Понятно. А если нет возможности перейти на последнюю. То как через group by сделать оптимально? Я так понимаю any берет первое попавшееся. И это не всегда детерминировано..

Aleksey Ryabkov
Понятно. А если нет возможности перейти на последн...

Ну тогда нужно думать, с какой точностью вам нужно отдавать результаты, сколько строк в одной секунде

Aleksey-Ryabkov Автор вопроса
Dmitry [Altinity] Titov
Ну тогда нужно думать, с какой точностью вам нужно...

А простой max - min насколько плох? Точность не сильно важна. Строк в секунде до десятка. Счётчик либо монотонно растет. Либо сбрасывается. В ноль и дальше опять растет

Aleksey Ryabkov
А простой max - min насколько плох? Точность не с...

Если точность устраивает, то ок. Если строк на входе не очень много (до сотен тысяч) можно посмотреть на runningAccomulate

Aleksey Ryabkov
Ясно спсб

https://kb.altinity.com/altinity-kb-queries-and-syntax/cumulative-unique Тут не совсем оно, но почерпнуть что то можно Есть еще вариант с arrayJoin

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

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

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Всем привет, у меня есть сервер принимающий входящие HTTP подключения, как проверить, что подключение было через прокси или нет, есть какие то поля в заголовках по которым мо...
DS
8
Карта сайта