В процессе обновления FreeBSD с версии 7.0 до версии 7.4 методом компиляции ядра и "мира" столкнулся с возникновением ошибки на одном из последних шагов - запуске утилиты mergemaster без параметров.
# mergemaster
*** Creating the temporary root environment in /var/tmp/temproot
*** /var/tmp/temproot ready for use
*** Creating and populating directory structure in /var/tmp/temproot
+ ln -s ../var/named/etc/namedb /var/tmp/temproot/etc/namedb
install: wrong number or types of arguments
usage: install [-bCcpSsv] [-B suffix] [-f flags] [-g group] [-m mode]
[-o owner] file1 file2
install [-bCcpSsv] [-B suffix] [-f flags] [-g group] [-m mode]
[-o owner] file1 ... fileN directory
install -d [-v] [-g group] [-m mode] [-o owner] directory ...
*** FATAL ERROR: Cannot 'cd' to /usr/src and install files to
the temproot environment
Смотрим, что такое /var/tmp/temproot/etc/namedb:
# ls -l /var/tmp/temproot/etc/namedb
lrwxr-xr-x 1 root wheel - 23 6 янв 11:53 /var/tmp/temproot/etc/namedb@ -> ../var/named/etc/namedb
Стало быть - символическая ссылка.
Но перейти по ней не получается, несмотря на то, что исходная директория существует:
# cd /var/tmp/temproot/etc/namedb
cd: permission denied: /var/tmp/temproot/etc/namedb
Собственно, из-за этого утилите instal и не получается скопировать файлы в эту директорию.
Все потому, что на сервере директория /var/tmp примонтирована без права перехода по символическим ссылкам:
# mount | grep tmp
/dev/ar0s1d on /var/tmp (ufs, local, noexec, nosuid, nosymfollow)
Данный флаг был выставлен для того, чтобы предотвратить часть хакерских атак, возможных при эксплуатации дыр в стороннем ПО при загрузке файлов на сервер (которые первоначально попадают как раз в /var/tmp).
Выхода два:
- Убрать в файле /etc/fstab флаг nosymfollow и примонтировать заново /var/tmp
- Указывать утилите mergemaster другой раздел для развертывания каталога temproot с помощью параметра -t