Форум программистов, компьютерный форум, киберфорум
Debian, Kali Linux, Raspbian, Astra Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.52/29: Рейтинг темы: голосов - 29, средняя оценка - 4.52
0 / 0 / 0
Регистрация: 29.09.2012
Сообщений: 10

Производственный файловый сервер

29.09.2012, 22:56. Показов 6070. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер. Поставили задачу поднять файловый сервер на предприятии, так как уже имеется один сервер со squid и dhcp который раздает IP по мак адресу. Так вот хотелось бы сделать так, поднять файловый сервер на отдельном компьютере, создать отдельные папки к примеру бухгалтерия, расчетный отдел и т.д и сделать к ним доступ по мак адресам чтоб никто кроме того кому разрешено не смог залезть в папку и прочитать документы. С помощью каких программ посоветуете это сделать?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.09.2012, 22:56
Ответы с готовыми решениями:

Файловый сервер некоторые помехи
Стоял сервер на Linux. Через команду uname -a проверил, выдало Linux serv1 2.6.32-5-686 в инете посмотрел написано Debian, но это мы...

Нужен антивирус и для почтовый сервер и для файловый сервер, скажите пожалуйста какой лучшее установить
Нужен антивирус и для почтовый сервер и для файловый сервер, скажите пожалуйста какой лучшее установить.. Касперский нашел они для одного...

Файловый сервер
Всем привет! Посоветуйте конфигурацию для сервера. Использоваться будет только как файлсервер. Количество пользователей: 25 человек,...

14
Псевдослучайный
1946 / 1146 / 98
Регистрация: 13.09.2011
Сообщений: 3,215
29.09.2012, 23:33
Просто ftp с разными учётками не катит?
0
0 / 0 / 0
Регистрация: 29.09.2012
Сообщений: 10
30.09.2012, 00:58  [ТС]
просто не хочется создавать пользователей, потом бегать по заводу объяснять как пользоваться, хочется сделать попроще для себя, так как уже списаны мас адреса с компьютеров, и я знаю у какого компьютера какой ip.
0
Эксперт по компьютерным сетямЭксперт NIX
 Аватар для Dmitry
13441 / 7534 / 831
Регистрация: 09.09.2009
Сообщений: 29,554
30.09.2012, 10:01
Цитата Сообщение от mr4ester Посмотреть сообщение
С помощью каких программ посоветуете это сделать?
samba
0
310 / 233 / 15
Регистрация: 01.07.2011
Сообщений: 812
Записей в блоге: 1
30.09.2012, 22:40
Dmitry как бы уже сказал, дополню: нужно установить программу - самба-сервер и настроить ее.
В Debian конфиг находится на /etc/samba/smb.conf
samba на википедии
установка:
Bash
1
sudo apt-get install samba
сайт все о samba - про настройку, конфиги там и проч.
1
0 / 0 / 0
Регистрация: 29.09.2012
Сообщений: 10
30.09.2012, 22:42  [ТС]
благодарю за ссылку, очень полезная!
0
310 / 233 / 15
Регистрация: 01.07.2011
Сообщений: 812
Записей в блоге: 1
30.09.2012, 22:46
mr4ester, на здоровье
на Debian samba очень хорошо работает, аптайм годами и не единого разрыва, можно поднять на железе времен молодости вашего дедушки.
0
0 / 0 / 0
Регистрация: 29.09.2012
Сообщений: 10
01.10.2012, 21:48  [ТС]
сегодня обговаривал с начальником на чем с помощью чего делать локальный сервер и принцип доступа к папкам, то есть через логин и пароль, он задался вопросом а что если пользователи дадут друг другу свои логин и пароль и будут так же лазить в тех папках которых им не положено?, ну и назрел вопрос, можно ли как то дополнительно к примеру привязать логин к ip адресу, или мас?
0
01.10.2012, 22:41

Не по теме:

что ip-адрес, что mac-адрес можно легко настраивать вручную (это информация, которая открыта и при малейшем желании становится известна).
продолжайте с начальником думать дальше...

0
0 / 0 / 0
Регистрация: 29.09.2012
Сообщений: 10
01.10.2012, 23:38  [ТС]
дык а кто знает что у нас учетки привязаны к маку или ip. Пару раз попробуют, не получится и перестанут.

Добавлено через 55 минут
Dmitry, может вы можете предложить какую либо идею?
0
310 / 233 / 15
Регистрация: 01.07.2011
Сообщений: 812
Записей в блоге: 1
02.10.2012, 09:56
Цитата Сообщение от mr4ester Посмотреть сообщение
а что если пользователи дадут друг другу свои логин и пароль и будут так же лазить в тех папках которых им не положено?
это вопрос не к аппаратно-программным средствам, а к организационно-административным.
для общего пользования обычно выделяется общий раздел share, вот в него все что "не личное" пусть и кидают.
Потом пишется инструкция под ознакомление с подписями сотрудников, в которой в том числе упоминается, что мол "пользоваться данными размещенными под чужой учетной записью запрещено". Одного без премии оставить разок - остальные сразу все поймут.
Важно вот что - резервное копирование (на случай ядерной войны):
На сервачок ставится отдельный диск (резерв), монтируется к системе, но по samba не расшаривается. На него будут копироваться изменения, произведенные за день. Обязательно сделайте это. Утилита:
rsync
Прочитайте
man rsync
rsync(1) rsync(1)



НАЗВАНИЕ
rsync - более быстрая и гибкая замена rcp

СИНТАКСИС
rsync [OPTION]... SRC [SRC]... [USER@]HOST:DEST

rsync [OPTION]... [USER@]HOST:SRC DEST

rsync [OPTION]... SRC [SRC]... DEST

rsync [OPTION]... [USER@]HOST::SRC [DEST]

rsync [OPTION]... SRC [SRC]... [USER@]HOST::DEST

rsync [OPTION]... rsync://[USER@]HOST[:PORT]/SRC [DEST]

ОПИСАНИЕ
Утилита rsync ведет себя во многом подобно rcp с той разницей, что
имеет гораздо больше параметров и использует протокол удаленного
обновления (remote-update protocol) для значительного ускорения
передачи файлов, которые уже существуют в месте назначения.

Благодаря этому протоколу rsync передает только различия между двумя
наборами файлов через сетевое соединение, используя эффективный
алгоритм поиска контрольных сумм (cheksum-search algorithm), описанный
в сопровождающей этот пакет документации.

Вот некоторые дополнительные особенности rsync:

o поддержка копирования ссылок, файлов устройств, атрибутов
владельца, группы и прав

o параметры исключения путей exclude и exclude-from подобно GNU
tar

o CVS-подобный режим исключения для определенных файлов, которые
игнорируются тем же образом, каким их должен игнорировать CVS

o может прозрачно использовать любую оболочку удаленного доступа,
включая rsh или ssh

o не нуждается в привилегиях суперпользователя root

o конвейеризация передач файлов для уменьшения задержек

o поддержка анонимного сервера rsync или сервера rsync с
аутентификацией (идеально для зеркалирования)

ГЛАВНОЕ
Относительно rsync существует восемь способов его использования:

o Для локального копирования файлов, когда ни исходный SRC, ни
конечный DEST пути не содержат двоеточия : .

o Для копирования локальных файлов на удаленный хост, используя
программу удаленной оболочки в качестве транспорта (например,
rsh или ssh). В этом случае конечный путь DEST содержит одно
двоеточие : как разделитель адреса удаленного хоста и пути
файловой системы на нем.

o Для копирования с удаленного хоста в локальные файлы, используя
программу удаленной оболочки. Это происходит, если исходный
путь SRC содержит двоеточие : .

o Для копирования с удаленного rsync-сервера в локальные файлы,
когда исходный путь SRC содержит либо двойное двоеточие :: ,
либо он сформирован в виде URL, начинающийся с rsync:// .

o Для копирования локальных файлов на удаленный rsync-сервер. В
этом случае конечный путь DEST содержит :: или является URL'ом
вида rsync:// .

o Для копирования с удаленной машины с использованием удаленной
оболочки как транспорта и удаленного rsync-сервера. Это
происходит, когда исходный путь SRC содержит разделителем
двойное двоеточие :: и установлен параметр --rsh=COMMAND (или -e
"COMMAND").

o Для копирования с локальной машины на удаленную с использованием
удаленной оболочки как транспорта и удаленного rsync-сервера.
Это происходит, когда конечный путь DEST содержит разделителем
двойное двоеточие :: и установлен параметр --rsh=COMMAND (или -e
"COMMAND").

o Для получения списка файлов на удаленной машине. Это
происходит, если не указать (оставить пустым) локальный путь.

Обратите внимание, что во всех случаях (кроме запроса списка) как
минимум один путь (либо исходный SRC, либо конечный DEST) должен быть
локальным.

УСТАНОВКА
За инструкциями по установке обращайтесь в файл README.

Для удаленных передач rsync использует ssh для выполнения коммуникаций
с удаленными хостами, поэтому сразу после установки Вы можете
использовать rsync относительно любой машины, к которой возможен доступ
через ssh (также как и к тем, где запущен rsync-сервер). Но можно
сконфигурировать использование другой оболочки, например, rsh или
remsh.

Вы можете указать альтернативу rsh либо с помощью параметра командной
строки -e, либо с помощью переменной окружения RSYNC_RSH.

Обратите внимание, что rsync должна быть установлена на обоих хостах,
которые вовлечены в операцию копирования.

ИСПОЛЬЗОВАНИЕ
Применение rsync подобно rcp. Вы должны указать исходный путь и
конечный путь назначения, один из которых может быть на удаленном
хосте.

Возможно, лучший способ объяснить синтаксис - это привести примеры:

rsync *.c foo:src/

Копирует все файлы по шаблону *.c из текущего каталога в каталог src ,
расположенный на машине foo . Если какой-либо из файлов уже
существует, rsync использует протокол удаленного обновления для
передачи только различий. За деталями протокола обращайтесь к
соответствующей документации.

rsync -avz foo:src/bar /data/tmp

Копирует все файлы рекурсивно из каталога src/bar с машины foo в
локальный каталог /data/tmp/bar . Передача файлов происходит в
"архивном" режиме, который гарантирует сохранение символьных ссылок,
файлов-устройств, атрибутов, разрешений и т.д. Кроме того,
используется сжатие для уменьшения объема непосредственно передаваемых
данных.

rsync -avz foo:src/bar/ /data/tmp

Слэш в окончании исходного пути меняет поведение при копировании так,
что все файлы копируются в каталог /data/tmp без создания
дополнительного уровня вложения каталогов. Завершающий исходный путь
слэш означает "копировать содержимое этого каталога". Без завершающего
слэша - "копировать каталог". В обоих случаях (со слэшем и без него)
атрибуты содержащего файлы каталога копируются на содержащий их копии
каталог назначения. Другими словами, в каждом последующем примере
команды копируют файлы одинаково, включая атрибуты /dest/foo :

rsync -avz /src/foo /dest
rsync -avz /src/foo/ /dest/foo

Вы также можете использовать rsync в режиме только локального
копирования, когда ни один из путей НЕ содержит двоеточия : . Тогда
rsync ведет себя как улучшенная команда копирования.

rsync somehost.mydomain.com::

Запрашивает весь список анонимно-доступных модулей на машине some‐
host.mydomain.com. (Смотрите следующую секцию на предмет деталей.)

ПОДКЛЮЧЕНИЕ К RSYNC-СЕРВЕРУ
rsync можно использовать без обращения к удаленной оболочке как
транспорту. В этом случае Вы будете подключаться к удаленному
rsync-серверу, запущенному на 873 порту TCP.

Вы можете осуществлять соединение через web-прокси, устанавливая
переменную окружения RSYNC_PROXY, равной паре hostname:port,
соответствующей Вашему web-прокси. В этом случае Ваш web-прокси должен
разрешать проксирование 873 порта.

Использование rsync-сервера аналогично варианту с удаленной оболочкой
за исключением:

o Вы используете двойное двоеточие :: , а не одинарное, как
разделитель имени хоста и пути.

o удаленный сервер может выводить сообщение дня (motd), когда Вы
подсоединяетесь.

o если Вы опускаете указание пути на удаленном сервере, то он
показывает список доступных путей.

o если Вы опускаете локальный путь копирования, то Вам
предоставляется список указанных файлов на удаленном сервере.

Некоторые пути на удаленном сервере могут быть доступными только по
аутентификации. Тогда вы получите приглашение ввести пароль при
подключении. Можно избежать запроса пароля, предварительно выставив
переменную RSYNC_PASSWORD в значение с необходимым паролем или указав
параметр в командной строке --password-file . Это удобно при
использовании rsync в скриптах.

ВНИМАНИЕ: На некоторых системах переменные окружения видимы всеми
пользователями. На таких системах рекомендуется использовать --pass‐
word-file .

ПОДКЛЮЧЕНИЕ К RSYNC-СЕРВЕРУ ЧЕРЕЗ УДАЛЕННУЮ ОБОЛОЧКУ
Иногда бывает полезно при подключении к rsync-серверу передавать файлы,
используя удаленную оболочку как транспорт. Это особенно полезно, если
нужно подключиться к удаленной машине через ssh (для шифрации или в
обход сетевого экрана), но при этом сохранить доступ к функциональным
особенностям rsync-сервера (см. ЗАПУСК RSYNC-СЕРВЕРА ПОВЕРХ УДАЛЕННОЙ
ОБОЛОЧКИ).

С пользовательской точки зрения этот способ такой же, как и подключение
к rsync-серверу, за исключением того, что необходимо явно указать
программу удаленной оболочки в командной строке параметром --rsh=COM‐
MAND. (Установка RSYNC_RSH в окружении не активизирует эту
функциональность.)

В порядке необходимости различать пользователя удаленной оболочки и
пользователя удаленного rsync-сервера Вы можете использовать '-l user'
в указании программы оболочки:

rsync -av --rsh="ssh -l ssh-user" rsync-user@host::module[/path]
local-path

Здесь "ssh-user" имеет значение на уровне ssh; "rsync-user" проверяется
относительно rsyncd.conf на удаленной стороне.

ЗАПУСК RSYNC СЕРВЕРА
rsync-сервер конфигурируется с помощью специального файла, которым по
умолчанию выбирается /etc/rsyncd.conf, кроме тех случаев, когда rsync
запускается поверх удаленной оболочки и не от root. В этом случае
выбирается rsyncd.conf из текущего каталога на удаленной машине (обычно
$HOME). Смотрите страницы руководства по rsyncd.conf(5) на предмет
деталей.

ЗАПУСК RSYNC-СЕРВЕРА ПОВЕРХ УДАЛЕННОЙ ОБОЛОЧКИ
Некоторые конфигурационные параметры не будут доступны, если удаленный
пользователь не root (chroot, setuid/setgid и т.д.). Нет необходимости
в конфигурировании inetd или включении порта rsync-сервера в список
доступных сетевых служб, если rsync-сервер запущен только через
программу удаленной оболочки.

Для запуска rsync-сервера с ssh-ключом ограниченного применения см.
соответствующий раздел rsyncd.conf(5).

ПРИМЕРЫ
Далее приведено несколько примеров, как использовать rsync.

Для резервного архивирования домашнего каталога моей жены, который
содержит большие MS Word файлы и почтовые папки, я использую задание
для cron'а, которое запускается

rsync -Cavz . arvidsjaur:backup

каждую ночь через PPP-соединение для дублирования каталога на мою
машину "arvidsjaur".

Для синхронизации моего дерева samba-исходников я использую Make‐
file-указания:

get:
rsync -avuzb --exclude '*~' samba:samba/ .

put:
rsync -Cavuzb . samba:samba/

sync: get put

Это позволяет мне синхронизировать с CVS-каталогом на другом конце
соединения. Затем я осуществляю cvs-операции на удаленной машине, что
сохраняет мне массу времени, т.к. передача по удаленному cvs-протоколу
не очень эффективна.

Я зеркалирую каталог между моими "старым" и "новым" ftp-сайтами
командой

rsync -az -e ssh --delete ~ftp/pub/samba/ nim‐
bus:"~ftp/pub/tridge/samba"

это запускается cron'ом несколько раз в день.

СВОДКА ПАРАМЕТРОВ
Далее краткий обзор параметров, понимаемых rsync. Пожалуйста,
обращайтесь к более детальному описанию чуть ниже.

-v, --verbose увеличить уровень подробностей

-q, --quiet уменьшить уровень подробностей

-c, --checksum проверять контрольные суммы

-a, --archive архивный режим, эквивалент для -rlptgoD

-r, --recursive рекурсивно входить в подкаталоги

--no-recursive отключить действие --recursive

--no-implied-dirs не передавать затрагиваемые параметром -R
каталоги

-R, --relative использовать относительные пути

-b, --backup создавать резервную копию (см. --suffix и
--backup-dir)

--backup-dir создавать резервную копию в этом каталоге

--suffix=SUFFIX суффикс для резервной копии (по умолчанию ~ в
отсутствие --backup-dir)

-u, --update только обновление (не переписывает более
новые файлы)

-l, --links копировать символьные ссылки как символьные
ссылки

-L, --copy-links копировать то, на что ссылаются символьные
ссылки

--copy-unsafe-links копировать ccылки за пределы исходного дерева
каталогов

--safe-links не копировать любые символьные ссылки,
которые ссылаются за пределы дерева каталогов
назначения

-H, --hard-links сохранять жесткие ссылки

-p, --perms сохранять разрешения

-o, --owner сохранять владельца (только root)

-g, --group сохранять группу

-D, --devices сохранять файлы устройств (только root)

-t, --times сохранять время

-S, --sparse эффективно обработать фрагментированные файлы

-n, --dry-run показать, что скопируется

-W, --whole-file копировать весь файл без rsync-алгоритма

--no-whole-file отключить --whole-file

-x, --one-file-system не выходить за пределы файловой системы

-B, --block-size=SIZE размер блока контрольных сумм (по умолчанию
700)

-e, --rsh=COMMAND указывает замену программу удаленной оболочки

--rsync-path=PATH указывает путь к rsync на удаленной машине

--existing только обновить те файлы, которые уже
существуют

--ignore-existing пропускать те файлы, которые уже существуют
на приемной стороне

--delete удалять файлы, которых нет на передающей
стороне

--delete-excluded также удалять те файлы, которые исключены из
списка копирования

--delete-after удалять после копирования, а не до него

--ignore-errors удалить даже при наличии ошибок ввода/вывода

--max-delete=NUM не удалять больше, чем NUM файлов

--partial сохранять частично переданные файлы

--force принудительно удалять даже не пустые каталоги

--numeric-ids не преобразовывать значения uid/gid по
именам пользователя/группы

--timeout=TIME установить время ожидания ввода/вывода в
секундах

-I, --ignore-times отключить "быструю проверку" файлов по
времени модификации и размеру

--size-only отключить проверку времени модификации при
"быстрой проверке" файлов (проверять только
размер)

--modify-window=NUM сравнивать времена модификации файлов с
пониженной точностью

-T, --temp-dir=DIR каталог для временных файлов

--compare-dest=DIR также сравнивать принятые файлы относительно
каталога DIR

--link-dest=DIR создавать жесткие ссылки в каталоге DIR на не
изменявшиеся файлы

-P эквивалент для --partial --progress

-z, --compress сжимать поток передачи данных

-C, --cvs-exclude автоматический пропуск файлов тем же
способом, что и в cvs

--exclude=PATTERN исключить файлы, соответствующие шаблону PAT‐
TERN

--exclude-from=FILE шаблоны исключения брать из файла FILE

--include=PATTERN не исключать файлы по шаблону PATTERN

--include-from=FILE не исключать файлы по шаблонам в файле FILE

--files-from=FILE читать имена файлов для копирования из файла
FILE

-0, --from0 нуль - разделитель всех списков файлов

--version вывести номер версии

--daemon запустить как rsync-демон

--no-detach не отключаться от родительского процесса

--address=ADDRESS слушать на указанном адресе

--config=FILE указать другой rsyncd.conf файл

--port=PORT слушать другой порт

--blocking-io использовать блочный ввод/вывод для удаленной
оболочки

--no-blocking-io отключить --blocking-io

--stats выдавать статистику по передаче файлов

--progress показать % выполнения во время передачи

--log-format=FORMAT формат лог-файла передач

--password-file=FILE читать пароль из файла FILE

--bwlimit=KBPS ограничить скорость ввода/вывода, Кбайт/с

--read-batch=PREFIX для пакетного режима читать набор файлов с
префиксом PREFIX

--write-batch=PREFIX для пакетного режима записать набор файлов с
префиксом PREFIX

-h, --help показать помощь

ПАРАМЕТРЫ
rsync использует соглашение о длинных именах параметров GNU. Многие из
параметров командной строки имеют два варианта: один - короткий, а
другой - длинный. Ниже это отражено в разделении запятой двух
вариантов. Некоторые параметры имеют только длинный вариант. Знак '='
для параметров с дополнительным значением необязателен и может быть
заменен на пробел.

-h, --help
Печатает короткую подсказку, описывающую доступные параметры
rsync

--version
Печатает номер версии rsync и завершается

-v, --verbose
Этот параметр увеличивает сумму подробностей, которые выводятся
в течение передачи. По умолчанию, rsync работает молча. Один
-v будет иметь следствием выдачу списка переданных файлов и
короткий итог в конце. Два -v раскрывают детали о пропущенных
файлах и выдают несколько больше информации в завершение.
Большее число может понадобится только при отладке rsync.

-q, --quiet
Уменьшает сумму подробностей о передаче, преимущественно,
сообщения от удаленного сервера. Этот параметр полезен при
вызове из cron.

-I, --ignore-times
Обычно rsync пропускает файлы, чей размер и время модификации
идентичны. Этот параметр отключает такое поведение "быстрой
проверки".

--size-only
Обычно rsync пропускает файлы, чей размер и время модификации
идентичны. С --size-only файлы будут пропускаться, если их
размер одинаков, независимо от времени модификации. Это полезно
при использовании rsync сразу после работы другой зеркалирующей
системы, которая не сохранила точно времена.

--modify-window
При сравнение двух меток времени rsync рассматривает эти метки
равными, если они расходятся в пределах значения modify_window.
Обычно это значение ноль, но Вы можете найти полезным установку
его в большую величину в некоторых случаях. На практике, при
передаче на файловую систему Windows FAT, которая не может
представлять время с точностью до секунды, --modify_window=1
весьма полезна.

-c, --checksum
Принуждает на передающей стороне подсчитывать контрольные суммы
всех файлов, используя 128-битный алгоритм MD4 перед передачей.
Контрольная сумма затем проверяется на приемной стороне для
того, чтобы пропускать передачи уже существующих файлов с
одинаковыми размером и контрольной суммой. Этот параметр может
приводить к некоторому замедлению.

-a, --archive
Эквивалентно набору -rlptgoD. Это быстрый способ указать, что
Вам нужна рекурсия и Вы хотите сохранить почти все.

Однако заметьте, что -a не сохраняет жесткие ссылки, потому что
поиск многосвязных файлов дорог. Вам придется отдельно
указывать -H.

-r, --recursive
Указывает rsync копировать каталоги рекурсивно. Без указания
этого rsync совсем не будет копировать каталоги.

-R, --relative
Использовать относительные пути. Это значит, что посылаются
полные пути, указанные в командной строке, а не последние части
имен файлов. На практике это полезно, когда Вам нужно послать
несколько различных каталогов за раз. Например, если указать
команду:

rsync foo/bar/foo.c remote:/tmp/



то она создаст файл foo.c в /tmp на удаленной машине. Если
вместо этого указать

rsync -R foo/bar/foo.c remote:/tmp/



то файл создастся в /tmp/foo/bar/foo.c на удаленной машине -
полный путь сохранится.

--no-relative
Выключает параметр --relative. Это нужно только если Вы хотите
использовать параметр --files-from без подразумеваемого им
поведения с включенным параметром --relative.

--no-implied-dirs
В комбинации с --relative все затрагиваемые каталоги в каждом
пути явно не копируются как часть процесса передачи. Это делает
передачу более оптимальной и также позволяет иметь непарные (см.
пример ниже) символьные ссылки в подразумеваемых передачей
путях. Например, если передается файл "/path/foo/file" с
параметром -R, то по умолчанию rsync следит, чтобы "/path" и
"/path/foo" в точности соответствовали каталогам/ссылкам на
приемной стороне. Параметр --no-implied-dirs позволяет
игнорировать несоответствие, когда "/path" - реальный каталог на
одной стороне и символьная ссылка на другой. rsync не пытается
с этим параметром что-либо менять в этом случае.

-b, --backup
С этим параметром существовавшие до передачи файлы на приемной
стороне переименовываются, как только соответствующий файл
передан или удален. Вы можете контролировать, куда перемещаются
файлы и какой суффикс (если нужно) добавляется к имени,
используя параметры --backup-dir и --suffix.

--backup-dir=DIR
В комбинации с --backup указывает каталог, куда сохранять
резервные копии. Это весьма полезно для инкрементального
резервирования. Вы можете дополнительно указать суффикс с
помощью --suffix (иначе резервные копии файлов будут сохранять
свои исходные имена).

--suffix=SUFFIX
Этот параметр позволяет указать суффикс, отличный от суффикса по
умолчанию, для резервных копий файлов при установленном --backup
(-b). По умолчанию этот суффикс установлен в ~ без установки
--backup-dir, установка которого сбрасывает этот суффикс в
пустую строку.

-u, --update
Указывает пропускать любые файлы, уже существующие на приемной
стороне с более поздней датой, чем у исходных файлов.

-l, --links
Если обнаружена символьная ссылка, то она же создается и на
приемной стороне.

-L, --copy-links
Если обнаружена символьная ссылка, то на приемную сторону
копируется файл, на который она указывает, а не такая же
символьная ссылка.

--copy-unsafe-links
Копирует все объекты за пределами исходного дерева каталогов, на
которые ссылаются символьные ссылки. Абсолютные символьные
ссылки, а также, при выставленном --relative, любые символьные
ссылки в пределах исходного дерева каталогов, рассматриваются
как обычные файлы.

--safe-links
Указывает игнорировать любую символьную ссылку, которая
относится к объекту за пределами конечного дерева каталогов.
Все абсолютные ссылки также пропускаются. Использование этого
параметра в комбинации с --relative может дать неожиданные
результаты.

-H, --hard-links
Указывает пересоздать жесткие ссылки на конечной стороне в
соответствии с тем, что имеется на исходной. Без этого
параметра жесткие ссылки обрабатываются как обычные файлы.

Обратите внимание, что rsync может обнаруживать жесткие ссылки,
только если обе части ссылки попадают в список предназначенных к
передаче файлов.

С этим параметром передача может быть довольно-таки медленной,
так что пользуйтесь им только при необходимости.

-W, --whole-file
Этот параметр отключает дифференциальный алгоритм rsync'а и с
ним весь файл передается как есть, целиком. Передача может
происходить быстрее с этим параметром, если полоса пропускания
между исходной и конечной машинами шире, чем полоса пропускания
доступа к диску (особенно, если "диск" в действительности
сетевая файловая система). Этот параметр включен по умолчанию,
если и исходная, и конечная цели находятся локально.

--no-whole-file
Выключает действие параметра --whole-file, если последний
включен по умолчанию.

-p, --perms
Копирует все права на приемную сторону точь в точь с оригиналом.

Без указания этого параметра каждый новый файл получает те права
доступа, что имеет исходный с учетом umask, действующей на
приемной стороне, в то время как все другие (включая
обновляемые) сохраняют свои уже существующие разрешения (это то
же поведение, что имеют другие утилиты копирования файлов, такие
как cp).

-o, --owner
Копирует атрибуты владельца на приемную сторону в точности с
оригиналом. На большинстве систем только супер-пользователь
имеет право устанавливать владельца файла. Нужно заметить, что
если удаленный демон действует в chroot-окружении, то
подразумевается наличие параметра --numeric-ids, потому что на
удаленной стороне в этом случае нет доступа к именам
пользователей в /etc/passwd.

-g, --group
Копирует атрибуты группы на приемную сторону в точности с
оригиналом. Если удаленная сторона не действует из-под
супер-пользователя, то сохранятся только те значения групп,
членом которых является пользователь приемной стороны (имеет
значение имя группы, а не ее id).

-D, --devices
Указывает передавать информацию о символьных и блочных
устройствах для пересоздания их на приемной стороне. Доступно
только супер-пользователю.

-t, --times
Указывает передавать время модификации файлов и обновлять им
соответствующий атрибут на приемной стороне. Обратите внимание,
что если этот параметр не установлен, то становится
неэффективной оптимизация передачи по исключению не изменявшихся
по времени файлов; другими словами, пропуск -t или -a будет
означать, что следующая передача будет осуществляться с
параметром -I, для всех файлов будут сравниваться контрольные
суммы, а в журнале появятся соответствующие сообщения о них,
даже если они не изменялись.

-n, --dry-run
Указывает не осуществлять никаких передач, а только сообщать о
тех действиях, которые могли бы произойти.

-S, --sparse
Пытаться эффективнее обработать фрагментацию файлов, чтобы
сэкономить пространство на приемной стороне.

ЗАМЕЧАНИЕ: Не используйте этот параметр, если в точке назначения
имеется файловая система "tmpfs" Solaris. Не представляется
возможным правильно управлять поиском среди "дырок" (null
regions), что заканчивается повреждением файлов.

-x, --one-file-system
Требует не переходить границ файловой системы при рекурсивном
копировании. Это полезно при необходимости копирования только
одной файловой системы.

--existing
Указывает не создавать никаких новых файлов - только обновить
те, которые уже существуют на приемной стороне.

--ignore-existing
Указывает не обновлять файлы, которые уже существуют на приемной
стороне.

--max-delete=NUM
Не удалять больше, чем NUM файлов и каталогов. Это полезно при
зеркалировании очень массивных деревьев каталогов для
предохранения от неприятностей.

--delete
Удалять любые файлы на приемной стороне, которых нет на
передающей. Файлы, исключенные из передачи, исключаются также и
из процесса удаления, если не указана --delete-excluded.

Этот параметр не оказывает никакого влияния, если не включено
рекурсивное копирование каталогов.

Этот параметр может быть опасным при неправильном использовании!
Очень хорошим правилом может стать использование сначала
холостого выполнения rsync (-n) для просмотра того, что за файлы
могут удалиться и нет ли среди них важных.

При возникновении каких-либо ошибок ввода-вывода на передающей
стороне удаление любых файлов на приемной автоматически
отключается. Это предотвращает от массивного удаления файлов на
приемной стороне из-за временных ошибок файловой системы
(например, NFS) на передающей. Это поведение можно отключить
параметром --ignore-errors.

--delete-excluded
В дополнение к файлам, удаляемым на приемной стороне из-за
отсутствия их на передающей, указывает удалять также любые
исключенные параметром --exclude файлы на приемной стороне.
Подразумевается наличие параметра --delete.

--delete-after
По умолчанию, rsync сначала выполняет удаление файлов перед
копированием для пущей уверенности, что хватит свободного места
на приемной стороне. Если же Вы хотите, чтобы удаление
производилось после, то используйте --delete-after.
Подразумевается наличие параметра --delete.

--ignore-errors
При удалении (--delete) форсирует процесс и игнорирует любые
ошибки, даже ошибки ввода-вывода.

--force
Удалять каталоги при замене их не-каталогами, даже если они не
пусты. Уместен только без --delete, потому что удаление
происходит только каталогов одного уровня. Требует --recursive
(который подразумевается, если -a) для значимого эффекта.

-B, --block-size=BLOCKSIZE
Регулирует размер блока, используемый rsync-алгоритмом. См.
техническое описание на предмет деталей.

-e, --rsh=COMMAND
Позволяет выбрать альтернативную программу удаленной оболочки
для осуществления соединения между удаленной и локальной копиями
rsync. Обычно rsync сконфигурирован для использования ssh по
умолчанию, но Вы можете предпочесть использовать rsh в локальной
сети.

Если этот параметр используется с указанием пути вида
[user@]host::module/path, то программа удаленной оболочки COM‐
MAND будет использована для запуска rsync-сервера на удаленной
стороне, а все данные будут передаваться через соединение
удаленной оболочки, а не напрямую через соединение с
rsync-сервером на "том" конце. См. раздел "ПОДКЛЮЧЕНИЕ К
RSYNC-СЕРВЕРУ ЧЕРЕЗ УДАЛЕННУЮ ОБОЛОЧКУ".

Аргументы командной строки для COMMAND разрешено указывать в
форме, при которой COMMAND представляется для rsync в виде
одного аргумента. Например:

-e "ssh -p 2234"

(Заметьте, что ssh-пользователи могут альтернативно настраивать
специфичные для своего окружения параметры подключения в своих
.ssh/config файлах.)

Вы также можете выбирать программу удаленной оболочки через
переменную окружения RSYNC_RSH, которая принимает тот же
диапазон значений, что и -e.

См. также --blocking-io, на которую влияет установка параметра
-e.

--rsync-path=PATH
Указывает путь к копии rsync на удаленной стороне. Полезен,
если rsync'а нет в Ваших путях поиска. Заметьте, что здесь
указывается полный путь к программе, а не каталог, где она
лежит.

-C, --cvs-exclude
Этим параметром Вы исключаете широкий диапазон файлов, которые
Вы не хотите передавать между системами. При этом используется
тот же алгоритм, что использует CVS для определения игнорируемых
файлов.

Список исключений изначально включает в себя:

RCS/ SCCS/ CVS/ .svn/ CVS.adm RCSLOG cvslog.* tags TAGS
.make.state .nse_depinfo *~ #* .#* ,* *.old *.bak *.BAK *.orig
*.rej .del-* *.a *.o *.obj *.so *.Z *.elc *.ln core

затем файлы, перечисленные в $HOME/.cvsignore , добавляются к
первоначальному списку, а также любые, перечисленные в
переменной окружения CVSIGNORE (разделенные пробелами).

В заключение, любой файл пропускается, если в том же каталоге
есть файл .cvsignore, в котором есть соответствующий файлу
шаблон. См. руководство по cvs(1) для дальнейшей информации.

--exclude=PATTERN
Позволяет выборочно исключать определенные файлы из процесса
передачи. Это наиболее полезно при рекурсивной передаче.

Вы можете использовать так много --exclude, как Вам
заблагорассудится для построения произвольного списка
исключаемых файлов.

См. секцию "ШАБЛОНЫ ИСКЛЮЧЕНИЯ" за информацией о синтаксисе для
этого параметра.

--exclude-file=FILE
Подобен параметру --exclude, но в отличие от него использует
шаблоны исключаемых фалов, перечисленные в файле FILE. Пустые
строки вместе со строками, начинающимися с ';' или '#',
игнорируются. Если FILE указан как -, то список шаблонов
читается со стандартного ввода.

--include=PATTERN
Указывает шаблоны для имен тех файлов, которые нельзя исключать
из процесса. Полезен тем, что позволяет Вам строить довольно
сложные правила включения/исключения.

См. секцию "ШАБЛОНЫ ИСКЛЮЧЕНИЯ" за информацией о синтаксисе для
этого параметра.

--include-from=FILE
Указывает брать список обязательно включаемых в передачу файлов
из файла FILE. Если FILE указан как -, то список шаблонов
читается со стандартного ввода.

--files-from=FILE
Позволяет задать точный список файлов для передачи (который
будет прочитан из указанного FILE или из стандартного ввода,
если указан -). Это также меняет поведение rsync по умолчанию
в целях облегчения процесса передачи заданных файлов и
каталогов. Например, по умолчанию включается использование
опции --relative (для отключения этого используйте --no-rela‐
tive), на принимающей стороне создаются все указанные в списке
каталоги (а не пропускаются безгласно, как если бы не
использовалась опция -r), а поведение -a (--archive) не
подразумевает наличие -r (--recursive) - его, при необходимости,
нужно указывать явно.

Все имена файлов, прочитанные из FILE, считаются относительными
к исходному каталогу -- первые слэши убираются и не допускаются
ссылки "..", указывающие выше по дереву исходного каталога. Для
примера рассмотрим:

rsync -a --files-from=/tmp/foo /usr remote:/backup

Если /tmp/foo содержит строку bin (или даже "/bin"), каталог
/usr/bin будет создан как /backup/bin на удаленной машине (но
содержимое /usr/bin не должно передаваться, кроме тех случаев,
когда объекты явно указаны в /tmp/foo, или в случае указания
параметра -r). Также учитывайте, что эффект от --relative
(включенный по умолчанию) касается копирования путей,
прочитанных из файла, -- он не принуждает копировать полностью
указанный исходный путь (/usr в примере).

В дополнение, --files-from файл может быть прочитан с удаленной
машины, а не локально, если указать перед именем файла "host:"
(это должно соответствовать одному из концов передачи). Для
краткости, можно указывать только префикс ":" для обозначения
удаленного участника копирования. Например:

rsync -a --files-from=:/path/file-list src:/ /tmp/copy

эта команда должна скопировать все файлы указанные в файле
/path/file-list, который расположен на удаленной машине "src".

-0, --from0
Говорит rsync, что имена файлов, читаемые извне, заканчиваются
символом '\0', не NL, CR или CR+LF. Это касается параметров
--exclude-from, --include-from, and --files-from.

-T, --temp-dir=DIR
Инструктирует использовать DIR как каталог временных копий
передаваемых файлов на принимающей стороне. По умолчанию
временные файлы создаются в каталоге назначения.

--compare-dest=DIR
Инструктирует использовать DIR на машине назначения как каталог,
относительно содержимого которого осуществляется сравнение во
время процесса передачи при условии отсутствия файлов в каталоге
назначения. Это полезно для осуществления передачи в новое
место, оставляя существующие файлы неприкосновенными, а затем
перенося и очищая, когда все файлы были переданы (например, при
перемещении каталогов в новое место и удалении старого, хотя при
этом пропускаются не изменявшиеся файлы; см. также --link-dest).

Прим. переводчика: Существование этого параметра обусловлено
необходимостью обновлять, например, дерево с взаимозависимыми
файлами. В этом случае нежелательно осуществлять копирование на
пофайловой основе. Параметр --compare-dest позволяет указывать
временный каталог назначения, куда и копируются передаваемые
файлы. По окончании процесса передачи rsync переименовывает
оригинальное дерево назначения, затем переименовывает временный
каталог DIR в оригинальный и, наконец, удаляет переименованный
на первом шаге оригинальный каталог со "старыми" файлами.

Этот параметр повышает полезность --partial, потому что частично
переданные файлы будут оставаться в новом временном каталоге до
тех пор, пока не окажутся целиком на месте. Если DIR задан как
относительный путь, то он соотносится к каталогу назначения.

--link-dest=DIR
Ведет себя также, как и --compare-dest, но также создает жесткие
ссылки в DIR на не изменявшиеся файлы в каталоге назначения.
Файлы с измененными правами и владением не подвергаются этому.
Как и в случае --compare-dest, если DIR задается относительным
именем, то и действия осуществляются относительно каталога
назначения.

-z, --compress
С этим параметром rsync сжимает все передаваемые данные файлов.
Это полезно на медленных линиях. Метод сжатия, используемый при
этом, тот же, что реализует gzip.

Заметьте, что при этом обычно достигается лучший коэффициент
сжатия, чем может быть достигнут, используя сжатие программ
удаленной оболочки или сжатие транспортного уровня, т.к. в
процесс сжатия вовлекается вся информация, посылаемая в
соответствующих блоках данных.

--numeric-ids
Вместо имен групп и пользователей посылаются их числовые id и
ставятся в соответствие друг другу на обоих концах.

По умолчанию rsync использует имена групп и пользователей для
определения владельца файлов. Специальные uid 0 и gid 0
никогда не отображаются через имена пользователей/групп, даже
если не указана --numeric-ids.

Если исходная система работает в ограниченном chroot-окружении
или если пользователь или группа не существуют на приемной
стороне, то используются исходные числовые id.

--timeout=TIMEOUT
Позволяет устанавливать максимальное время ожидания ввода-вывода
в секундах. Если за указанный период ничего не передано, то
работа rsync завершается. По умолчанию 0, что означает без
ожидания.

--daemon
Запускает rsync как демон. Демон доступен для клиентов через
синтаксис host::module или rsync://host/module .

Если стандартным вводом является сокет, то rsync полагает
условием запуск от inetd, иначе он отключается от текущего
терминала и становится фоновым процессом-демоном. Демон читает
конфигурационный файл (rsyncd.conf) на каждое соединение от
клиентов и соответственно отвечает на их запросы.

--no-detach
При запуске демоном этот параметр инструктирует rsync не
отключаться от терминала и стать фоновым процессом. Он
требуется при запуске службой под Cygwin, и также может быть
полезен, если rsync находится под наблюдением таких программ как
daemontools или AIX's System Resource Controller. --no-detach
также рекомендуется к применению при запуске rsync под
отладчиком. Этот параметр не имеет никакого эффекта при запуске
от inetd или sshd.

--address
По умолчанию rsync использует групповой адрес 0.0.0.0, когда
запускается как демон с --daemon или при подключениях к
rsync-серверу. --address позволяет Вам указать точный IP-адрес
(или хост-имя) для этого. Это делает возможным виртуальный
хостинг в сочетании с --config.

--config=FILE
Указывает альтернативный файл конфигурации. Это имеет значение
только если указан --daemon. По умолчанию /etc/rsyncd.conf за
исключением случая, когда демон запускается поверх удаленной
оболочки и удаленный пользователь не root. В последнем случае
rsyncd.conf по умолчанию располагается в текущем каталоге
(обычно $HOME).

--port=PORT
Указывает альтернативный номер TCP порта для работы, а не 873 по
умолчанию.

--blocking-io
Указывает использовать блокирующий ввод-вывод при запуске поверх
программы-транспорта удаленной оболочки. Если этой программой
являются либо rsh, либо remsh, то rsync использует блокирующий
ввод-вывод по умолчанию, иначе по умолчанию используется
неблокирующий ввод-вывод. (Заметьте, что ssh предпочитает
неблокирующий.)

--no-blocking-io
Отключает действие --blocking-io, когда оно активировано по
умолчанию.

--log-format=FORMAT
Позволяет Вам точно указывать, что rsync сообщает (журналирует)
на стандартный вывод на по-файловой основе. Формат сообщений
определяется тем же соглашением, что и для параметра
журналирования в файле rsyncd.conf.

--stats
Указывает выводить подробную статистику по передаче файлов,
позволяя Вам оценить, насколько эффективен алгоритм rsync
относительно Ваших данных.

--partial
По умолчанию rsync будет удалять все частично-переданные файлы в
случае прерывания передачи. В некоторых случаях более
желательно сохранять такие файлы. Используя параметр --partial,
можно указать rsync сохранять частично-переданный файл, что
может ускорить передачу всего файла при последовательном
повторении таких передач.

--progress
Указывает выводить rsync информацию о ходе передачи. Скучающему
пользователю будет на что посмотреть. Подразумевает наличие
--verbose без увеличения подробностей.

-P Эквивалент для --partial --progress . Автор нашел для себя
частым использование этой комбинации, поэтому для облегчения
ввел отдельный параметр.

--password-file
Позволяет Вам предоставить пароль для доступа к rsync-серверу,
сохранив его в файле. Заметьте, что этот параметр полезен
только при использовании для доступа к rsync-серверу встроенного
rsync-транспорта, при использовании программы удаленной оболочки
он бесполезен. Файл не должен быть всем доступен на чтение. Он
должен содержать только пароль, в одну строчку.

--bwlimit=KBPS
Позволяет указать максимальную скорость передачи, килобайт в
секунду. Этот параметр наиболее эффективен при использовании
rsync для передачи больших файлов (несколько мегабайт и выше).
В соответствии с природой rsync-передач передается обычный блок
данных, затем если rsync определяет, что скорость выше
установленного, то он вводит задержку перед посылкой следующего
блока. В результате средняя скорость передачи равна указанному
пределу. Нулевое значение означает отсутствие этого
ограничения.

--write-batch=PREFIX
Генерирует набор файлов, которые могут быть переданы в пакетном
обновлении. Каждое имя файла в наборе начинается с PREFIX. См.
раздел "ПАКЕТНЫЙ РЕЖИМ" за деталями.

--read-batch=PREFIX
Применяет ранее сгенерированный пакет изменений, используя тот
набор файлов, чьи имена начинаются с PREFIX. См. раздел
"ПАКЕТНЫЙ РЕЖИМ" за деталями.

ШАБЛОНЫ ИСКЛЮЧЕНИЯ
Шаблоны исключения и включения, будучи заданными, позволяют гибко
выделять, какие файлы должны передаваться, а какие должны быть
пропущены.

rync строит упорядоченный список на основе параметров
--include/--exclude, указанных в командной строке. Rsync проверяет
каждое имя файла или каталога относительно соответствия каждому шаблону
включения/исключения. В действие вступает первое же совпадение. Если
совпавший шаблон исключающий, то соответствующий файл пропускается.
Если шаблон включающий, то не пропускается. При отсутствии подходящих
шаблонов к имени файла он также не пропускается.

Имена файлов проверяемых по таким шаблонам задаются относительно
каталога назначения, "верхнего каталога", так что шаблоны необязательно
должны включать элементы исходного или конечного каталогов.
Единственный случай, когда шаблоны будут проверяться относительно
абсолютных путей к файлам или каталогам, - это случай, когда исходным
путем является корневой каталог файловой системы.

Заметьте, что при использовании параметра -r (он подразумевается при
-a) каждая отдельная часть каждого пути просматривается сверху вглубь,
так что шаблоны включения/исключения применяются рекурсивно к каждой
такой части.

Также обратите внимание, что параметры --include и --exclude допускают
только по одному шаблону каждый. Для добавления множества шаблонов
используйте параметры --include-from и --exclude-from или множество
параметров --include и --exclude соответственно.

Шаблоны могут быть заданы в нескольких формах. Правила для них таковы:

o Если шаблон начинается с /, то он проверяется на соответствие с
началом имени файла, в противном случае - относительно
завершающей части имени. Это эквивалент начального ^ в
регулярных выражениях. Таким образом, "/foo" должен
соответствовать файлу с именем "foo" в вершине передаваемого
дерева. С другой стороны, "foo" должен соответствовать любому
файлу "foo" везде в пределах дерева каталогов, потому что
алгоритм применяется рекурсивно сверху вглубь. Он работает так,
как если бы каждая составная часть пути была завершением имени
файла. Начальный / не превращает шаблон в абсолютный путь.

o Если шаблон заканчивается на /, то он соответствует только
каталогу, не файлу, не ссылке и не устройству.

o Если шаблон содержит символы подстановки из набора *?[ , то при
проверке соответствия используются правила подстановки командной
оболочки для имен файлов. В противном случае используется
просто соответствие строке.

o В соответствия двойной звездочки "**" входит слэш, в то время
как для одиночной звездочки "*" на слэше совпадение
заканчивается.

o Если шаблон содержит слэш / (не считая завершающего слэша) или
"**" , то такой шаблон проверяется на соответствие полному имени
файла, включая любые вышестоящие каталоги. Если шаблон не
содержит / или "**", то такой шаблон проверяется относительно
завершающей части имени файла. Еще раз, помните, что алгоритм
применяется рекурсивно, так что "полным именем файла" может
оказаться в действительности любая часть пути в глубине иерархии
от начального каталога.

o Если шаблон начинается на "+ " (плюс с последующим пробелом), то
это всегда рассматривается как включающий шаблон, даже если
указан как часть параметра исключения. Сама часть "+ " не
учитывается при проверке на соответствие.

o Если шаблон начинается на "- " (минус с последующим пробелом),
то это всегда рассматривается как исключающий шаблон, даже если
он фигурирует как часть параметра включения. Сама часть "- " не
учитывается при проверке на соответствие.

o Если шаблоном указан одиночный восклицательный знак ! , то
текущий список включения/исключения сбрасывается удалением всех
ранее определенных шаблонов.

Правила +/- наиболее полезны в списках, читаемых из файла, позволяя Вам
иметь один общий список, который содержит как исключающие, так и
включающие шаблоны.

Если Вы завершите исключающий список указанием --exclude '*', то
обратите внимание, что из-за рекурсивного характера алгоритм
остановится на родительских каталогах и не будет пробовать файлы внутри
них за исключением тех случаев, когда Вы явно укажете включать
родительские каталоги файлов, которые Вы хотите включить. Для
включения всех каталогов используйте --include '*/' до --exclude '*'.

Несколько примеров включения/исключения:

o --exclude "*.o" исключить все имена файлов, соответствующие *.o

o --exclude "/foo" исключить файл с именем foo в верхнем каталоге

o --exclude "foo/" исключить любой каталог с именем foo

o --exclude "/foo/*/bar" исключить любой файл с именем bar в двух
уровнях вглубь по иерархии от каталога "foo" в вершине дерева

o --exclude "/foo/**/bar" исключить любой файл с именем bar в двух
и более уровнях вглубь по иерархии от верхнего каталога "foo"

o --include "*/" --include "*.c" --exclude "*" включить только
каталоги и файлы с Си-исходниками

o --include "foo/" --include "foo/bar.c" --exclude "*" включит
только foo/bar.c (каталог foo/ нужно включать явно, иначе он
будет пропущен из-за "*")

ПАКЕТНЫЙ РЕЖИМ
Заметьте: Пакетный режим должен рассматриваться как экспериментальный в
этой версии rsync. Интерфейс и дизайн могут измениться, прежде чем его
реализация стабилизируется.

Пакетный режим может использоваться для выполнения обновлений
нескольких идентичных систем. Предположим, что имеется дерево
каталогов, которое нужно реплицировать на некоторое количество машин.
Теперь предположим, что в это исходное дерево внесены изменения,
которые нужно распространить на те машины. В порядке реализации этого
в пакетном режиме rsync запускается с параметром --write-batch для
копирования изменений исходного дерева на одну из конечных машин. Этот
параметр заставляет rsync сохранить в набор файлов пакетного обновления
(см. ниже) информацию, необходимую для повторения той же операции
копирования относительно и других машин. Имя каждого файла в наборе
начинается с префикса, указанного пользователем в аргументе для
параметра --write-batch. Затем этот набор файлов копируется на каждую
из оставшихся удаленных машин, где запускается rsync с параметром
--read-batch, тем же префиксом и конечным деревом назначения. Rsync
обновляет последнее, используя информацию, сохраненную в наборе файлов
пакетного обновления.

Набор состоит из 4 файлов:

o <prefix>.rsync_argvs параметры и аргументы командной строки

o <prefix>.rsync_flist внутренние метаданные rsync'а о перемещаемых
файлах

o <prefix>.rsync_csums контрольные суммы

o <prefix>.rsync_delta блоки данных для обновления и изменения
файлов

Файл .rsync_argvs содержит необходимые команды оболочки, подходящие для
обновления конечного дерева каталогов, используя набор файлов пакетного
обновления. Это можно использовать при запуске из Bourne-подобной
оболочки, дополнительно передавая параметр альтернативного пути который
затем используется вместо оригинального. Последнее полезно, если
конечный путь отличается от оригинального конечного пути.

Генерация набора файлов пакетного обновления позволяет избежать
многократного повторения создания информации о состоянии файлов,
контрольных суммах и блоках данных при обновлении многих конечных
деревьев каталогов. Многоадресные транспортные протоколы могут быть
использованы для передачи файлов пакетного обновления параллельно на
несколько машин за раз вместо посылки их на каждую индивидуально.

Примеры:

$ rsync --write-batch=pfx -a /source/dir/ /adest/dir/
$ rcp pfx.rsync_* remote:
$ ssh remote rsync --read-batch=pfx -a /bdest/dir/
# или альтернативно
$ ssh remote ./pfx.rsync_argvs /bdest/dir/




В этом примере rsync используется для обновления /adest/dir/ из
/source/dir/ , и информация для повторения этой операции сохраняется в
файлах pfx.rsync_* . Эти файлы затем копируются на машину с именем
"remote" . После этого rsync запускается на "remote" для обновления
/bdest/dir/ тем же способом, что и /adest/dir/ . Последняя строка
демонстрирует как можно использовать rsync_argvs для запуска rsync.

Предостережения:

Параметр --read-batch требует аргументом конечное дерево назначения,
что значит обновлять идентично тому дереву назначения, которое было
использовано для создания набора файлов обновления. Если выясняется
различие между конечными деревьями, то обновление немедленно
прекращается, оставляя дерево назначения в частично обновленном
состоянии. В таком случае rsync может быть использован в своем обычном
режиме (не пакетном) для исправления дерева назначения.

Версия rsync должна быть везде одинаковой относительно той версии,
которая использовалась для создания оригинала.

Параметр -z/--compress не работает в пакетном режиме и выдает ошибку
использования. Вместо этого могут быть использованы сторонние
средства сжатия для уменьшения размера файлов пакетного обновления при
транспортировке к цели.

Параметр -n/--dryrun не работает в пакетном режиме и выдает ошибку
выполнения.

См. http://www.ils.unc.edu/i2dsi/unc_rsync+.html на предмет
документации и технических описаний.

СИМВОЛИЧЕСКИЕ ССЫЛКИ
Три основных сценария поведения возможны при обнаружении символических
ссылок в исходном каталоге.

По умолчанию символические ссылки не передаются совсем. Для любой
существующей ссылки в этом случае выдается сообщение "skipping non-reg‐
ular" ("пропуск нерегулярного").

Если указан параметр --links, то символические ссылки на тот же объект
в конечном месте заново пересоздаются. Заметьте, что --archive
подразумевает --links.

Если указан параметр --copy-links, то символическая ссылка
"раскрывается" копированием того объекта, на который она указывает,
вместо создания ссылки.

rsync также различает безопасные и небезопасные символические ссылки.
Примером того, где это может быть использовано, может послужить такое
зеркалирование web-сайта, при котором желательно быть уверенным, что в
зеркальной копии нет символических ссылок на /etc/passwd в доступной
всем пользователям части сайта. При использовании --copy-unsafe-links
любые ссылки копируются в конечное место в виде файла, на который они
указывают. Параметр --safe-links указывает полностью пропускать
небезопасные ссылки.

Символические ссылки считаются небезопасными, если они указывают на
абсолютный путь (начинающийся с /), если они пустые или если они
содержат достаточное количество "..", чтобы выйти за пределы каталога
копирования.

ДИАГНОСТИКА
rsync порой производит сообщения об ошибках, которые могут показаться
немного загадочными. Одним из таких сообщений является "protocol ver‐
sion mismatch - is your shell clean?" ("несоответствие версий - ваша
оболочка в порядке?").

Это сообщение обычно является следствием того, что Ваши запускающие
скрипты или возможности удаленной оболочки производят лишний мусор в
потоке, который rsync использует в качестве транспорта. Способ
диагностирования этой проблемы следующий:

ssh remotehost /bin/true > out.dat




и посмотреть в out.dat . Если все работает корректно, то этот файл
должен быть нулевого размера. Если Вы получаете вышеупомянутое
сообщение от rsync, то Вы, возможно, найдете какие-то текст или данные
в файле out.dat . Взгляните на его содержимое и по нему проверьте то,
что может его производить. Наиболее общая причина - это неправильно
настроенные скрипты запуска (такие как .cshrc или .profile), которые
содержат выражения, выдающие сообщения при не интерактивном входе в
систему.

Если Вы имеете трудности с отладкой шаблонов включения и(или)
исключения, то попробуйте указать параметр -vv. При таком уровне
подробностей rsync будет показывать, почему включен или исключен каждый
отдельный файл.

КОДЫ ЗАВЕРШЕНИЯ
0 Успешно

1 Синтаксическая ошибка или ошибка использования

2 Несовместимость протоколов

3 Ошибки выбора входных/выходных файлов и каталогов

4 Запрошенное действие не поддерживается: была сделана попытка
работы с 64-битными файлами на платформе, которая их не
поддерживает; или указан параметр, который поддерживается только
клиентом и не поддерживается сервером.

5 Ошибка при попытке начать работать по протоколу клиент-сервер

10 Ошибка сокета ввода/вывода

11 Ошибка ввода/вывода файла

12 Ошибка в потоке данных rsync-протокола

13 Ошибки при диагностике

14 Ошибка в IPC-коде

20 Получены сигналы или SIGUSR1, или SIGINT

21 Вызов waitpid() возвращает ошибку

22 Error allocating core memory buffers

23 Незавершенная передача из-за ошибки

24 Незавершенная передача из-за пропадания исходного файла

30 Время ожидания при передаче/приеме данных

ПЕРЕМЕННЫЕ ОКРУЖЕНИЯ
CVSIGNORE
Переменная окружения CVSIGNORE дополняет исключающие шаблоны из
файла .cvsignore. За деталями см. параметр --cvs-exclude.

RSYNC_RSH
Переменная окружения RSYNC_RSH позволяет переопределить
программу удаленной оболочки, используемую rsync'ом как
транспорт. Параметры командной строки для оболочки указываются
после имени программы, также как и для параметра -e.

RSYNC_PROXY
Переменная окружения RSYNC_PROXY позволяет указать rsync-клиенту
использовать web-прокси для подключения к rsync-серверу. Вы
должны указать прокси в виде пары hostname:port .

RSYNC_PASSWORD
Установка значения RSYNC_PASSWORD позволяет осуществить
rsync-соединение к rsync-серверу без вмешательства пользователя
для ввода пароля. Заметьте, что это не тоже самое, что и пароль
для транспортной оболочки, например, ssh.

USER или LOGNAME
Переменные окружения USER или LOGNAME используются для
определения пользователя по умолчанию, имя которого
предоставляется rsync-серверу для аутентификации.

HOME Переменная HOME используется для поиска пользовательского файла
.cvsignore.

ФАЙЛЫ
/etc/rsyncd.conf или rsyncd.conf

СМ. ТАКЖЕ
rsyncd.conf(5)

ДИАГНОСТИКА
ОШИБКИ
Информация о времени передается как unix-структура time_t .

При передаче на файловую систему FAT rsync может скопировать не
измененные файлы. См. комментарий к параметру --modify-window.

Права на файлы, устройства и т.п. передаются как изначальные числовые
значения.

См. также комментарии к параметру --delete.

Пожалуйста, сообщайте об ошибках! См. web-сайт http://rsync.samba.org/

CREDITS
rsync распространяется на условиях GPL. См. файл COPYING на предмет
деталей.

Web-сайт доступен по адресу http://rsync.samba.org/. Сайт содержит в
том числе FAQ-O-Matic, который отвечает на многие незатронутые в этом
руководстве вопросы.

Первичный ftp-сервер для rsync ftp://rsync.samba.org/pub/rsync.

Нам было бы приятно услышать от Вас, что Вам понравилась наша
программа.

Эта программа использует превосходную библиотеку сжатия zlib,
написанную Jean-loup Gailly и Mark Adler.

БЛАГОДАРНОСТИ
Благодарим Richard Brent, Brendan Mackay, Bill Waite, Stephen Rothwell
и David Bell за полезные предложения, патчи и тестирование rsync. Если
мы пропустили некоторых людей, то пусть примут наши извинения.

Специальные благодарности: David Dykstra, Jos Backus, Sebastian Krah‐
mer.

АВТОР
rsync была написана Andrew Tridgell <tridge@samba.org> and Paul Macker‐
ras.

Сейчас rsync сопровождается Martin Pool <mbp@samba.org>.

Списки рассылок для поддержки и разработки доступны по адресу
http://lists.samba.org

Если Вы подозреваете, что нашли уязвимость в rsync, пожалуйста,
известите Martin Pool и Andrew Tridgell. Для других вопросов
пользуйтесь списком рассылки.

ПЕРЕВОД
Sergey Golovin <svgol@mail.ru>

Aleksandr Blokhin <sass@altlinux.ru>



Jan 2004 rsync(1)

Строка с rsync ставится в crontab на время, когда мало кто работает с документами (например, в 4 утра). В случае если ВНЕЗАПНО полетит основной диск, зеркальная копия данных будет сохранена. Саму систему копировать необязательно, но тоже можно, только надо добавить в --exclude=/proc
Пример строки для бекапа:
Bash
1
rsync -azq --delete-after --exclude=видео_корпоративов /media/откуда /media/куда
Возможно вы не знаете, но для удаленного управления сервером часто используют ssh. Установка:
Bash
1
sudo apt-get install openssh-server -y
И вот еще: при установке сервака "иксы" (графическая подсистема) не ставится.
1
 Аватар для bagas
15 / 15 / 0
Регистрация: 20.03.2012
Сообщений: 91
02.10.2012, 10:12
У себя в доме на виндузе реализовал такую файловую помойку.
Samba ав триазция в AD
Стоит только до выставлять acl и дешовый вариант файлового сервера готов.
Конечно если более 100 пользователей и нужно выставить иерархию прав, то уже посложнее и дольше прийдется по возиться с асл.
0
0 / 0 / 0
Регистрация: 29.09.2012
Сообщений: 10
02.10.2012, 19:29  [ТС]
remarkes спасибо за подсказку.
0
310 / 233 / 15
Регистрация: 01.07.2011
Сообщений: 812
Записей в блоге: 1
02.10.2012, 22:13
mr4ester, обращайся
0
-8 / 7 / 0
Регистрация: 28.10.2012
Сообщений: 84
12.11.2012, 19:40
сейчас для этого используется dropbox.com или google диск. И проще, и быстрее, и лучше.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.11.2012, 19:40
Помогаю со студенческими работами здесь

Файловый сервер
Подскажите что нужно написать, чтобы загружать на свой компьютер файл, выбранный listView1, в дальнейшем отображать процесс загрузки через...

Файловый сервер
Всем доброго времени суток. У меня возник такой вопрос. Как создать файловый сервер. И какое оборудование для этого нужно. Но всё бы было...

Файловый сервер
Ребята нужна помощь. Помогите подобрать вэб сервер для обмена файлами, причем нужно чтоб оболочка была графическая, доступ мог быть к...

Файловый сервер
Привет всем. На какой системе лучше всего запустить файловый сервер?(есть ли какой нибудь гайд)ПК на i5 , там находится два диска по 3тб и...

Файловый сервер
“Файловый сервер” Сервер: при подключении выводит список файлов (разделенный символом конца строки) из заданной папки и их размер. Имена...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определенном условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru