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

Всем привет, есть доска объявлений на которую хотят добавить аналитику: 1

- Продолжительность сеанса, какие страницы/экраны посещают юзеры, всякие триггеры при кликах и тд. Нужно для веба и мобилки(flutter)
2 - Подсчет кол-во посещений объявления, сколько раз объявление появлялось в поиске, сколько раз кликали на показать контакты, сколько раз добавляли в избранное и тд. Эти данные будут выводиться на самом сайте, использоваться для сортировки в списках, отрисовки всяких графиков и сопоставления с другими объявлениями/конкурентами.
3 - Аналитика сотрудников доски объявлений, которые работают в админке(только браузер). Хотят на основе этих данных расчитывать kpi. Скорее всего нужно что-то как и для пункта 1.

Данные из пунктов 1 и 3 нужно будет выгружать в инструменты типа BigQuery.

К чему смог прийти:
1 - использовать google analytics и firebase analytics из них вроде можно выгружать в BigQuery
2- использовать отдельную бд для хранения этих данных и раз в n часов синхронизировать полученные числа в основную базу
3 - так же использовать google analytics

Вопросы:
1 и 3 - Если ли алтернативы получше? Возможно какой-то единный недорогой инструмент, возможно selfhosted.
2 - Стоит ли использовать какую-то специальную бд? Сейчас основная postgres. Кол-ко пользователей в день ожидается около 3-5 млн, кол-во одновременно активных объявлений скорее всего не будет больше 1млн. Стоит ли смотреть в сторону elasticsearch(В проекте уже используется для поиска), clickhouse(нет опыта работы)?

Я особо никогда не интерисовался этой темой и не совсем понимаю в какую сторону смотреть.

3 ответов

24 просмотра

связка FB + GA + DWH (типа того же BQ) вполне себе стандартна для таких сценариев

1 можно (и я считаю нужно) считать через ga. 2 и 3 пункт надо на стороне приложения считать. у нас такое считается асинхронно через очереди и хранится в обычной бд

[username]- Автор вопроса
Anton K.
1 можно (и я считаю нужно) считать через ga. 2 и 3...

А какую клиентскую библиотеку вы используете для п3?

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Ребят в СИ можно реализовать ООП?
Николай
33
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта