Похоже, вы настраиваете сервер разработки и хотите скопировать данные с производства. Вы должны рассмотреть
- Воздействие на производственном сервере
- нужно ли частые обновления с сервера производства (это обновление производства приложение свою базу данных? Вы нужны те, в развитии?)
- вам нужно все данные или подмножество?
Существует хорошая вероятность, что администраторы баз данных имеют scheduled regular backups, особенно если есть частые обновления. Предполагая, что это так, вы должны иметь возможность получить копию одного из этих резервных копий без какого-либо влияния на prod-сервер. Таким образом, мое первое предложение было бы # 1. Вы можете обновлять свои серверы с этими резервными копиями так часто, как это делают администраторы. Обратите внимание, что использование резервного копирования базы данных требует, чтобы оба сервера работали на одной платформе. Это даст вам все производственные данные.
С другой стороны, если важно, чтобы ваш сервер-разработчик получал частые обновления с производственного сервера более или менее по мере их возникновения, тогда выполнение 2-й гибкой репликации или репликации баз данных №3 будет выполняться. Поймите, что для этого требуется больше работы с производственного сервера и, вероятно, не то, что вы хотите сделать для целей dev, но это вариант. Влияние на сервер prod будет зависеть от частоты обновлений баз данных в prod. Из двух я не знаю, какое влияние оказал бы на prod (кто-нибудь еще?). Это может получить все данные или может быть настроено на получение подмножества.
И, наконец, если вам не нужны частые (как-бы-они) обновления, и администраторы не делают резервных копий, или если prod и dev работают на разных платформах (Windows/Linux/Mac), вы можете запустить XQSync в нерабочее время. Я бы сделал это очень тщательно, так как смешивание параметров могло отправить данные в неправильном направлении. Вы можете настроить это, чтобы взять подмножество данных на основе каталогов, коллекций или пользовательского запроса.
Относительная нота: каждая из этих стратегий касается копирования данных, но ни одна из них не копирует для вас конфигурацию базы данных. Для этого потребуется другой подход. Вы можете использовать Roxy Deployer, чтобы поддерживать конфигурацию в git/svn/whatever и загружать конфигурацию таким же образом во всех средах. Вы можете использовать предоставленный MarkLogic Configuration Manager для создания моментального снимка производственной среды (для этого вам потребуются администраторы, чтобы сделать это для вас) и импортировать его в среду разработки.
Предлагаемая начальная точка: убедитесь, что ваша конфигурация соответствует, а затем используйте резервные копии, которые администраторы, вероятно, принимают в любом случае. Это будет иметь наименьшее влияние на и минимальный риск для производственной системы. Если это не соответствует вашим потребностям, посмотрите на одну из других стратегий.
Около 2: вы имеете в виду «без задержки», как в «без прерывания базы данных»? Или вы действительно хотите быть в синхронизации без промедления? – grtjn