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

Всем привет! Можно общий вопрос, не про Erlang? Он больше к

архитектурным особенностям относится.

Имеется ресурс в сервисе А для получения данных телеметрии. Сам сервис А ходит в другой сервис Б для получения данных.
Пакет данных по телеметрии нужно обогащать данными пользователя. Для того, чтобы это сделать нужно сопоставить timestamp в пакете с журналом привязки устройств. Записи в журнале привязки имеют дату и время начала и окончания привязки.
Сама суть в принципе сводится к тому, чтобы найти вхождение timestamp в множество периодов.
Вопроc: как это можно делать эффективно?

7 ответов

7 просмотров

достаточно эффективный вариант — привести таймстемпы к одному виду, чтобы они строго возрастали со временем. Целое число ( erlang:system_time(milli_seconds). ) достаточно легко сравнить с двумя другими. Бинарь вида <<“20220217-184102”>> тоже можно сравнивать. Это чуть медленнее, чем с целочисленным таймстемпом, но зато читаемо для глаз. А вообще лучше как-то иначе пересекать источники данных. Нагенерить какой-нибудь id, например.

Здесь о другом, кажется. В журнале есть N запиcей диапазонов, нужно вычислить в какие диапазоны попадает таймстемп, не перебирая N.

Alexey-Golubev Автор вопроса
Denis
Здесь о другом, кажется. В журнале есть N запиcей ...

Ага, по факту вот это и нужно. Только записей может быть очень много. Одно устройство в месяц производит минимум 40000 пакетов, минимально таких устройств 1000. Сами устройства в течении дня могут менять привязку и быть у нескольких сотрудников. И кажется, что налету обогащать данные не очень хорошая идея

Alexey-Golubev Автор вопроса
Danil Zagoskin
достаточно эффективный вариант — привести таймстем...

ID это общий ключ по которому однозначно данные можно сопоставить?

Alexey Golubev
Ага, по факту вот это и нужно. Только записей може...

очень странная задача. У тебя в каждый момент открыто 1000 подключений. Как ты собираешься угадывать, где чьё подключение?

Alexey-Golubev Автор вопроса
Danil Zagoskin
очень странная задача. У тебя в каждый момент откр...

Это не касается Erlang, это общая задача. В сервис Б прилетают сообщения телеметрии от разных устройств и разных типов устройств. Сервис А ходит в него, чтобы получить необходимые данные за определенный промежуток

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

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

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Подскажите, можно ведь комбинировать запись данных в один и тот же Stream через TFileStream и через TCompressionStream поочерёдно? Ну т.е. часть данных мне нужно сжать, часть ...
notme
4
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Кстати на работу никто не хочет, слегка на Сшке подписывать? От 170к в месяц, под Москвой
Andrey Ermakov
6
А подскажите вопрос. Запускаю приложение под дебагом, всё красиво дебажится. Копирую его в другую папку, запускаю, в делфи делаю атач ту процесс, бряки при этом перестают рабо...
Serjone
2
Карта сайта