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

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

    <bug>
          <bug_id>13824</bug_id>
          
          <creation_ts>2007-12-28 22:39:21 +0300</creation_ts>
          <short_desc>Bad error message with ${IPV4ADDRESS} use</short_desc>
          <delta_ts>2019-03-06 17:55:48 +0300</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>4</classification_id>
          <classification>Development</classification>
          <product>Sisyphus</product>
          <component>etcnet</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>normal</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Eugene Ostapets">eostapets</reporter>
          <assigned_to name="Andrew Kornilov">hiddenman</assigned_to>
          <cc>ldv</cc>
    
    <cc>mrdrew</cc>
    
    <cc>pv</cc>
    
    <cc>rider</cc>
    
    <cc>sem</cc>
    
    <cc>shaba</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>60146</commentid>
    <comment_count>0</comment_count>
    <who name="Eugene Ostapets">eostapets</who>
    <bug_when>2007-12-28 22:39:23 +0300</bug_when>
    <thetext>При старте сети, правило 
snat ${IPV4ADDRESS}  if out-iface ${NAME}
чудесно применяется, при остановке получается ругань:

Unloading rules for the &quot;POSTROUTING&quot; chain in the &quot;nat&quot; tableiptables v1.3.7:
Bad IP address `&apos;

Try `iptables -h&apos; or &apos;iptables --help&apos; for more information.
ERROR: /etc/net/scripts/config-fw: /sbin/iptables -t nat -D POSTROUTING -j SNAT
--to-source ${IPV4ADDRESS} -o ${NAME}

Хотя само правило удаляется...</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60149</commentid>
    <comment_count>1</comment_count>
    <who name="Denis Ovsienko">pilot</who>
    <bug_when>2007-12-28 23:53:31 +0300</bug_when>
    <thetext>Это по Андреевой части.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60151</commentid>
    <comment_count>2</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2007-12-29 00:14:55 +0300</bug_when>
    <thetext>Гм. А что за тип интерфейса?
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60171</commentid>
    <comment_count>3</comment_count>
    <who name="Eugene Ostapets">eostapets</who>
    <bug_when>2007-12-29 17:34:43 +0300</bug_when>
    <thetext>Как положено,
TYPE=eth
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60172</commentid>
    <comment_count>4</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2007-12-29 17:39:43 +0300</bug_when>
    <thetext>Очень странно, вроде все проверял. Последняя версия etcnet, надеюсь?
Посмотрю еще дома. Хотя все удаляло/добавляло. Может опять с regexp-ом для
адреса что-то не так. ip addr ls покажи, plz</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60173</commentid>
    <comment_count>5</comment_count>
    <who name="Eugene Ostapets">eostapets</who>
    <bug_when>2007-12-29 17:44:56 +0300</bug_when>
    <thetext>[root@host64 ~]# ip ad ls
2: lo: &lt;LOOPBACK,UP,LOWER_UP&gt; mtu 16436 qdisc noqueue 
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
4: nvidia: &lt;BROADCAST,MULTICAST,UP,LOWER_UP&gt; mtu 1500 qdisc pfifo_fast qlen 1000
    link/ether 00:e0:4d:0e:6f:b5 brd ff:ff:ff:ff:ff:ff
    inet 172.23.0.1/24 brd 172.23.0.255 scope global nvidia
6: volia: &lt;BROADCAST,MULTICAST,UP,LOWER_UP&gt; mtu 1500 qdisc pfifo_fast qlen 1000
    link/ether 00:e0:6f:ba:b7:c5 brd ff:ff:ff:ff:ff:ff
    inet 77.123.10.134/20 brd 77.123.15.255 scope global volia

[root@host64 ~]# rpm -q etcnet
etcnet-0.9.5-alt1
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60174</commentid>
    <comment_count>6</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2007-12-29 17:53:01 +0300</bug_when>
    <thetext>А hotplug случайно не используется? Похоже, что в момент остановки iptables
адреса на интерфейсе уже нет. Я предусматривал эту ситуацию, но тестировал всё
на нехотплаговском типе подключения. Может быть там и забыл что-то.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60175</commentid>
    <comment_count>7</comment_count>
    <who name="Eugene Ostapets">eostapets</who>
    <bug_when>2007-12-29 18:02:44 +0300</bug_when>
    <thetext>Интерфейс есть, я специально проверял... Интерфейс есть, а правила нет... Такое
впечатление, что удаление вызывается дважды, один раз до удаления адреса, второй
раз уже после...

cat /etc/net/ifaces/volia/options
TYPE=eth
BOOTPROTO=dhcp
ONBOOT=yes
USE_HOTPLUG=no
MODULE=cdc_ether
DHCP_ARGS=&quot; -R &quot;
NEVER_RMMOD=yes
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60183</commentid>
    <comment_count>8</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2007-12-30 00:09:02 +0300</bug_when>
    <thetext>Нда, пока ничего не понимаю. А можешь в fw/iptables/options вставить что-то вроде:
echo &quot;Here&quot;
Сколько раз выведет при остановке, столько раз и вызывает. Теоретически....Эх,
пора уже дебаг внедрять :)</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60187</commentid>
    <comment_count>9</comment_count>
    <who name="Eugene Ostapets">eostapets</who>
    <bug_when>2007-12-30 01:03:26 +0300</bug_when>
    <thetext>Я поступил круче, вставил echo -e &quot;\n `ip ad ls` \n&quot;

К моменту вывода сообщения об ошибке адреса на интерфейсе уже нет. </thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60188</commentid>
    <comment_count>10</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2007-12-30 01:07:55 +0300</bug_when>
    <thetext>Чудеса....В ifdown первыми идут остановки fw и qos, потом ip rules/routes, потом
уже идет destroy интерфейса, то есть rmmod и т.п. У тебя там не шалит никакая из
сильно умных утилит? </thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60189</commentid>
    <comment_count>11</comment_count>
    <who name="Eugene Ostapets">eostapets</who>
    <bug_when>2007-12-30 12:22:09 +0300</bug_when>
    <thetext>Какая из? Ничего специального я не настраивал! 

Судя по отладке, к моменту вызова удаления файрвола, адреса и ip routes уже
нет(что не удивительно), но ip rules еще существуют...

Кстати, только что поигрался еще и с ifup/ifdown, так вот ifdown вызывает
удаление только один и слишком поздно, так что после комплекта ifdown volia ;
ifup volia я получаю плюс одно правило... Если при выполнении этой комбинации
адрес от dhcp изменится - я получу неработоспособную систему... </thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60207</commentid>
    <comment_count>12</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2007-12-30 22:20:16 +0300</bug_when>
    <thetext>(In reply to comment #11)
&gt; Какая из? Ничего специального я не настраивал! 
&gt; 
&gt; Судя по отладке, к моменту вызова удаления файрвола, адреса и ip routes уже
&gt; нет(что не удивительно), но ip rules еще существуют...
Да вот это как раз и удивительно. Без dhcp адрес в этот момент существует. А вот 
функция stop_dhcp_client в functions прибивает dhcp клиент. А не может ли именно
он и удалять адрес? МОжешь проверить на статическом адреса, просто для теста?
Если адрес назначает dhcp, то он и должен его убирать? Или все-таки убирать не
он должен?

&gt; 
&gt; Кстати, только что поигрался еще и с ifup/ifdown, так вот ifdown вызывает
&gt; удаление только один и слишком поздно, так что после комплекта ifdown volia ;
&gt; ifup volia я получаю плюс одно правило... Если при выполнении этой комбинации
&gt; адрес от dhcp изменится - я получу неработоспособную систему... 

</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60208</commentid>
    <comment_count>13</comment_count>
    <who name="Eugene Ostapets">eostapets</who>
    <bug_when>2007-12-30 23:27:24 +0300</bug_when>
    <thetext>Конечно должен, достаточно сказать killall dhcpcd, чтобы адреса уже не было на
интерфейсе!!!
Проверил, если сделать BOOTPROTO=static (при том, что адрес назначен через
dhcpcd), то перезапуск происходит без ругани. Я одного не понимаю - кто все таки
удачно удаляет правило и как, dhcpcd к этому явно не причастен... Или это
конечный iptables -F уже зачищает?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60209</commentid>
    <comment_count>14</comment_count>
    <who name="Mikhail Gusarov">dottedmag</who>
    <bug_when>2007-12-30 23:33:02 +0300</bug_when>
    <thetext>Кстати, тогда вся процедура опускания должна обрабатывать случай, когда адреса 
на интерфейсе уже нет. Мало ли по какой причине dhcp-клиент помер :)
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60210</commentid>
    <comment_count>15</comment_count>
    <who name="Eugene Ostapets">eostapets</who>
    <bug_when>2007-12-30 23:44:03 +0300</bug_when>
    <thetext>Я боюсь заикнуться, но что происходит, если вообще есть реакция, если в ходе
работы dhcpcd меняется адрес на интерфейсе... У меня бывает комп по пару месяцев
не перегружается... Но если на старой квартире адрес у меня не менялся, то на
новом месте у меня при каждой перезагрузке он прыгает и подозреваю, что
теоретически может прыгнуть просто при очестке кэша и перезагрузке dhcpd на
стороне сервера... </thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60212</commentid>
    <comment_count>16</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2007-12-31 02:36:56 +0300</bug_when>
    <thetext>Нда, плохо. Слона-то я и не приметил. Опять придется под это костыль какой-то
приделывать. А недавно, вроде бы, в etcnet изобрели еще что-то, кроме static и
dhcp. Кажется, некое avahi. Там как работает добавление/удаление адресов? Нужно,
похоже, это в виде хуков уже все реализовывать. В OS/2 это было популярно во
всяком ПО :)
Кто удаляет конечное правило - то же интересно. ifdown eth0 не должен, только
при network stop, когда удаляется всё из iptables.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60234</commentid>
    <comment_count>17</comment_count>
    <who name="Eugene Ostapets">eostapets</who>
    <bug_when>2007-12-31 14:16:17 +0300</bug_when>
    <thetext>Кстати да, с avahi я тоже собираюсь поиграться, но пока руки не дошли:) Знаю
только одно - в бубунте он(avahi) меня достал так, что я его пришиб... Хотя...
Может я просто не умею его готовить... :)</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>60252</commentid>
    <comment_count>18</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2008-01-01 04:02:07 +0300</bug_when>
    <thetext>Надо с Денисом посовещаться. Потому как это не только firewall касается, если
использовать эту переменную. qos еще, например. Видимо, остановку fw/qos
придется вставлять еще раньше прибивания dhcp. </thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>93132</commentid>
    <comment_count>19</comment_count>
    <who name="Denis Ovsienko">pilot</who>
    <bug_when>2009-06-16 13:18:30 +0400</bug_when>
    <thetext>Либо решайте, либо закрывайте.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>149422</commentid>
    <comment_count>20</comment_count>
    <who name="Pavel Vainerman">pv</who>
    <bug_when>2014-12-23 14:50:35 +0300</bug_when>
    <thetext>у меня такая же проблема, сейчас (cert6).
При service network start переменная  ${IPV4ADDRESS} применяется..
при restart видна ругать..

[root@gate fw]# service network restart
Computing interface groups: ... 3 interfaces found
Processing /etc/net/vlantab: empty.
Stopping group 1/realphys (2 interfaces)
        Stopping lan0: 
Stopping iptables for lan0
        Unloading rules for the &quot;PREROUTING&quot; chain in the &quot;nat&quot; tableiptables: No chain/target/match by that name.
ERROR: /etc/net/scripts/config-fw: /sbin/iptables -t nat -D PREROUTING -p tcp --destination $IPV4ADDRESS --dport 20132 -j DNAT --to-destination $IPV4ADDRESS:22
.
        ...OK</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>149423</commentid>
    <comment_count>21</comment_count>
    <who name="Pavel Vainerman">pv</who>
    <bug_when>2014-12-23 14:51:53 +0300</bug_when>
    <thetext>BOOTPROTO=static..</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>179233</commentid>
    <comment_count>22</comment_count>
    <who name="mrdrew@altlinux.org">mrdrew</who>
    <bug_when>2019-03-06 17:55:48 +0300</bug_when>
    <thetext>Не воспроизводится.</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>