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

Ребят, всем привет!) Столкнулся проблемой — течет приложение на зио и

немножко http4s, в дампе такая картина: в zio файбер контексте валяется reportFailure, содержит миллиард похожих вложенных контекстов. За что в таком случае можно зацепиться, что бы размотать клубок?)

23 ответов

29 просмотров

Если удастся разобраться — отпиши в чате плиз, как решил.

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

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

и еще в дебагере кажется можно поставить брейкпоинт и размотав эту вложенность найти по косвенным данным что именно за FiberContextы и вероятно найти куски кода приложенияв которые это провоцируют, дальше копать вглубь в исходники

Nick-Gushchin Автор вопроса
Artem Sokolov
и еще в дебагере кажется можно поставить брейкпоин...

Спасибо, буду пробовать) Самое сложное, конечно, смэппить это на куски приложения

Nick Gushchin
Спасибо, буду пробовать) Самое сложное, конечно, с...

Лучше просто по исходникам зио посмотреть все места использования ссылки.

Artem Sokolov
Лучше просто по исходникам зио посмотреть все мест...

Так вообще ж не факт, что это в зиве. Больше всего объектов не оттуда

Nick-Gushchin Автор вопроса
Artem Sokolov
Наоборот все в зиве интернал

так не все кто-то держит вот эти объекты, а они уже держат зивовые

Никита Мязин
screenshot так не все кто-то держит вот эти объекты, а они уж...

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

Artem Sokolov
их (верхние ссылки) держит текущий активный процес...

Да, но кто-то же держит все эти контексты Сами по себе большие цепочки ссылок или циклические не являются проблемой для гц же

скинь плс точную версию зивы. если есть ссылка на исходники этой версии сразу - будет лучше найду место которое с багом

в итоге раскопали?

Nick-Gushchin Автор вопроса
Nick-Gushchin Автор вопроса
Artem Sokolov
в итоге раскопали?

\cc @lmnet89 @Nikita_Miazin Да, раскопал, но хип дампы мне никак не помогли — догадался по поведенческим маркерам. Проблема оказалась в куске кода на первом скрине. После 4х минут интенсивного дергания HTTP GET /probes/startup Утекала вся память (скрин 2). Я заменил blaze на ember и проблема ушла (последние два скрина)

Nick-Gushchin Автор вопроса
Nick Gushchin
screenshot

Интересно, спасибо

Nick Gushchin
screenshot

А вебсокеты на проекте есть? Просто эмбер по факту с ними не работает, хотя апишка есть :)

Nick-Gushchin Автор вопроса
Юрий Бадальянц
А вебсокеты на проекте есть? Просто эмбер по факту...

Спасибо, я не знал) На данный момент вебсокетов нету

Nick-Gushchin Автор вопроса

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

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

Добрый день. Хочу сделать отрисовку по команде на панели. Почему-то рисуется только при втором вызове. С чем может быть связано, не подскажете? procedure TForm1.FormDblClick(...
Kirill Filippenok
20
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
А почему в си некоторые вещи работают с двойными кавычками некоторые с одинарными? Нельзя было все сделать с одними или чтоб работало с разными? например чтоб выводить строки ...
.
15
Всем привет! Нужен совет от опытных. Переношу свой проект с Делфи 10.2 Токио на Лазарус 3.2 установленный через инсталлятор fpcupdeluxe-x86_64-win64. При импортировании проект...
Дмитрий Завгородний
7
Всем привет! procedure TForm1.FormCreate(Sender: TObject); type TStartEnd = record S: Byte; E: Byte; end; var a, b: TStartEnd; begin {1} a.S := 1; {2} a.E := 2; ...
Руслан Михайлович
10
Всем привет!) я тут новенький и пытаюсь освоить evolution методом тыка. У меня при переходе между папками файлов выскакивают вот такие уведомления Можете подсказать как их от...
Диман Samoed
10
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Карта сайта