Модераторы: xvr
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как убить поток, послав ему сигнал? по таймеру 
V
    Опции темы
Dimonius
  Дата 2.3.2007, 00:49 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 51
Регистрация: 11.10.2006

Репутация: нет
Всего: 1



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

Я хотел бы отключать клиента после некоторого времени бездействия. Например, если клиент ничего не делает (не присылает) в течение 10 минут, то сервер бы его отключал. Причем отключал корректно (закрыв соединение и убив поток, который обслуживает клиента). Есть мысля генерировать, какой-нибудь сигнал и отправлять его в поток, чтобы тот завершился. Но как это сделать???, не могу придумать.  smile 

Еще работу с таймера надо наладить. Так как я не могу пользоваться alarm() и settimer() так как они пользуются одним и тем же таймером. Я имею ввиду, если один поток изменит значение таймера, то и для других потоков оно тоже изменится... а нужно, чтобы каждый поток имел свой таймер, по истечению которого поток бы закрывался.

Ребята помогите, срочно нужно решение этой проблемы!
PM MAIL   Вверх
MAKCim
Дата 2.3.2007, 16:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Воін дZэна
****


Профиль
Группа: Экс. модератор
Сообщений: 5644
Регистрация: 10.12.2005
Где: Менск, РБ

Репутация: 84
Всего: 207



Цитата(Dimonius @  2.3.2007,  00:49 Найти цитируемый пост)
Ребята помогите, срочно нужно решение этой проблемы! 

1. Не использовать потоки (использовать процессы)
2. pthread_cancel() + pthread_setcancelstate()/pthread_setcanceltype()


--------------------
Ах, у елі, ах, у ёлкі, ах, у елі злыя волкі ©

PM MAIL   Вверх
Dimonius
Дата 7.3.2007, 00:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 51
Регистрация: 11.10.2006

Репутация: нет
Всего: 1



Цитата(MAKCim @  2.3.2007,  16:42 Найти цитируемый пост)
1. Не использовать потоки (использовать процессы)

В линукс потоки работают как процессы. Источник

А так, разобрался как работают сигналы. Вопрос решен.
PM MAIL   Вверх
MAKCim
Дата 7.3.2007, 09:56 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Воін дZэна
****


Профиль
Группа: Экс. модератор
Сообщений: 5644
Регистрация: 10.12.2005
Где: Менск, РБ

Репутация: 84
Всего: 207



Цитата(Dimonius @  7.3.2007,  00:54 Найти цитируемый пост)
В линукс потоки работают как процессы

есть posixthreads и linuxthreads


--------------------
Ах, у елі, ах, у ёлкі, ах, у елі злыя волкі ©

PM MAIL   Вверх
Ken
Дата 1.4.2007, 00:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 47
Регистрация: 31.3.2007

Репутация: нет
Всего: 4



Цитата(Dimonius @ 2.3.2007,  00:49)
У меня есть программа сервер, которая при  подключении клиента выделяет для каждого отдельный поток. И получается, что работа с каждым клиентом крутится в своем потоке. Надо прикрутить к этому обязательно сигналы. Есть идеи?

Я хотел бы отключать клиента после некоторого времени бездействия. Например, если клиент ничего не делает (не присылает) в течение 10 минут, то сервер бы его отключал. Причем отключал корректно (закрыв соединение и убив поток, который обслуживает клиента). Есть мысля генерировать, какой-нибудь сигнал и отправлять его в поток, чтобы тот завершился. Но как это сделать???, не могу придумать.  smile 

Еще работу с таймера надо наладить. Так как я не могу пользоваться alarm() и settimer() так как они пользуются одним и тем же таймером. Я имею ввиду, если один поток изменит значение таймера, то и для других потоков оно тоже изменится... а нужно, чтобы каждый поток имел свой таймер, по истечению которого поток бы закрывался.

Ребята помогите, срочно нужно решение этой проблемы!

Если клиентские потоки не используют какие-нибудь общие данные в памяти, то лучше использовать процессы. Если один из потоков завершит работу аварийно (например, Segmentation fault), то завершится процесс с всеми другими потоками. В случае отдельных процессов все процессы работают изолированно и не влияют друг-другу и проблема с таймером тоже решится.



PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С/С++: Программирование под Unix/Linux"
xvr
  • Проставьте несколько ключевых слов темы, чтобы её можно было легче найти.
  • Не забывайте пользоваться кнопкой "Код".
  • Вопросы мобильной разработки тут
  • Телепатов на форуме нет! Задавайте чёткий, конкретный и полный вопрос. Указывайте полностью ошибки компилятора и компоновщика.
  • Новое сообщение должно иметь прямое отношение к разделу форума. Флуд, флейм, оффтопик запрещены.
  • Категорически запрещается обсуждение вареза, "кряков", взлома программ и т.д.

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, xvr.

 
 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Программирование под Unix/Linux | Следующая тема »


 




[ Время генерации скрипта: 0.0727 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.