Один файловый сервер и два реплицированных узла с демоном samba
Я должен создать новую инфраструктуру для проекта. У нас есть два офиса с медленной восходящей и нисходящей линией связи (2 Мбит SDSL) к Интернету и один сервер C со 100 Мбит соединением с Интернетом. Затем в каждом офисе (A и B) есть машина с Ubuntu с общим ресурсом samba, так что каждый пользователь в конкретном офисе может подключить этот общий ресурс под буквой диска в Windows. Таким образом, они имеют быстрый доступ, потому что внутренняя локальная сеть использует 100/1000 Мбит. Затем две машины Ubuntu (A и B) и сервер Ubuntu (C) должны реплицировать данные между ними. Все они имеют диск объемом 1 ТБ, и данные на них всегда должны быть одинаковыми.
По этой причине я попробовал GlusterFS на серверах A и C, но, похоже, он не очень надежен (сервер B на данный момент не существует). Для быстрого теста я скопировал файл размером 10 МБ в точку монтирования glusterfs на сервере A. В ту же секунду файл появился на сервере C, но был только 6 МБ. Требуется до 30 минут, чтобы файл на сервере C получил правильный размер 10 МБ. Из-за этого я не очень хочу использовать его в продуктивной среде.
Основная проблема заключается в том, что пользователи в офисе хотят иметь быстрое соединение с локальным сервером, и если кто-то изменяет, удаляет, перемещает или создает файл, его также следует изменить, удалить, переместить или создать на других серверах. Может быть, будет достаточно использовать только серверы A и B в качестве кеша, но какой сервис лучше для этого?
Я действительно ценю твою помощь. Было бы неплохо найти подходящее решение. Спасибо!
1 ответ
Стандартное решение этой проблемы - использовать программу под названием Unison. Их веб-страница гласит:
Unison - это инструмент синхронизации файлов для OSX, Unix и Windows. Он позволяет хранить две копии набора файлов и каталогов на разных хостах (или разных дисках на одном хосте), изменять их отдельно, а затем обновлять, распространяя изменения в каждой реплике на другую.
Интеграция с Samba Share достаточно проста: она подробно обсуждается на страницах Samba Wiki.
По сути, он состоит из четырех этапов:
Синхронизация пользователя. Наиболее удобно иметь одинаковый набор пользователей обеих систем. Это особенно легко, если общие ресурсы принадлежат одному и тому же пользователю, и любой может изменять их содержимое. Но вы также можете настроить свою систему так, чтобы в ней были все пользователи обеих локальных сетей, это зависит только от вас.
Доступ без пароля. Это необходимо для обеспечения автоматических, но безопасных соединений SSH между двумя системами.
Настройка Unison (самая простая часть, всего одна строка).
настройка crontab. Это необходимо для синхронизации ваших двух машин каждую минуту (это не может быть сделано чаще с помощью crontab). Это тоже однострочник.
Это в основном все.