Когда я пытаюсь настроить remus между двумя машинами, я получаю ошибку в файле журнала remus, я не могу понять, почему это происходит, у меня на обеих системах запущены одни и те же vms, поэтому попытка репликации не должна быть проблемой. Файл журнала выглядит следующим образом
Disk is not replicated: phy:/dev/loop0,xvda,w
Disk is not replicated: phy:/dev/loop1,xvdb,w
tc qdisc add dev vif1.0 ingress
RTNETLINK answers: File exists
tc filter add dev vif1.0 parent ffff: proto ip pref 10 u32 match u32 0 0 action
mirred egress redirect dev ifb0
RTNETLINK answers: No such file or directory
We have an error talking to the kernel
Traceback (most recent call last):
File "/usr/bin/remus", line 219, in <module>
run(cfg)
File "/usr/bin/remus", line 125, in run
bufs.append(BufferedNIC(vif))
File "/usr/lib64/python2.6/site-packages/xen/remus/device.py", line 326, in __init__
self.setup()
File "/usr/lib64/python2.6/site-packages/xen/remus/device.py", line 358, in setup
self.bufdev.install(self.vif)
File "/usr/lib64/python2.6/site-packages/xen/remus/device.py", line 184, in install
'dev %s' % (vif.dev, self.devname))
File "/usr/lib64/python2.6/site-packages/xen/remus/util.py", line 71, in runcmd
proc.returncode)
xen.remus.util.PipeException: tc failed (errmsg: RTNETLINK answers: No such file or directory
We have an error talking to the kernel): 2, No such file or directory
Команда remus, используемая для получения этого файла, выглядит следующим образом:
remus -i 100 sles11-sp1-xm BackupMachineIP >/var/log/xen/domU-sles11-sp1-24-09-12.log 2>&1 &
BackupMachineIP настраивается как имя IP-адреса устройства резервного копирования, содержимое списка xm и настройки устройства обратной связи на каждой машине следующие:
список xm
Начальный:
Name ID Mem VCPUs State Time(s)
Domain-0 0 1036702 8 r----- 411617.9
sles11-sp1 512 4 0.0
sles11-sp1-xm 1 256 1 -b---- 77.0
sles11-sp2 512 4 0.0
sles11-sp2-xm 2 256 1 -b---- 62.0
Вторичное:
Name ID Mem VCPUs State Time(s)
Domain-0 0 1400 2 r----- 73.1
sles11-sp1-xm 1 256 1 -b---- 11.6
sles11-sp2-xm 2 256 1 -b---- 14.0
проиграть
Начальный:
/dev/loop0: [0808]:337772 (/tmp/base/sles11sp1/sles11sp1.img)
/dev/loop1: [0808]:337773 (/tmp/base/sles11sp1/swap)
/dev/loop2: [0808]:337779 (/tmp/base/sles11sp2/sles11sp2.img)
/dev/loop3: [0808]:337780 (/tmp/base/sles11sp2/swap)
Вторичное:
/dev/loop0: [0805]:2109411 (/tmp/base/sles11sp1/sles11sp1.img)
/dev/loop1: [0805]:2109412 (/tmp/base/sles11sp1/swap)
/dev/loop2: [0805]:1840010 (/tmp/base/sles11sp2/sles11sp2.img)
/dev/loop3: [0805]:1840012 (/tmp/base/sles11sp2/swap)
решение1
Вероятно, в вашем ядре не загружен модуль ядра mirred. Обычно он даже не компилируется с ядром, поэтому вам приходится компилировать и загружать его. Довольно глупо, что RTNETLINK отвечает простым ENOENT (Нет такого файла или каталога), если модуль не загружен, мне потребовался почти день, чтобы выяснить, почему он не работает.