OpenVZ Forum


Home » International » Russian » [SOLVED] openvz на LiveCD -- что-то с правами MS_NOUSER
[SOLVED] openvz на LiveCD -- что-то с правами MS_NOUSER [message #10607] Sat, 24 February 2007 03:50 Go to next message
seyko2 is currently offline  seyko2
Messages: 188
Registered: February 2007
Location: Moscow
Senior Member

При попытке использовать openvz-028.015 как ядро для загрузки с ISO столькнулся с проблемой, что UNIONFS не может вывести перечень каталогов, объединенных в одно целое.

То есть команда
cat /proc/mounts
вызывает oops внутри unionfs. Раскопки показали, что проблема в функии __d_path() файла dcache.c ядра openvz. А именно в строчках

if (!(oldvfsmnt->mnt_sb->s_flags & MS_NOUSER))
return ERR_PTR(-EINVAL);

Если их вырезать, то все работает.
UNIONFS на livecd используется в качестве корневой FS.

Вопрос: что сия прооверка означает и как поправить unionfs чтоб она правильно флаги выставляла?

[Updated on: Sun, 04 March 2007 07:11]

Report message to a moderator

Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10610 is a reply to message #10607] Sat, 24 February 2007 07:56 Go to previous messageGo to next message
seyko2 is currently offline  seyko2
Messages: 188
Registered: February 2007
Location: Moscow
Senior Member

Уточнение -- MS_NOUSER срабатывает только для подмонтированного в UNIONFS squashfs-файла. Входящий в UNIONFS RAM-диск такой проблемы не имеет. SQUASHFS-патч наложен на openvz-028.15 без проблем, взят из стандарных патчей для gentoo-sources.
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10678 is a reply to message #10607] Mon, 26 February 2007 12:43 Go to previous messageGo to next message
dev is currently offline  dev
Messages: 1693
Registered: September 2005
Location: Moscow
Senior Member

сия проверка означает следующие:
все пути которые получаются через __d_path должны быть видимы внутри VE. Для этого, путь должен всегда начинаться с /, т.е. корневой dentry VE. Однако есть виртуальные файловые системы - типа sockfs, pipefs которые создают super_block через get_sb_pseudo(), т.к. они реально никуда не примонтированы в дереве файлов - ядро монтирует их специальным образом. Такие файловые системы данная проверка должна пропускать.

как правильно пофиксить: подпереть unionfs код, чтобы он проверял код ошибки d_path() и пропускал такой mount.


http://static.openvz.org/userbars/openvz-developer.png
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10680 is a reply to message #10607] Mon, 26 February 2007 13:06 Go to previous messageGo to next message
Vasily Tarasov is currently offline  Vasily Tarasov
Messages: 1345
Registered: January 2006
Senior Member
Здравствуйте, Сергей,

Если я правильно понимаю, вы подпатчили OpenVZ ядро, чтобы оно поддерживало unionfs. А код внутри unionfs не делает проверку на возврат функции __d_path(.), в результате, когда выполняется условие !(oldvfsmnt->mnt_sb->s_flags & MS_NOUSER) происходит Oops.
Я вас правильно понял?

Если да, то вам, во-первых, стоит сообщить разработчикам unionfs об этой досадной ошибке =) Они должны проверять возврат этой функции.

Во-вторых, что касается проверки:
oldvfsmnt->mnt_sb->s_flags & MS_NOUSER
там есть такой коммент:
+        * We traversed the tree upward and reached a root, but the given
+        * lookup terminal point wasn't encountered.  It means either that the
+        * dentry is out of our scope or belongs to an abstract space like
+        * sock_mnt or pipe_mnt.  Check for it.
+        *
+        * There are different options to check it.
+        * We may assume that any dentry tree is unreachable unless it's
+        * connected to `root' (defined as fs root of init aka child reaper)
+        * and expose all paths that are not connected to it.
+        * The other option is to allow exposing of known abstract spaces
+        * explicitly and hide the path information for other cases.
+        * This approach is more safe, let's take it.  2001/04/22  SAW
+        */


Т.е. из VE разрешены быть видимыми только ФС:
1) примонтированные в VE
2) те, у которых ноги растут не из VE и при этом они "особые" (ramfs, shmemfs, ramfs, libfs...)

[Updated on: Mon, 26 February 2007 13:07]

Report message to a moderator

Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10739 is a reply to message #10678] Tue, 27 February 2007 16:42 Go to previous messageGo to next message
seyko2 is currently offline  seyko2
Messages: 188
Registered: February 2007
Location: Moscow
Senior Member

dev wrote on Mon, 26 February 2007 07:43

сия проверка
как правильно пофиксить: подпереть unionfs код, чтобы он проверял код ошибки d_path() и пропускал такой mount.



Приделать в код UNIONFS проверку на предмет валидности указателя -- святое. Однако что смущает: пропускаем мы такой mount и в выводимой информации отсутствует инфа о подмонтированной squashfs (reas-only система). А выкидывает из ядра OPENVZ указанную проверку -- и все показывается как надо и проблем нет.

Мож проверка не совсем корректна?
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10741 is a reply to message #10739] Tue, 27 February 2007 16:53 Go to previous messageGo to next message
dev is currently offline  dev
Messages: 1693
Registered: September 2005
Location: Moscow
Senior Member

мммм...
вообще конечно надо смотреть по коду что делает этот squashfs такого, что по пути от dentry мы не доходим до root'а.

dirty hack: проверять не только на MS_NOUSER, но и на sb->fs_type->fs_magic == SQUASHFS_FS_MAGIC

если не сложно зайбете баг в bugzillа. чуть попозже покапаемся, может вылечим почеловечески.


http://static.openvz.org/userbars/openvz-developer.png
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10742 is a reply to message #10680] Tue, 27 February 2007 16:59 Go to previous messageGo to next message
seyko2 is currently offline  seyko2
Messages: 188
Registered: February 2007
Location: Moscow
Senior Member

Т.е. из VE разрешены быть видимыми только ФС:
1) примонтированные в VE
2) те, у которых ноги растут не из VE и при этом они "особые" (ramfs, shmemfs, ramfs, libfs...)

До использования VE вроде дело не доходит. Просто openvz используется как обычное ядро при загрузке с CDROM. При этом происходят манипуляции с путями ранее подмонтированных систем. Сама UNIONFS становится корневой, а подмонтированные системы уходят куда-то вглубь.

Может стартовая squashfs тоже особая? Или Unionfs неправильно с флагами манипулирует?

Да, unionfs я практически не правил: только то что здесь в форуме уже пролетало

- if (!permission(hidden_dir, MAY_WRITE | MAY_EXEC, NULL))
+ if (!permission(hidden_dir, MAY_WRITE | MAY_EXEC, NULL, NULL))
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10743 is a reply to message #10742] Tue, 27 February 2007 17:14 Go to previous messageGo to next message
dev is currently offline  dev
Messages: 1693
Registered: September 2005
Location: Moscow
Senior Member

полагаю что unionfs по какой-то причине не удовлетворяет этим рассуждениям... с другой стороны Вы говорите что на ramfs - раюотает. Значит дело в squashfs?

Вы готовите LiveCD? надеюсь, можно будет на него взглянуть :@)


http://static.openvz.org/userbars/openvz-developer.png
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10744 is a reply to message #10741] Tue, 27 February 2007 17:16 Go to previous messageGo to next message
seyko2 is currently offline  seyko2
Messages: 188
Registered: February 2007
Location: Moscow
Senior Member

Чисто squashfs без unionfs прооблем не вызывает (когда корень / остается в initramfs). Проблема -- когда unionfs станоится корнем, то есть / есть на самом деле unionfs с ФС внутри. Подозреваю, что с ramdisk внутри unionfs тоже бы проблемы были но он проскакивает проверку как "особая система"
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10745 is a reply to message #10743] Tue, 27 February 2007 17:30 Go to previous messageGo to next message
seyko2 is currently offline  seyko2
Messages: 188
Registered: February 2007
Location: Moscow
Senior Member

dev wrote on Tue, 27 February 2007 12:14

полагаю что u
Вы готовите LiveCD? надеюсь, можно будет на него взглянуть :@)



LiveCD стандарный гентушный (GENTOO mini-cd), только ядро не gentoo-sources, а openvz-sources.

Если указанную проверку выкинуть -- внутри VE мы сможем увидать не только свое ?
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10747 is a reply to message #10742] Tue, 27 February 2007 17:34 Go to previous messageGo to next message
seyko2 is currently offline  seyko2
Messages: 188
Registered: February 2007
Location: Moscow
Senior Member

На каком этапе создаются VE? В том числе VE0? Может при загрузке squashfs умудряются подмонтировать раньше создания VE, потом создают VE и получается, что squashfs и не особая и не создана внутри VE...
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10754 is a reply to message #10745] Wed, 28 February 2007 07:52 Go to previous messageGo to next message
dev is currently offline  dev
Messages: 1693
Registered: September 2005
Location: Moscow
Senior Member

да, в /proc/mounts начнут показываться левые mount'ы. плюс /proc/pid/fd для процесса который зашел извне (например, vzctl) будут видны всякие внешние пути, если не ошибаюсь, можно будет даже открыть бинарник vzctl и т.д.

если все дело в unionfs, тогда можно проверить на ее fstype.
Это довольно безопасно, т.к. понятно что делает unionfs...


http://static.openvz.org/userbars/openvz-developer.png
Re: openvz на LiveCD -- что-то с правами MS_NOUSER [message #10755 is a reply to message #10747] Wed, 28 February 2007 07:53 Go to previous messageGo to next message
dev is currently offline  dev
Messages: 1693
Registered: September 2005
Location: Moscow
Senior Member

вы же говорите что проблема стреляет без всяких VE?
VE0 это часть системы. она есть с самого начала boot'а.


http://static.openvz.org/userbars/openvz-developer.png
[SOLVED] openvz на LiveCD -- что-то с правами MS_NOUSER [message #10812 is a reply to message #10678] Sun, 04 March 2007 07:08 Go to previous message
seyko2 is currently offline  seyko2
Messages: 188
Registered: February 2007
Location: Moscow
Senior Member

Как выяснилось, проблема с initramfs от GENTOO. Точнее как там на данный момент реализована поддержка UNIONFS. SQUASHFS образ сначала монтируется на каталоге /newroot/mnt/live (точно не помню), а потом корнем делается unionfs, в которой /newroot каталога уже нет.

В SLAX squashfs доступен и после того, как корнем становится UNIONFS, причем по тому же пути.

RESUME:
openvz только помог выявить такую странную реализацию. К разработчикам unionfs отправлен рапорт об необходимости проверять код возврата функции d_path()
Previous Topic: vzyum & locale
Next Topic: IP адреса типа 10.10.10.х
Goto Forum:
  


Current Time: Sun Nov 03 23:19:24 GMT 2024

Total time taken to generate the page: 0.06136 seconds