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

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

    <bug>
          <bug_id>16881</bug_id>
          
          <creation_ts>2008-08-25 11:12:05 +0400</creation_ts>
          <short_desc>Неверные примеры qos в документации</short_desc>
          <delta_ts>2018-06-08 19:00:24 +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>
          <dependson>30523</dependson>
          
          <everconfirmed>1</everconfirmed>
          <reporter name="Vladimir V. Kamarzin">vvk</reporter>
          <assigned_to name="Andrew Kornilov">hiddenman</assigned_to>
          <cc>eugine.kosenko</cc>
    
    <cc>evg</cc>
    
    <cc>gray_graff</cc>
    
    <cc>grenka</cc>
    
    <cc>ldv</cc>
    
    <cc>mike</cc>
    
    <cc>rider</cc>
    
    <cc>sem</cc>
    
    <cc>shaba</cc>
    
    <cc>zver</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>76208</commentid>
    <comment_count>0</comment_count>
    <who name="Vladimir V. Kamarzin">vvk</who>
    <bug_when>2008-08-25 11:12:05 +0400</bug_when>
    <thetext>etcnet-0.9.7-alt0.M40.1
4.0/branch от конца августа 2008.

# pwd
/etc/net/ifaces/eth0/qos
# cp -rp /usr/share/doc/etcnet-0.9.7/examples/QoS-HTB-user-guide/1 .
# eqos eth0 start
# tc filter show dev eth0
#

Самописные скрипты для конфигурирования шейперов всё добавляют.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>76910</commentid>
    <comment_count>1</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2008-09-03 01:30:00 +0400</bug_when>
    <thetext>Ну слепо копировать из примеров не стоит, не факт, что они рабочие :) Покажите ls -lR, например. Включите VERBOSE и PROGRESS и в /var/log/messages загляните</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>76911</commentid>
    <comment_count>2</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2008-09-03 01:30:41 +0400</bug_when>
    <thetext>А, Вова, это ты...Ну может и не работает что, кто его знает.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>76929</commentid>
    <comment_count>3</comment_count>
    <who name="Vladimir V. Kamarzin">vvk</who>
    <bug_when>2008-09-03 08:52:36 +0400</bug_when>
    <thetext>Ну я и по документации на wiki пробовал делать, и по аналогии с примерами. Где-то затык там явно.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>76930</commentid>
    <comment_count>4</comment_count>
    <who name="Vladimir V. Kamarzin">vvk</who>
    <bug_when>2008-09-03 08:53:02 +0400</bug_when>
    <thetext>В сизифе кстати скорее всего такая же проблема.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>76969</commentid>
    <comment_count>5</comment_count>
    <who name="Andrew Kornilov">hiddenman</who>
    <bug_when>2008-09-03 22:44:11 +0400</bug_when>
    <thetext>Ты ls -lR всё-таки покажи и в messages глянь, что пишет. У меня, например, всё работает.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>87875</commentid>
    <comment_count>6</comment_count>
    <who name="Vladimir V. Kamarzin">vvk</who>
    <bug_when>2009-03-25 09:17:15 +0300</bug_when>
    <thetext>В общем, поковырялся вчера с этим и обнаружил, что в классе 1:1 требуется создать фильтры, заворачивающие в него весь трафик:
% cat /etc/net/ifaces/ppp0/qos/1/1/filter
proto ip prio 1 u32 match ip src 0.0.0.0/0
proto ip prio 2 u32 match ip src 0.0.0.0/0
proto ip prio 5 u32 match ip src 0.0.0.0/0
proto ip prio 6 u32 match ip src 0.0.0.0/0

без этого фильтры вида
% cat /etc/net/ifaces/ppp0/qos/1/1/10/filter
protocol ip prio 1 u32  match ip tos 0x10 0xff

не добавляются вовсе, причём tc ошибок не выдаёт, и код завершения 0 :(</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>87877</commentid>
    <comment_count>7</comment_count>
    <who name="Vladimir V. Kamarzin">vvk</who>
    <bug_when>2009-03-25 09:19:16 +0300</bug_when>
    <thetext>Перевешиваю на сизиф и меняю summary. Нужно исправить примеры, идущие в пакете.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>87895</commentid>
    <comment_count>8</comment_count>
    <who name="Denis Ovsienko">pilot</who>
    <bug_when>2009-03-25 12:50:59 +0300</bug_when>
    <thetext>QoS-HTB-user-guide, как нетрудно догадаться, --- адаптация иерархии из HTB user guide к синтаксису /etc/net. В своё время этот пример был рабочим, насколько я помню. Смотреть нужно.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>148985</commentid>
    <comment_count>9</comment_count>
    <who name="Eugine V. Kosenko">eugine.kosenko</who>
    <bug_when>2014-11-24 09:21:54 +0300</bug_when>
    <thetext>Прошло пять лет...

Проблема по прежнему актуальна. Я отписался по ее поводу здесь:

http://lists.altlinux.org/pipermail/community/2014-November/683086.html

Я даже испугался, что как это до меня этого никто не обнаружил. Примеры в документации правильные и они до сих пор работают. Беда в самом etcnet.

Дело в том, что при настройке iproute фильтры должны иметь своим родителем базовый класс HTB (например, с идентификатором 1:0), а поток пакетов направлять в его дочерний класс (например, с идентификатором 1:11). В этом случае правильная команда для настройки tc должна быть:

tc filter add dev $1 protocol ip parent 1:0 prio 1 handle 1 fw flow 1:11

И здесь возникает противоречие. С одной стороны, etcnet-описание фильтр должен быть размещен в каталоге родительского класса, чтобы ему был правильно назначен parent. С другой стороны, согласно предлагаемой идеологии etcnet фильтр должен быть размещен в каталоге класса, куда направляется поток.

Попытка вынести описание на уровень родительского класса не дает нужного результата --- etcnet автоматически указывает направление в сам родительский класс.

Я решил проблему, сломав слегка файл /etc/net/scripts/config-qos. А именно, убрал из этого скрипта автоматическое направление в дочерние классы при задании фильтра, а нужное направление указал явно в файле filter на уровне родительского класса. При этом, однако, пришлось перенести инициализацию фильтров в конец процесса инициализации, иначе при задании фильтра дочерние классы еще не созданы и фильтр не может найти нужное направление. Правда, есть еще глюки с созданием лишних записей, сейчас воюю с этим. Может быть, позже опубликую патч с таким вот промежуточным решением.

Но как решить проблему идеологически грамотно --- пока не знаю...</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>149089</commentid>
    <comment_count>10</comment_count>
    <who name="Eugine V. Kosenko">eugine.kosenko</who>
    <bug_when>2014-11-29 09:39:40 +0300</bug_when>
    <thetext>Думаю, что эта проблема не связана с документацией. По крайней мере, в документации все настройки описаны именно так, как ожидается, чтобы они работали. Просто фильтр привязывается к некорректному родителю.

Поэтому я поставил зависимость от

https://bugzilla.altlinux.org/show_bug.cgi?id=30523

и считаю, что эту проблему можно закрыть.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>171732</commentid>
    <comment_count>11</comment_count>
    <who name="Grigory Ustinov">grenka</who>
    <bug_when>2018-06-08 19:00:24 +0300</bug_when>
    <thetext>(В ответ на комментарий №10)
&gt; Думаю, что эта проблема не связана с документацией. По крайней мере, в
&gt; документации все настройки описаны именно так, как ожидается, чтобы они
&gt; работали. Просто фильтр привязывается к некорректному родителю.
&gt; 
&gt; Поэтому я поставил зависимость от
&gt; 
&gt; https://bugzilla.altlinux.org/show_bug.cgi?id=30523
&gt; 
&gt; и считаю, что эту проблему можно закрыть.

Ну так и надо было закрыть.</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>