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

Всем доброй ночи. Нужна помощь с pyo3. Примерно следующий порядок

действий: есть сервис на питоне, он вызывает растовую зависимость и передаёт callback. В расте следующий код:
let pool = unsafe { py.new_pool() };
let py = pool.python();
py.allow_threads(|| {
self.inner.scan_artifacts(
path.to_string(),
timeout,
|msg: ScanCallbackMsg| match msg {
ScanCallbackMsg::Match(name, rule) => Python::with_gil(|py| {
let rule = rule::PyRule::new(py, rule).unwrap();
let _ = match_callback.call1(py, (name, rule));
}),
ScanCallbackMsg::Error(name, err) => Python::with_gil(|py| {
let (code, message): (u32, String) = PyEngineScanError(err).into();
let _ = error_callback.call1(py, (name, code, message));
})

match_callback и error_callback - это питонячьи объекты
И вижу по графикам, что течет память, запускал под valgrind - ничего не показал... Может быть кто-нибудь подскажет? Видел пару issue на гитхабе, с похожими проблемами, но там народ переписал код и не было такой матрёшки, как у меня

3 ответов

24 просмотра

Я бы сначала начал исследовать с какой стороны течет память, на стороне python или расширения. - на стороне python можно периодически дергать len(gc.get_objects()) и писать в лог, если заметен постоянный рост объектов, то получается утечка на стороне python. Можно дополнительно логировать количество объектов по типу collections.Counter(map(type, gc.get_objects())) - на стороне расширения, можно воспользоваться бисекцией, комментируем одну половину, если все еще течет, коментируем половину от оставшейся половины и т.д. пока не локализуем участок

Ivan-Krivosheev Автор вопроса
Andr T
Я бы сначала начал исследовать с какой стороны теч...

В расте отключил почти все, течет где-то в связке питона и раста и видимо я не правильно понимаю, как pyo3 работает с памятью

Ivan Krivosheev
В расте отключил почти все, течет где-то в связке ...

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

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Всем привет! Кто пользуется DevExpress, подскажите пожалуйста, реализован ли в TcxGrid в новых версиях поиск по датам как в Экселе (ну т.е. не просто список чекбоксов со значе...
A Z
4
Карта сайта