реклама на сайте
подробности

 
 
 
Reply to this topicStart new topic
> процесс init-respawning too fast: disabled for 5
romez777
сообщение Oct 14 2005, 04:14
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 292
Регистрация: 9-11-04
Пользователь №: 1 077



Приветствую.

Экспериментурую со своим самописным сетевым демоном. Организовал запуск демона средствами процесса init, в /etc/inittab добавил запись:

d:345:respawn:/path/to/my/daemon -d

Периодически в логи сыпятся сообщения:
Id "d" respawning too fast: disabled for 5 minutes

Как я догадываюсь, что-то не так с моим приложением smile.gif Хотя при этом он успешно работает.

Вот как я создаю демона:

Код
/* closeall() - close all FDs >= specified value */
void closeall(int fd)
{
 int fdlimit = sysconf(_SC_OPEN_MAX);
 while ( fd < fdlimit )
  close(fd++);
}

/* daemon() - detach process from user and disappear into the background */
int daemon(int nochdir, int noclose)
{
 switch ( fork() )
 {
     case 0:
       break;
     case -1:
       return -1;
     default:
       exit(0);  /* exit the original process */
 }

 /* create new session not having controlling terminal */
 if (setsid() < 0)    /* shoudn't fail */
    return -1;

 /* now we aren't session group leader, so never gain controlling terminal */
 switch ( fork() )
 {
    case 0:
      break;
    case -1:
      return -1;
    default:
      exit(0);
 }

 /* here run the child */
 if ( !nochdir )
  chdir("/");

 if ( !noclose ) {
  closeall(0);
  open("/dev/null", O_RDWR);
  dup(0); dup(0);
 }

 return 0;
}

...

int main(void)
{
  .....
     if ( daemon(0, 0) < 0 ) {
           perror("daemon");
           exit(2);
     }

     process();     /* run main process */

     return 0;
}


На что стоит еще обратить внимание?
Спасибо.
Go to the top of the page
 
+Quote Post
Olej
сообщение Oct 14 2005, 07:40
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 351
Регистрация: 11-09-05
Из: Харьков
Пользователь №: 8 458



Цитата(romez777 @ Oct 14 2005, 07:14)
Экспериментурую со своим самописным сетевым демоном. Организовал запуск демона средствами процесса init, в /etc/inittab добавил запись:

d:345:respawn:/path/to/my/daemon -d

Периодически в логи сыпятся сообщения:
Id "d" respawning too fast: disabled for 5 minutes
*


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

Цитата(romez777 @ Oct 14 2005, 07:14)
Как я догадываюсь, что-то не так с моим приложением smile.gif Хотя при этом он успешно работает.
*


Как я могу предположить - собака зарыта вот в этом:
Код
     process();     /* run main process */
}


Как мне помнится из ваших предыдущих сообщений, если не ошибаюсь - это что-то из части серверов с fork()? fork() - очень длинная операция, в ОС без COW и в зависимости от бъёма кода процесса - она может требовать до секунд или даже до десятков секунд... Если у вас запросы клиента хоть на одном интервале посыплятся чаще - то вы и получите подобный эффект. А на более редких запросах - оно и будет "работать" wink.gif.

P.S. (дописано позже) посмотрите здесь:
http://qnxclub.net/modules.php?name=Forums...viewtopic&t=126
- там есть обсуждения ровно по этому вопросу.
Go to the top of the page
 
+Quote Post
romez777
сообщение Oct 14 2005, 11:12
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 292
Регистрация: 9-11-04
Пользователь №: 1 077



Цитата(Olej @ Oct 14 2005, 10:40)
Как мне помнится из ваших предыдущих сообщений, если не ошибаюсь - это что-то из части серверов с fork()? fork() - очень длинная операция, в ОС без COW и в зависимости от бъёма кода процесса - она может требовать до секунд или даже до десятков секунд... Если у вас запросы клиента хоть на одном интервале посыплятся чаще - то вы и получите подобный эффект. А на более редких запросах - оно и будет "работать" wink.gif.

Приветствую.
Спасибо за разъяснения, становится понятнее. Но непонятно другое - как объяснить появление этих сообщений в тех случаях, когда демон не получает никаких соединений, т.е. он молча слушает сокет?
Go to the top of the page
 
+Quote Post

Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 20th July 2025 - 19:32
Рейтинг@Mail.ru


Страница сгенерированна за 0.01281 секунд с 7
ELECTRONIX ©2004-2016