<?xml version="1.0" encoding="UTF-8" ?>

<bugzilla version="5.2"
          urlbase="https://bugzilla.altlinux.org/"
          
          maintainer="jenya@basealt.ru"
>

    <bug>
          <bug_id>15044</bug_id>
          
          <creation_ts>2008-03-24 00:49:21 +0300</creation_ts>
          <short_desc>Добавить функцию принудительной остановки демона</short_desc>
          <delta_ts>2008-09-04 01:32:29 +0400</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>4</classification_id>
          <classification>Development</classification>
          <product>Sisyphus</product>
          <component>service</component>
          <version>unstable</version>
          <rep_platform>all</rep_platform>
          <op_sys>Linux</op_sys>
          <bug_status>CLOSED</bug_status>
          <resolution>FIXED</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P2</priority>
          <bug_severity>enhancement</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Andrew Kornilov">hiddenman</reporter>
          <assigned_to name="placeholder@altlinux.org">placeholder</assigned_to>
          <cc>glebfm</cc>
    
    <cc>ktirf</cc>
    
    <cc>ldv</cc>
    
    <cc>legion</cc>
    
    <cc>mike</cc>
    
    <cc>placeholder</cc>
    
    <cc>vt</cc>
    
    <cc>vvk</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>66474</commentid>
    <comment_count>0</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2008-03-24 00:49:21 +0300</bug_when>
    <thetext>Просьба сделать нечто вида --force[=SIGNUM] для функции stop_daemon, то есть,
принудительное завершение процесса сигналом SIGNUM (по умолчанию KILL, возможно,
кому-то понадобиться переопределить на STOP, например) после истечения некоего
timeout, в качестве fallback.
Довольно часто встречается, что некое ПО зависает наглухо или по неведомых
причинам нормально не завершает работу по kill -TERM. Например, mysql может так
себя вести. Коммерческого ПО тоже достаточно, которое иногда виснет. В httpd у
нас вообще штатно вбито killall -9q libhttpd.ep.
Приходится и самому строить такие конструкции, т.к. _гарантированно_ сейчас
завершить процесс с помощью stop_daemon не получается, чтение --help от
start-stop-daemon и /etc/init.d/functions ничего не подсказало.
При использовании мониторинга на серверах это более чем необходимо, т.к. тот же
monit в цикле пытается остановить зависший или нереагирующий процесс и у него
это не получается.
Починить всё ПО (особенно коммерческое), imho, сложнее, чем реализовать такой
функционал.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68929</commentid>
    <comment_count>1</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2008-04-25 05:37:16 +0400</bug_when>
    <thetext>У start-stop-daemon есть параметр --retry.
Каким вы хотите видеть соответствующий интерфейс у stop_daemon?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68963</commentid>
    <comment_count>2</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2008-04-25 17:47:24 +0400</bug_when>
    <thetext>Гм. Судя по ману, можно указать --retry KILL/forever и это будет аналогом force?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>74959</commentid>
    <comment_count>3</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2008-08-07 03:27:23 +0400</bug_when>
    <thetext>Если я правильно понял то, что написано в man start-stop-daemon, то -R  -это именно то, что нужно. Думаю, баг можно закрывать. </thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>75193</commentid>
    <comment_count>4</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2008-08-11 03:15:00 +0400</bug_when>
    <thetext>Нда, только дошло, что есть поддержка этой опции в самом start-stop-daemon, однако же в stop_daemon в functions этой поддержки нет. Просьба добавить. Может быть даже в таком же виде.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>76913</commentid>
    <comment_count>5</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2008-09-03 01:40:51 +0400</bug_when>
    <thetext>ping

Так что, поддержка retry в скриптах будет? Если да, то просьба обновить пакеты во всех бранчах. Вместе с пакетом startup, где исправлено удаление подкаталогов в /var/run/$name/</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>76979</commentid>
    <comment_count>6</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2008-09-04 01:32:29 +0400</bug_when>
    <thetext>0.5.15-alt1-1-ga562d6c(In reply to comment #5)
&gt; ping
&gt; 
&gt; Так что, поддержка retry в скриптах будет?

Тестируйте: 0.5.15-alt1-1-ga562d6c
</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>