URL: https://www.opennet.me/cgi-bin/openforum/vsluhboard.cgi
Форум: vsluhforumID9
Нить номер: 7153
[ Назад ]

Исходное сообщение
"проблемма с многопотоковым приложением"

Отправлено stolik , 05-Фев-08 11:24 
Всем доброго времени суток. Подскажите пожалуйста, ситуация такая.
Есть многопотоковое приложение, сервер, обслуживающий клиентов. Сервер считывает данные из драйвера устройства ЦОС, и раздает их всем подключившимся клиентам. Каждый клиент обслуживается отдельной ниткой. Основной поток, main, обслуживает подключение клентов, ещё один поток служит для управлением драйвера устройства и ещё один, постоянно читает данный из устройства ЦОС. Все засинхронизированно семафорами, все хорошо работает, но есть одна интересная проблемка. При завершении приложения (например Ctrl+C ,  с соответствующей обработкой сигнала) ИНОГДА, приложение не снимается. Вернее даже как, все потоки завершаются (все они DETACHED) main доходит до оператора return EXIT_SUCCESS; и все... ничего кроме kill -9 PID не помогает. Все это работает на очень старой системе с ядром 2.4 и версией pthread 0.10 (отличия по версиям хорошо видны в valgrind) (вот такая хитрая сборка, есть такая чУдо система Olivia, на базе Линукса) В таблице процессов (ps ax (даже без m, видны все потоки)) видно, что основной поток в состоянии sleep, поток-менеджер(да да, здесь он ещё виден в таблице процессов) в состоянии зомби. Остальные потоки завершились и их уже нет.
Но, например , на АСП Линукс 9.2 (тоже не новая, но просто ядро такое же как в Olivia, правда вот версия pthread сродня с версией glibc приблязительно 2.3.5 или че то такое), так вот, на это системе такого замеченно не было. С ядром 2.6 (Fedora 7) и подавно усе в порядке. Понимаю, без кода судить сложно, но все же, может кто знает, может у кого что похожее было. Заранее спасибо за ответы.

Содержание

Сообщения в этом обсуждении
"проблемма с многопотоковым приложением"
Отправлено Michelnok , 05-Фев-08 14:40 
Деструкторы глобальных объектов и/или функции atexit?

"проблемма с многопотоковым приложением"
Отправлено Michelnok , 05-Фев-08 14:47 
>основной поток в состоянии sleep, поток-менеджер(да да, здесь он ещё виден в
>таблице процессов) в состоянии зомби.

А вообще причина где-то тут. Может такое быть что основной поток ждет SIGCHILD о завершении потока-менеджера? Кто породил поток-менеджер и почему он сдох раньше ребенка?

А вообще, используйте NPTL (если там проблемы нет, как пишете) и не заморачивайтесь.


"проблемма с многопотоковым приложением"
Отправлено stolik , 05-Фев-08 18:55 
>>основной поток в состоянии sleep, поток-менеджер(да да, здесь он ещё виден в
>>таблице процессов) в состоянии зомби.
>
>А вообще причина где-то тут. Может такое быть что основной поток ждет
>SIGCHILD о завершении потока-менеджера? Кто породил поток-менеджер и почему он сдох
>раньше ребенка?
>
>А вообще, используйте NPTL (если там проблемы нет, как пишете) и не
>заморачивайтесь.

Неее, NPTL незяяя, я бы сам рад, но менять в системе незяяя, военная панимашь...