ALT Linux Community general discussions
 help / color / mirror / Atom feed
From: Alex Moskalenko <mav@elserv.msk.su>
To: community@lists.altlinux.org
Subject: Re: [Comm] P9 OpenVZ7 - автоматическое добавление veth-интерфейса в бридж
Date: Thu, 17 Dec 2020 11:54:44 +0300
Message-ID: <396098ef-690b-a657-7c20-007ef161e982@elserv.ru> (raw)
In-Reply-To: <b20922cc-d515-5754-20f6-56deb276fca7@elserv.ru>

В общем, штатными средствами добавить создаваемый интерфейс в мост я так 
и не смог. Указание network=bridgename для описания интерфейса не 
помогло - скрипт vznetcfg пытается использовать prlsrvctl, которого у 
нас нет.

Пока остановился на костыле - прописывание вручную в конфигурационный 
файл VE в конфигурацию интерфейса bridge=bridgename и создание скрипта 
/usr/share/libvzctl/script.d/vz-netns_dev_add по мотивам аналога из 
старого OpenVZ:

#!/bin/bash

. /etc/vz/vz.conf
. /usr/share/libvzctl/scripts/vz-functions

vzcheckvar VEID
vzcheckvar VNAME
vzcheckvar HNAME

. /etc/vz/conf/$VEID.conf

for iface in $(printf %s "$NETIF" |tr ';' '\n'); do
     unset BRIDGE
     bridge=
     host_ifname=

     for str in $(printf %s "$iface" |tr ',' '\n'); do
     case "$str" in
         bridge=*|host_ifname=*)
         eval "${str%%=*}=\${str#*=}" ;;
     esac
     done
     [ "$host_ifname" = "$HNAME" ] || continue
     [ -n "$bridge" ] && export BRIDGE="$bridge"
     break
done

/usr/share/libvzctl/scripts/vz-netns_dev_add


Если кто знает менее извращенный способ (а кстати, как это делается в 
RHEL? Ядро ведь из него?) - прошу поделиться знанием.


04.12.2020 17:27, Alex Moskalenko пишет:
>
> 04.12.2020 15:49, Andrew A. Vasilyev пишет:
>
>>> 2.  Непонятно пока, что делать с контейнерами, использующими veth. В 
>>> p8 был файл vznet.conf, в котором указывался внешний скрипт, 
>>> добавляющий veth-интерфейс со стороны хоста в указанный в 
>>> конфигурационном файле VE мост. В p9 vzctl вообще не знает параметр 
>>> bridge= в конфигурации VE, а файлы vznet.conf похоже вообще не 
>>> читается и внешний скрипт не вызывается. В mount-скрипте интерфейс 
>>> еще не создан. Как теперь правильно добавлять veth-интерфейсы 
>>> контейнеров в бридж?
>>
>>   В mount-скрипте можно ждать появления нужного интерфейса, как 
>> предлагается в примере из 
>> https://wiki.openvz.org/Virtual_Ethernet_device
>>   Только нужно обратить внимание на то, что скрипт mount должен 
>> находиться в каталоге /var/lib/vz/private/VEID/scripts/, при этом 
>> файловая система должна быть смонтирована без флага noexec! Файлы 
>> /etc/vz/conf/VEID.mount не поддерживаются. Про скрипты mount и 
>> vps.mount написано в vzctl(8).
>>
> Вариант с wiki.openvz.org тоже рассматривал и тестировал, но он у меня 
> не сработал, так как vzctl похоже ждет завершения всех потомков 
> mount-скрипта, и пока все они не завершатся - интерфейсы не создаются. 
> А потомки не завершаются, так как ждут создания интерфейса...
>


      reply	other threads:[~2020-12-17  8:54 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-12-04  7:57 Alex Moskalenko
2020-12-04 12:49 ` Andrew A. Vasilyev
2020-12-04 14:27   ` Alex Moskalenko
2020-12-17  8:54     ` Alex Moskalenko [this message]

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=396098ef-690b-a657-7c20-007ef161e982@elserv.ru \
    --to=mav@elserv.msk.su \
    --cc=community@lists.altlinux.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

ALT Linux Community general discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/community/0 community/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 community community/ http://lore.altlinux.org/community \
		mandrake-russian@linuxteam.iplabs.ru community@lists.altlinux.org community@lists.altlinux.ru community@lists.altlinux.com
	public-inbox-index community

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.community


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git