NFS HOWTO <author>Nicolai Langfeldt <tt/janl@math.uio.no/, перевод Alex Ott <tt>ott@phtd.tpu.edu.ru</tt> <date>v0.7, 3 Ноября 1997 <abstract> Как установить настроить клиент и сервер NFS </abstract> <toc> <p><bf>Примечание переводчика:</bf> Шлите мне любый комментарии и замечания, даже небольшие. <sect>Преамбула <sect1>Официальная часть <p>Авторские права Nicolai Langfeldt, 1997. Не вносить изменения без измения авторских прав, распространяется свободно, но с сохранением этого параграф. Раздел FAQ основывается на NFS FAQ, собранном Alan Cox. Раздел по разрешению проблем основан на списке проверки (checklist) проблем монтирования, собранном IBM Corporation. <sect1>Остальное <p>Это документ никогда не будет не завершен, пожалуйста присылайте мне сообщения о ваших успехах и проблемах -- это сделает этот документ лучше. Пожалуйста посылайте деньги, комментарии и/или вопросы janl@math.uio.no. Если вы посылаете сообщение по электронной почте, пожалуйста будьте уверены, что ваш обратный адрес правилен и работает, я получаю довольно много сообщений по электронной почте и определение вашего адреса может задать мне лишнюю работу. Пожалуйста. <p>Если вы хотите перевести этот HOWTO пожалуйста дайте мне знать, чтобы я мог отслеживать на каких языках я опубликован :-). <p>Проклятья и благодарности Olaf Kirch, который заставил меня написать этот документ и кто сделал много рекомендаций для него :-) <p>Этот HOWTO делает обзор NFS, используемого в ядрах версий 2.0.x. В ядрах версий 2.1.x существуют значительные изменения и дополнения. <sect1>Посвящение <p>Этот документ посвящен Anne Line Norheim Langfeldt. Хотя она вероятно никогда не прочитает его, поскольку она не относится к классу девушек, интересующихся этим вопросом. <sect>README.first<label id="intro"> <p>NFS --- Network File System (Сетевая файловая система) имеет три важных свойства: <itemize> <item>Она делает возможным разделение файлов по сети. <item>Она в большинстве работает достаточно хорошо. <item>Ее открытие может быть риском для безопасности, что хорошо понимается кракерами и может быть легко взломано чтобы получить доступ (чтение, запись, удаление) ко всем вашим файлам. </itemize> <p>В этом документе я расскажу о первых двух вопросах. Пожалуйста, убедитесь, что вы читали раздел о безопасности в этом документе и вы сможете уменьшить уязвимость своей системы от проблем безопасности. Пассажи о секретности будут довольно техническими и будут требовать некоторого знания о работе IP сетей и владение используемыми терминами. Если вы не знаете эти термины, то вы должны вернуться назад и просмотреть относящиеся к сети HOWTO или взять книгу о сетевом администрировании TCP/IP, чтобы ознакомить себя с TCP/IP. В любом случае это хорошая идея, если вы занимаетесь администрированием машин с UNIX/Linux. Очень хорошая книга о данном предмете -- это книга <em>TCP/IP Network Administration</em>, написанная Craig Hunt и опубликованая O'Reilly & Associates, Inc. И после того, как вы прочитаете и поймете ее у вас будет больше шансов при поиске работы, вы просто не сможете быть слабым ;-) <p>В этом документе есть два раздела чтобы помочь вам найти неисправности при работе с NFS, эти разделы называются <em/Список проверки проблем монтирования/ и <em/FAQs/. Пожалуйста посмотрите их, если что-то работает не так, как требуется. <sect>Установка сервера NFS<label id="nfs-server"> <sect1>Непременные условия <p>До того, как вы продолжите читать этот документ вам будет необходимо успешно выполнять операцию telnet между машинами, которые вы будете использовать как сервер и клиент. Если что-то не работает, вам нужно прочитать NET-3 HOWTO и правильно настроить работу сети. <sect1>Первый шаг <p>До того, как мы сможем сделать что-нибудь нам необходимо настроить сервер NFS. Если вы являетесь частью сети факультета или университета, то у вас вероятно есть несколько настроенных серверов NFS. Конечно, если они позволят вам получить доступ к ним и если вы читаете этот документ чтобы получить доступ к одному из них, то вам можно не читать это раздел и вы можете просто пропустить его до раздела <ref id="nfs-client" name="Установка клиента NFS"> <p>Если вас нужно настроить не-Linux машину как сервер, то вам нужно прочитать руководство по нужной системе, чтобы определить как разрешить работу сервера NFS и экспортировать файловую систему через NFS. Описание того, как это сделать на разных платформах вынесено в отдельный раздел. После того, как вы определили все, что вам нужно вы можете продолжать чтение следующего раздела этого документа. Или читайте дальше этот раздел, поскольку для некоторых вещей, о которых я буду говорить не важно какой тип машины вы используете как сервер. <p>То, о чем вы читали, потребует от вас настройки нескольких программ. <sect1>Portmapper<label id="portmapper"> <p>Portmapper на Linux называется либо <tt/portmap/ либо <tt/rpc.portmap/. Справочная страница на моей системе говорит, что это "Преобразователь номеров портов DARPA в вызовы соответствующих программ RPC". Это первая дыра в безопасности, которую вы откроете читая этот документ. Описание того, как закрыть одну из таких дыр находится в <ref id="nfs-security" name="разделе по безопасности">, который я советую вам обязательно прочитать. <p>Запустите portmapper. Он называется либо <tt/portmap/, либо <tt/rpc.portmap/ и должен находиться в директории <tt>/usr/sbin</tt> (на некоторых машинах он называется <tt/rpcbind/). Вы можете запустить его сейчас вручную, но он должен запускаться при каждом запуске вашей машины, так что вам необходимо создать/отредактировать rc-скрипты. Содержание ваших rc-скриптов объясняется более подробно в справочной странице <tt/init/. Они обычно находятся в директориях <tt>/etc/rc.d</tt>, <tt>/etc/init.d</tt> или <tt>/etc/rc.d/init.d</tt>. Если там есть скрипт, названный <tt/inet/, то его мы и будем редактировать. Но то, что в нем необходимо написать или что необходимо сделать еще, находится вне области рассмотрения этого документа. Запустите portmap, и проверьте, что он запущен с помощью команды <tt/ps aux/. Это сделано? Хорошо. <sect1>Mountd и nfsd<label id="nfsd"> <p>Следующие программы, которые нам нужно запустить далее -- это mountd и nfsd. Но сначала мы отредактируем другой файл. Это файл <tt>/etc/exports</tt>. Допустим я хочу, чтобы файловая система <tt>/mn/eris/local</tt>, которая находится на машине <tt>eris</tt> была доступна для машины названной <tt/apollon/. Тогда я должен поместить в файл <tt>/etc/exports</tt> на машине eris следующие строки: <code> /mn/eris/local apollon(rw) </code> Вышеприведенные строки дают машине apollon право на чтение/запись в каталог <tt>/mn/eris/local</tt>. Вместо <tt/rw/ мы можем сказать <tt/ro/, что означает достп только для чтения (если вы ничего не поместите, то по умолчанию будет доступ только для чтения. Существуют другие опции, которые вы можете задать здесь, и я позже рассмотрю некоторые из них, относящиеся к проблеме к безопасности. Они все перечислены в справочной странице <tt/exports/, которую вы должны прочитать по крайней мере раз в жизни. Существуют также лучшие способы, чем перечисление всех машин в файле exports. Вы например можете использовать сетевые группы, если у вас используется система NIS (или NYS) (NIS также известен как YP), и всегда использовать шаблоны (wild cards) доменов и подсетей IP как списки машин, которым разрешено что-то монтировать. Но вы должны учитывать, кто может получить доступ к серверу неавторизованным способом, если вы используете такую всеобъемлющую авторизацию. <bf/Замечание: Этот файл exports не имеет такой же синтаксис, который используют другие системы Unix./ В этом документе есть отдельный раздел о файлах <tt/exports/ других Unix-систем. <p>Сейчас мы готовы к запуску программ mountd (она также может называться <tt/rpc.mountd/) и nfsd (который может назван <tt/rpc.nfsd/). Обе эти программы читают данные из файла exports. <p>Если вы отредактировали файл <tt>/etc/exports</tt>, то вы должны быть уверены, что nfsd и mountd знают о том, что файл изменен. Традиционный способ сделать это -- это запустить программу <tt/exportfs/. Во многих дистрибутивах Linux программа exportfs отсутствует. Если это так, то вы можете создать такой скрипт на вашей машине: <code> #!/bin/sh killall -HUP /usr/sbin/rpc.mountd killall -HUP /usr/sbin/rpc.nfsd echo re-exported file systems </code> <p>Сохраните его в файле, скажем <tt>/usr/sbin/exportfs</tt>, и не забудьте выполнить над ним команду <tt/chmod a+rx/. Сейчас, после того как, вы изменили ваш файл exports, вы должны запустить программу exportfs, имея права администратора. <p>Теперь вы должны проверить, что mountd и nfsd запущены правильно. Сначала это делается с помощью команды <tt/rpcinfo -p/. Вывод программы должен показать что-то похожее на следующее: <code> program vers proto port 100000 2 tcp 111 portmapper 100000 2 udp 111 portmapper 100005 1 udp 745 mountd 100005 1 tcp 747 mountd 100003 2 udp 2049 nfs 100003 2 tcp 2049 nfs </code> <p>Как вы видите portmapper анонсировал свои сервисы, и что mountd и nfsd запущены. <p>Если вы получили сообщение <tt>rpcinfo: can't contact portmapper: RPC: Remote system error - Connection refused</tt> или что-то подобное вместо этого, то значит portmapper не запущен. Исправьте это. Если вы получили сообщение <tt>No remote programs registered.</tt>, то либо portmapper не хочет говорить с вами, либо что-то не в порядке. Завершите выполнение nfsd, mountd и portmapper и попытайтесь выполнить заново стартовую последовательность. <p>После проверки того, что portmapper объявил сервисы, вы также можете выполнить проверку работы с помощью команды ps. Portmapper будет продолжать объявлять свои сервисы даже после того как программы расширяющие его возможности завершили работу. Так что проверка с помощью ps может быть необходимой, если вам кажется, что что-то не работает. <p>Конечно вам будет нужно исправить ваши системные rc-файлы для запуска mountd и nfsd при загрузке. Очень вероятно, что эти скрипты уже существуют на вашей машине, и вам будет нужно только раскомментировать нужный раздел или активизировать скрипт на нужном уровне запуска. <p>Справочные страницы, которые вы должны уже изучить: portmap, mountd, nfsd и exports. <p>Если вы сделали все как я сказал, то вы должны были установить все необходимое для работы сервера NFS. <sect>Настройка клиента NFS<label id="nfs-client"> <p>Первым делом вам нужно ядро с поддержкой файловой системы NFS, либо вкомпилированной в ядро, либо доступной как модуль. Это настраивается до компиляции ядра. Если вы никогда не компилировали ядро, то вам может быть нужно прочитать Rernel HOWTO и выяснить как это делается. Если вы используете хороший дистрибутив (такой как RedHat) и вы никогда не экспериментировали с ядром или модулями (и таким образом разрушали его ;-), то вероятно, что поддержка nfs уже есть в ядре. <p>Теперь вы можете, в командной строке администратора, ввести соответствующую команду монтирования и файловая система появится у вас. Продолжая пример из предыдущего раздела мы хотим смонтировать <tt>/mn/eris/local</tt> с машины eris. Это делается с помощью такой команды: <code> mount -o rsize=1024,wsize=1024 eris:/mn/eris/local /mnt </code> <p>(Мы еще вернемся к опциям rsize и wsize). Файловая система сейчас доступна в <tt>/mnt</tt> и вы можете перейти туда и выполнить в ней команду <tt/ls/, и посмотреть на индивидуальные файлы. Вы заметите, что эта операция выполняется не так быстро как над локальной файловой системой, но более удобно чем ftp. Если вместо монтирования файловой системы команда mount выдаст сообщение об ошибке <tt>mount: eris:/mn/eris/local failed, reason given by server: Permission denied</tt>, то файл exports является неправильным или вы забыли запустить exportfs после редактирования файла exports. Если команда сообщит <tt>mount clntudp_create: RPC: Program not registered</tt> это означает, что nfsd или mountd не запущены на сервере. <p>Чтобы прекратить пользоваться файловой системы вы можете выполнить: <code> umount /mnt </code> <p>Чтобы выполнялось автоматическое монтирование файловой системы nfs при загрузке, вам необходимо отредактировать файл <tt>/etc/fstab</tt> как обычно это делается. Для нашего примера требуется такая строка: <code> # device mountpoint fs-type options dump fsckorder ... eris:/mn/eris/local /mnt nfs rsize=1024,wsize=1024 0 0 ... </code> <p>Это почти все, что необходимо. Читайте пожалуйста дальше. <sect1>Опции монтирования <p>Здесь перечислены некоторые опции, которые вы должны рассмотреть сразу, добавляя их в файл настроек. Они управляют способом, которым клиент NFS отрабатывает прекращение работы сервера или отключение сети. Одно из свойств NFS в том, что он может изящно обрабатывать эти неполадки, если вы правильно установите клиента. Существует два различающихся режима обработки ошибок: <descrip> <tag/soft/ NFS клиент будет сообщать об ошибке программе, которая пытается получить доступ к файлу расположенному на файловой системе, смонтированной через NFS. Некоторые программы довольно хорошо обрабатыают такого рода ошибки, но большинство программ не делают это. Я не рекомендую использование этой опции. <tag/hard/ Программа осуществляющая доступ к файлу на смонтированной по NFS файловой системе просто приостановит выполнение при разрыве связи с сервером. Процесс не может быть прерван или убит до тех пор, пока вы явно не укажите опцию <tt/intr/. Когда сервер NFS будет запущен заново, то программа продолжит безмятежно продолжать работу с прерванного места. Это скорее всего то, что вам нужно. Я рекомендую использовать опции <tt/hard,intr/ на всех файловых системах смонтированных через NFS. </descrip> <p>Продолжая предыдущий пример, теперь в нашем файле fstab запись будет выглядеть так: <code> # device mountpoint fs-type options dump fsckorder ... eris:/mn/eris/local /mnt nfs rsize=1024,wsize=1024,hard,intr 0 0 ... </code> <sect1>Оптимизация NFS<label id="optimizing"> <p>Обычно, если не заданы опции rsize и wsize, то NFS будет читать и писать блоками по 4096 или по 8192 байтов. Некоторые комбинации ядер Linux и сетевых карт не могут обрабатывать такие большие блоки, и это может быть неоптимально. Так что нам нужно поэкспериментировать и найти значения rsize и wsize, которые работают так быстр,о насколько это возможно. Вы можете протестировать скорость передачи при заданных опциях при помощи нескольких простых комманд. Выполнив вышеприведенную команду монтирования и получив доступ с правом записи на диск, вы можете выполнить тестирование производительности последовательной записи: <code> time dd if=/dev/zero of=/mnt/testfile bs=16k count=4096 </code> <p>Эта команда создает 64Mb файл, заполненный нулевыми значениями (этот файл должен быть достаточно большим, настолько большим, чтобы кэширование не сыграло значительную роль в производительности, используйте больший размер файла, если у вас достаточно много памяти). Проделайте эту операцию несколько раз (5-10?) и усредните полученные результаты. Полученная величина -- это время `прохода', т.е. величина наиболее интересующая нас в этом эксперименте. Затем вы можете измерить производительность чтения, прочитав файл обратно на свою машину: <code> time dd if=/mnt/testfile of=/dev/null bs=16k </code> выполните эту операцию несколько раз и усредните результат. Затем отмонтируйте файловую систему и примонтируйте ее заново, с увеличенными значениями rsize и wsize. Вероятно они должны быть кратными 1024, и не больше чем 16384 байтов, поскольку это максимальный размер блока данных в NFS версии 2. Прямо после монтирования с увеличенными значениями перейдите в смонтированную файловую систему и выполните команду подобную ls, исследуйте файловую систему, чтобы убедиться, что все в норме. Если значения rsize/wsize слишком большие, то симптомы <em/очень/ необычные и не на 100% очевидные. Типичный симптом выражается в неполном списке файлов при выполнении команды 'ls', и отсутствие сообщений об ошибках. Или чтение файлов загадочно срывается без сообщения об ошибке. После того, как вы установите, что заданные значения rsize/wsize работают, вы можете далее продолжать тестировать производительность. Различные серверные платформы вероятно имеют различные оптимальные размеры блоков. SunOS и Solaris по общему мнению, работают довольно быстрее при размере блока равном 4096 байт, чем при других значениях. <p>Новые ядра Linux (с версии 1.3) выполняют предваряющее чтение для значений rsize больших или равных размеру страницы машины. На процессорах Intel размер страницы равен 4096 байтам. Предваряющее чтение <em/значительно/ увеличивает производительность NFS при чтении. Так что на машинах с процессором Intel вы можете захотеть использовать значение rsize равное 4096 байтам. <p>Помните, что вам нужно отредактировать <tt>/etc/fstab</tt> для использования найденных значений rsize/wsize. <p>Прием для увеличения производительности NFS при записи заключается в запрещении синхронной записи на сервер. Спецификация NFS требует, чтобы запросы NFS на запись не считались законченными до записи данных на носитель (обычно диск). Это ограничивает производительность записи, а асинхронная запись значительно увеличит скорость записи по NFS. Демон nfsd для Linux никогда не делает синхронную запись, поскольку реализация файловой системы Linux сама не дает сделать это, но серверах работающих на отличных от Linux системах вы можете увеличить производительность этим способом, поместив в ваш файл exports: <code> /dir -async,access=linuxbox </code> <p>или что-то подобное. Пожалуйста посмотрите справочную страницу exports на данной машине. Также запомните, что это увеличивает риск потери данных. <sect>NFS через медленные линии<label id="slow-lines"> <p>Медленные линии включают в себя модемы, ISDN и другие соединения на дальние расстояния. <p>Этот раздел базируется на знании об используемых протоколах, а не на настоящих экспериментах. Мой домашний компьютер был выключен в течении 6 месяцев (плохой жесткий диск и отсутствие денег), так что у меня не было модемного соединения для тестирования. Пожалуйста дайте мне знать, если вы попробуете сделать это :-) <p>Первая вещь которую вы должны помнить, что NFS -- медленный протокол. Использование NFS в большинстве своем подобно использованию протокола kermit для переноса файлов. Это -- <em/медлено/. Почти все быстрее чем NFS. FTP быстрее. HTTP быстрее. rcp быстрее. ssh быстрее. <p>Вы все еще хотите попробовать его в работе? Ok. <p>Параметры по умолчанию для NFS установлены для довольно быстрых линий с малым временем запаздывания. Если вы будете использовать эти настройки для линий с высоким временем запаздывания, то это приведет к выдаче сообщений об ошибках, прерыванию операций, система может притворяться, что файлы короче, чем они есть на самом деле и странно работать в других случаях. <p>Первое, что вам необходимо сделать -- это <em/не/ использовать опцию монтирования <tt/soft/. Это вызовет возвращение программному обеспечению сигналов об ошибках при таймаутах. В основном обычное программное обеспечение не слишком хорошо обрабатывает такие ошибки. Это хороший способ получить странные сбои. Вместо этого используйте опцию монтирования <tt/hard/. Когда активна опция <tt/hard/, то таймауты вызывают бесконечные попытки возобновления вместо прерывания работы ваших программ. Это то, что вам действительно нужно. <p>Следующая вещь, которую нужно сделать -- это поэксперементировать с опциями монтирования timeo и retrans. Они описаны в справочной странице nfs(5), здесь приводится выдержка из нее: <code> timeo=n Величина в десятых долях секунды до посылки первой ретрансляции после таймаута RPC. По умолчанию эта величина равна 7 десятых секунды. После первого таймаута, время таймаута удваивается после каждого таймаута, пока не будет достигнута величина максимального таймаута равна 60 секундам, или произойдет достаточно ретрансляции, вызвав главный таймаут. Затем если файловая система смонтирована с опцией hard, то каждый новый таймаут каскадно запускается с начальным значением в два раза больше, чем при предыдущем каскаде, кроме того удваиваясь на каждой ретрансляции. Максимальный таймаут всегда равен 60 секундам. Наилучшая общая производительность может быть достигнута увеличением таймаута при монтировании на загруженной сети, к медленному серверу, или сквозь несколько маршрутизаторов. retrans=n Эта величина задает количество неосновных таймаутов и ретрансляций, которые должны произойти до возникновения главного таймаута. По умолчанию эта величина равна 3. Когда возникает главный таймаут, то файловые операции либо прерываются или на консоли печатается сообщение "server not responding". </code> <p>Другими словами: Если запрос не будет передан за таймаут равный 0.7 секунды (700ms), то клиент NFS повторит запрос и увеличит таймаут в два раза, до 1.4 секунды. Если ответ не придет в течении 1.4 секунды, то запрос повторится снова и таймаут будет увеличен до 2.8 секунды. <p>Скорость линии может быть измерена с помощью команды ping с размером пакета равным значению, установленому опциями rsize/wsize. <code> $ ping -s 8192 lugulbanda PING lugulbanda.uio.no (129.240.222.99): 8192 data bytes 8200 bytes from 129.240.222.99: icmp_seq=0 ttl=64 time=15.2 ms 8200 bytes from 129.240.222.99: icmp_seq=1 ttl=64 time=15.9 ms 8200 bytes from 129.240.222.99: icmp_seq=2 ttl=64 time=14.9 ms 8200 bytes from 129.240.222.99: icmp_seq=3 ttl=64 time=14.9 ms 8200 bytes from 129.240.222.99: icmp_seq=4 ttl=64 time=15.0 ms --- lugulbanda.uio.no ping statistics --- 5 packets transmitted, 5 packets received, 0% packet loss round-trip min/avg/max = 14.9/15.1/15.9 ms </code> <p>Здесь время показывает как долго пакет программы ping идет туда и обратно к машине lugulbanda. 15ms это довольно быстро. При работе через модем со скоростью 28.000 бод вы можете ожидать где-то 4000-5000ms, и если линия нагружена еще кем-то, то время будет даже выше, может быть раза в два. Когда это время высоко, мы говорим что это 'высокое запаздывание'. В общем для больших пакетов и для более загруженных линий запаздывание будет увеличиваться. Увеличьте timeo соответственно вашей линии и загрузке. И поскольку запаздывание увеличивается когда вы используете линию для других вещей: даже если вы хотите использовать FTP и NFS в одно и тоже время, то вы должны попытаться измерить время ping во время использования FTP для передачи файлов. <sect>Безопасность и NFS<label id="nfs-security"> <p>Я ни коим образом не являюсь экспертом в области компьютерной безопасности. Но у меня есть <em/маленький/ совет для сознающих проблему безопасность. Но будьте предупреждены: этот список ни в коем случае не является полным списком проблем относящихся к NFS, и если вы думаете, что вы обезопасились один раз прочитав и выполнив, все что я даю здесь, то я хочу предупредить вас. <p>Этот раздел не должен беспокоить вас, если вы находитесь в <em/закрытой/ сети, где вы доверяете всем пользователям, и никто из тех кому вы не доверяете ни может получить доступ к машинам в сети. Например, не должно быть dial-соединения в сеть, и не должно быть никакого способа подключиться к сети, в которой вы есть люди, которым вы не доверяете. Вы думаете я параноик? Я не параноик. Это базовый совет по безопасности. <em/Безопасность/ требует наличия тщательного и знающего администратора, который знает где найти информацию о текущих и потенциальных проблемах безопасности. <p>Основная проблема NFS в том, что клиент, если не задано, будет доверять серверу и наоборот. Это может быть плохо. Это значит, что если запись администратора сервера NFS взломана, то также легко может быть взломана запись администратора клиентской машины. И наоборот. Существует набор полицейских стратегий для этого, мы к ним еще вернемся. <p>Что вам необходимо прочитать -- это консультационные материалы CERT относящиеся к NFS. Большинство текстов приведенных ниже, связаны с советами, написанными в выпусках CERT. Смотрите <htmlurl url="ftp://ftp.cert.org/01-README" name="ftp.cert.org/01-README"> для обновленного списка консультативных материалов CERT. Здесь приведены некоторые относящиеся к NFS консультативные материалы: <code> CA-91:21.SunOS.NFS.Jumbo.and.fsirand 12/06/91 Уязвимость в отношении сетевой файловой системы (NFS) Sun Microsystems, Inc. (Sun) и программы fsirand. Эта уязвимость возможна в версиях SunOS 4.1.1, 4.1, and 4.0.3 на всех архитектурах. Заплатки (Patches) доступны для SunOS 4.1.1. Также доступна начальная заплатка для SunOS 4.1 NFS. Sun будет обеспечит полные заплатки для SunOS 4.1 и SunOS 4.0.3 позже. CA-94:15.NFS.Vulnerabilities 12/19/94 Этот консультационный материал обеспечивает измерение безопасности для охраны против против некоторых дыр в безопасности в сетевой файловой системе (NFS). Этот материал выпущен в связи с увеличением случаев взлома машин, используя утилиты для взлома через уязвимые точки. CA-96.08.pcnfsd 04/18/96 Этот материал описывает проблемы с безопасностью в программе pcnfsd (также известной как rpc.pcnfsd). Заплатка для исправления ошибки прилагается. </code> <sect1>Безопасность клиента <p>На клиентской стороне мы можем решить, что мы не хотим слишком сильно доверять серверу. Это делается несколькими способами, используя опции монтирования. Например, мы можем запретить выполнение программ с установленным битом suid в файловой системе NFS, это делается опцией монтирования <tt/nosuid/. Это хорошая идея и вы должны рассмотреть ее, используя смонтированные через NFS файловые системы. Это означает, что администратор сервера не сможет сделать программы с установленным suid-администратора на файловой системе, затем войти на машину клиента как обычный пользователь и используя программу с suid-администратора приобрести также права администратора на машине клиента. Мы также можем запретить выполнение файлов на смонтированной файловой системе с помощью опции <tt/noexec/. Но она применяется реже по сравнению с опцией <tt/nosuid/, поскольку файловая система может содержать по крайней мере <em/некоторые/ скрипты, или программы, которые необходимо выполнять. Вы можете ввести эти опции в колонке опций вместе с опциями <tt/rsize/ и <tt/wsize/, разделяя их запятыми. <sect1>Безопасность сервера: nfsd <p>На стотоне сервера мы можем решить, что мы не хотим доверять администратору клиента. Мы можем сделать это указав опцию root_squash в файле exports: <code> /mn/eris/local apollon(rw,root_squash) </code> <p>Теперь, если пользователь с UID 0 на стороне клиента попытается получить доступ (чтение, запись, удаление), то файловый сервер выполнит подстановку UID пользователя `nobody' на сервере. Это означает, что администратор клиента не сможет получить доступ или изменять файлы, которые может изменять или иметь доступ к которым может только администратор сервера. Это хорошо и вы должны использовать опцию <tt/root_squash/ на всех экспортируемых файловых системах. Вы скажете, что "Администратор клиента все равно может выполняить команду 'su', чтобы зайти как любой другой пользователь и получить доступ и изменить любые пользовательские файлы". На это есть ответ: "Да есть такой способ, и это работает в Unix и NFS. Это имеет одно важное заключение: Все важные файлы и программы должны иметь владельцем пользователя <tt/root/, а не пользователя <tt/bin/ или другого пользователя не-администратора, поскольку только администратор клиента не может получить доступ как администратор сервера. С справочной странице NFSd есть несколько других подобных опций, так что вы можете решить, что вы (не) доверяете кому-либо со стороны клиента. У вас также имеются опции для осечения любых диапазонов UID и GID. Это описывается в справочной странице Linux NFSd. <p>Опция root_squash является установленной по умолчанию для NFSd в Linux, для передачи администраторских полномочий для доступа к файловой системе используйте опцию <tt/no_root_squash/. <p>Другая важная вещь, которую необходимо сделать, это проверить, что nfsd проверяет, все ли запросы приходят с привелигированного порта. Если он принимает запросы с любого старого порта на клиенте, то пользователь без специальных привелегий может запустить программу, которую легко получить по Internet. Он умеет "говорить" на языке протокола nfs и будет притворяться, что пользователь является любым пользователем, которым он хочет быть. NFSD на Linux делает эту проверку по умолчанию, но для других операционных систем вы должны разрешить эту проверку сами. Это должно быть описано в справочной странице nfsd для вашей операционной системы. <p>Другая вещь. Никогда не экспортируйте файловую систему для машины с именем 'localhost' или 127.0.0.1. Доверяйте мне. <sect1>Безопасность сервера: portmapper <p>Основа portmapper, в соединении с nfsd имеет проблему в проектировании, которая делает возможной получить файлы с серверов NFS без каких-либо привелегий. К счастью portmapper под Linux использует относительную безопасность против такой атаки, и может быть сделано более безопасной настройкой списка доступа в двух файлах. <p>Сначала мы отредактируем файл <tt>/etc/hosts.deny</tt>. Он должен содержать строку <code> portmap: ALL </code> которая запретит доступ <em/всем/. Это может быть слишком кардинальным, поэтому мы снова откроем доступ, отредактировав файл <tt>/etc/hosts.allow</tt>. Но сначала нам надо определить, что мы туда поместим. В этом файле перечисляются все машины, которые могут получить доступ к вашему portmapper. Среди множества работающих под Linux систем только некоторым машинам нужен полный доступ для любой работы. Portmapper обслуживает nfsd, mountd, ypbind/ypserv, pcnfsd, и 'r' сервисы, такие как ruptime и rusers. Из них только nfsd, mountd, ypbind/ypserv и возможно pcnfsd имеют какое-либо важное значение. Всем машинам, которым необходим доступ к сервисам на вашей машине должно быть разрешено делать это. Скажем адрес машины равен 129.240.223.254 и она находится в подсети 129.240.223.0, и ей нужен доступ к сервисам на вашей машине (эти термины введены HOWTO по сетям, вернитесь к нему и освежите свои знания, если это необходимо). Для этого мы напишем в файле <tt/hosts.allow/ <code> portmap: 129.240.223.0/255.255.255.0 </code> Это тоже самое, что и сетевой адрес, который вы даете командой route и маска подсети, которую вы передаете команде ifconfig. Для устройства <tt/eth0/ на этой машине <tt/ifconfig/ должен показывать <code> ... eth0 Link encap:10Mbps Ethernet HWaddr 00:60:8C:96:D5:56 inet addr:129.240.223.254 Bcast:129.240.223.255 Mask:255.255.255.0 UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:360315 errors:0 dropped:0 overruns:0 TX packets:179274 errors:0 dropped:0 overruns:0 Interrupt:10 Base address:0x320 ... </code> а программа <tt/netstat -rn/ должна показывать <code> Kernel routing table Destination Gateway Genmask Flags Metric Ref Use Iface ... 129.240.223.0 0.0.0.0 255.255.255.0 U 0 0 174412 eth0 ... </code> (Сетевой адрес находится в первой колонке). Файлы <tt/hosts.deny/ и <tt/hosts.allow/ описаны в справочных страницах с теми же именами. <p><bf/ВАЖНО:/ <em/Не/ помещайте в этих файлах <em/ничего/, кроме <em/IP НОМЕРОВ/ в строках для настройки portmap. Поиск имен машин может вызвать активность portmap, которая вызовет поиск имен машин, которое вызовет portmap, которое вызовет... <p>Вышеприведенные вещи должны вызвать переключение вашего сервера. Остающаяся проблема в том, что кто-то взломает администратора (или загрузит MS-DOS) на машине, которой доверяют и использует эти привелегии для посылки запросов на безопасный порт, как любой пользователь, которым он захочет быть. <sect1>NFS и firewall<label id="security-firewalls"> <p>Очень хорошая идея защитить порты nfs и portmap с помощью firewall на вашем маршрутизаторе. Nfsd работает на порту 2049, используя оба протокола -- udp и tcp. Portmapper работает на порту 111, tcp и udp, а mountd работает на портах 745 и 747, tcp и udp. По умолчанию. Вы должны проверить номера используемых портов, используя команду <tt/rpcinfo -p/. <p>Если вы хотите использовать NFS сквозь firewall, то есть опции для новых версий NFSd и mountd, для того, чтобы заставить их использовать нестандартные порты, которые могут быть открыты в firewall. <sect1>Резюме<label id="security-summary"> <p>Если вы используете hosts.allow/deny, root_squash, nosuid и привилегированные порты в программном обеспечении portmapper/nfs, то вы можете избежать известных ошибок в nfs и можете чувствовать себя почти в безопасности. Но все равно: когда взломщик имеет доступ к вашей сети, то он/она может добавить странные команды в ваш файл <tt/.forward/ или почтовый ящик, когда <tt>/home</tt> или <tt>/var/spool/mail</tt> смонтирован через NFS. По той же причине, вы никогда не должны осуществлять доступ к вашим личным ключам PGP через nfs. Или по крайней мере вы должны знать какой риск существует. И знать о нем хотя бы немного. <p>NFS и portmapper создают комплексную систему и поэтому не полностью невероятно,что новые ошибки будут найдены, либо в основе проекта, либо в реализации, которую мы используем. Также могут быть известные дыры, которые кто-нибудь использует. Но такова жизнь. Чтобы быть в курсе таких вещей, вы должны как минимум читать группы новостей <htmlurl url="news:comp.os.linux.announce" name="comp.os.linux.announce"> и <htmlurl url="news:comp.security.announce" name="comp.security.announce">. <sect>Контрольный список разрешения проблем монтирования <p>Это раздел основан на контрольном списке проблем монтирования, этот документ написан в IBM Corp. Я благодарен им за то, что они сделали его доступным для использования в этом документе. Если у вас есть проблема с монтированием файловой системы через NFS, то пожалуйста проверьте это список, до того как вы пошлете сообщение об ошибке. Каждый пункт описывает конкретную проблему и ее решение. <enum> <item>Файловая система не экспортируется, или не экспортируется при запросе клиента. <p><bf/Исправление:/ Экспортируйте ее <item>Система разрешения имен не выдает соответствия со списком машин в файле exports. <p>Например: список экспортируемых ресурсов задает экспортирование <tt/johnmad/, но имя <tt/johnmad/ разрешается как <tt/johnmad.austin.ibm.com/ и монтирование запрещается. <p><bf/Исправление:/ Экспортируйте ресурс для обоих форм имени машины. <p>Это также случается, если клиент имеет 2 интерфейса с разными имена для каждого из них и файловая система экспортируется только для одного указанного имени. <p><bf/Исправление:/ Экспортируйте оба интерфейса. <p>Это также может произойти, если сервер не может выполнить функции lookuphostbyname или lookuphostbyaddr (это библиотечные функции) на клиенте. Убедитесь, что клиент может выполнять команды <tt/host <name>/; <tt/host <ip_addr>/; и обе они указывают на одну и ту же машину. <p><bf/Исправление:/ наладьте систему разрешения имен. <item>Файловая система была смонтирована, после того как NFS был запущен (на том сервере). В таком случае сервер экспортирует саму точку монтирования, а не смонтированную файловую систему. <p><bf/Исправление:/ Завершите NFSd и затем перезапустите его. <p><bf/Заметчание:/ Клиенты, которые уже были примонтированы к точке монтирования файловой системы будут иметь проблемы с доступом к ней после перезапуска сервера. <item>Дата наобум изменяется на одной или обоих машинах (это может спутать make). <p><bf/Исправление:/ Установите правильную дату. <p>Автор HOWTO рекомендует использовать NTP для синхронизации часов. Поскольку существуют экспортные ограничения на NTP в US, то вы можете получить NTP для debian, redhat или slackware с ftp://ftp.hacktic.nl/pub/replay/pub/linux или с сервера-зеркала. <item>Сервер не допускает монтирования от пользователя, который находится больше чем в 8 группах. <p><bf/Исправление:/ уменьшите количество групп в которые входит пользователь или смонтируйте под именем другого пользователя. </enum> <sect>Часто Задаваемые Вопросы (FAQ) <p>Это раздел часто задаваемых вопросов (FAQ). Большая часть его написана Alan Cox. <enum> <item>Я получаю сообщения об ошибках 'stale nfs handle (устарелый дескриптор nfs)' при использовании Linux как сервера nfs. <p>Это вызывается ошибкой в одной из устаревших версий nfsd. Это исправлено в nfs-server2.2beta16 и более поздних. <item>Когда я пытаюсь примонтировать файловую систему я получаю сообщение <tscreen><verb> can't register with portmap: system error on send (не могу зарегистрироваться с помощью portmap: системная ошибка при посылке) </verb></tscreen> <p>Вы вероятно используете систему Caldera. Это ошибка в скриптах rc. Пожалуйста свяжитесь с Caldera для получения исправления. <item>Почему я не могу выполнить файл после копирования его на NFS сервер? <p>Причина в том, что nfsd кэширует дескрипторы открытых файлов для улучшения производительности (помните, что он запущен в пространстве пользователей). Пока nfsd держит файл открытым (как в этом случае, после записи в него), то ядро не позволит вам выполнять его. Nfsds новее чем версии выпуска весны 95 держат файлы открытыми в течении нескольких секунд, более старые могут держать файл открытым в течении нескольких дней. <item>Мои файлы на NFS все считаются с правом только на чтение <p>По умолчанию сервер NFS для Linux выдается все как только для чтения. Перечитайте справочные страницы по ``exports'' и nfsd. Вам необходимо изменить файл <tt>/etc/exports</tt>. <item>Я монтирую файловую систему с сервера nfs под linux и пока работает команда ls я не могу читать или записывать файлы. <p>На старых версиях Linux вы должны монтировать сервер NFS с опциями <tt/rsize=1024,wsize=1024/. <item>Я монтирую файловую систему с сервера NFS под Linux с размером блока между 3500-4000 и это регулярно роняет машину с Linux <p>Обычно не делайте так. <item>Может Linux выполнять NFS по TCP <p>Нет <item>Я получаю странные ошибки при монтировании машины с машины под Linux. <p>Убедитесь, что ваш пользователь находится в 8 или меньшем количестве групп. Старые сервера требую этого. <item>Когда я перезагружаю свою машину она иногда вешается при попытке отмонтироваться от зависшего сервера NFS. <p><bf/Не/ отмонтируйтесь от серверов NFS при перезагрузке или выключении, просто проигнорируйте это, ничто не повредится, если вы не отмонтируетесь от него. Команда будет выглядеть следующим образом <tt/umount -avt nonfs/. <item>Клиент NFS для Linux работает очень медлено при записи на системы Sun и BSD. <p>Обычно NFS записывает в синхронном режиме (вы можете запретить это, если вы считаете, что вы не рискуете потерять данные). Хуже всего то, что ядра произошедшие от BSD не могут работать с маленькими блоками. Таким образом когда вы пишете 4K данных с машины под Linux в 1K пакетах, то BSD выполняет это следующим образом <tscreen><verb> прочитать страницу размером 4K изменить 1K записать страницу размером 4K обратно на диск прочитать страницу размером 4K изменить 1K записать страницу размером 4K обратно на диск и т.д... </verb></tscreen> </enum> <sect>Экспортирование файловых систем <p>Способ экспортирования файловых систем с помощью NFS не является полностью совместимым между платформами. В этом случае отличаются Linux и Solaris 2. Этот раздел поверхностно перечисляет способы как выполнить эту операцию на большинстве систем. Если ваша система не была перечислена здесь, то посмотрите справочные страницы по вашей операционной системе. Ключевые слова следующие: nfsd, system administration tool (утилиты системного администрирования), rc scripts, boot scripts, boot sequence, /etc/exports, exportfs. Я буду использовать один пример для всего раздела: как экспортировать файловую систему /mn/eris/local для машины apollon с правами на чтение/запись. <sect1>IRIX, HP-UX, Digital-UNIX, Ultrix, SunOS 4 (Solaris 1), AIX <p>Эти операционные системы используют традиционный формат Sun для экспортирования. В файле <tt>/etc/exports</tt> напишите: <code> /mn/eris/local -rw=apollon </code> Полная документация находится в справочной странице <tt/exports/. После редактирования файла запустите <tt/exportfs -av/ для экспортирования файловых систем. <p>Точный синтаксис команды exportfs различается. В некоторых операционных системах вы можете обнаружить, что введенные строки читаются как: <code> /mn/eris/local apollon </code> или даже вот так: <code> /mn/eris/local rw=apollon </code> Я рекомендую быть формальным. Вы рискуете, если следующая версия <tt/exportfs/ будет другая и тогда все внезапно перестанет работать. <sect1>Solaris 2 <p>Sun полностью переизобрел колесо при разработке Solaris 2. Так что он полностью отличается от других операционных систем. То, что вам нужно сделать -- это отредактировать файл <tt>/etc/dfs/dfstab</tt>. В нем вы должны поместить команды организации доступа так, как это описано в справочной странице share(1M). Примерно вот такие строки: <code> share -o rw=apollon -d "Eris Local" /mn/eris/local </code> После редактирования запустите программу <tt/shareall/ для экспортирования файловой системы. <sect>PC-NFS <p>Вы не должны запускать PC-NFS. Вы должны запустить samba. <p>Извинение: Я ничего не знаю о PC-NFS. Если кто-нибудь может написать о нем, то пожалуйста сделайте это и я включу материал здесь. </article>