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

Есть http сервер, который в одном потоке принимает tcp соединения,

затем распаршенный запрос пихает в тредпул. Когда таких запросов много, от логов почти нет толка, потому что не понятно, к какому запросу относится запись. Хочу выдавать id каждому запросу в потоке, принимающим соединение и проводящем парсинг, и каждый лог предворять таким id. Вопрос в том, как это лучше сделать? Передавать в каждую функцию , которая вызывается в воркере тредпула дополнительным параметром строку с этим id можно, но выглядит очень топорно. Есть идеи, как изящнее решить такую проблему?

6 ответов

5 просмотров

наверно, можно логировать адреса объектов (будет менее читаемо, но зато без дополнительных полей типа id).

Animal- Автор вопроса
говорит непонятна
RequestId

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

Animal- Автор вопроса
fr
наверно, можно логировать адреса объектов (будет м...

ну да, это совсем не информативно . Объекты то тоже меняются в ходе обработки (например, из функции обработки обращается к сервису бд, который другой объект с другим адресом и ничего о http запросе не знает )

Animal
гуглится , что в кофиге nginx нужно указать , что ...

Тебе бы не только RequestId пробрасывать, тебе бы учет вести всего стека вызовов.

Animal- Автор вопроса
Гласси
Тебе бы не только RequestId пробрасывать, тебе бы ...

в некоторых случаях это может быть полезным, согласен

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

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

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
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
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
@ahndmn @ayaw0_0 здарова, на чем пишете?
Aiwan \ (•◡•) / _bot
7
Коллеги, как получить PId для собственного процесса из под линукса?
Роман Лях (rgreat)
6
Карта сайта