Рекомендации по репликации SQL-сервера - PullRequest
3 голосов
/ 04 февраля 2009

У нас есть сценарий

Один главный сайт электронной коммерции - в настоящее время привлекает много посетителей.

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

Клиент требует, чтобы обработка заказа для каждого сайта бренда происходила в одном месте (т. Е. В одном офисе).

Какую топологию выбрать? Мы думаем, что возможно наличие основного сервера sql с возможностью как чтения, так и записи из бэк-офиса, и репликация этих данных в «брендовые» экземпляры сервера SQL может работать. Каждый сайт конкретной марки будет иметь свой собственный выделенный sql-сервер для «чтения» Frontoffice. Любые записи, которые мы выполняем, возвращаются в основную базу данных для одновременного хранения данных

Есть мысли? Масштабируемость в будущем является основным фактором.

Ответы [ 2 ]

1 голос
/ 04 февраля 2009

Без более подробного понимания того, как должно работать ваше приложение, трудно дать вам четкое указание.

Предполагаемая реализация наличия центрального сервера (Publisher), поддерживающего чтение и запись, с рядом дополнительных серверов (подписчиков), специфичных для сайта (только для чтения), безусловно, правдоподобна. Это дает дополнительное преимущество, позволяя вам гибко реплицировать только те таблицы, которые потребуются для запросов на чтение, т. Е. Ваш центральный сервер, скорее всего, будет управлять такими данными, как информация о поставщике, выставление счетов и т. Д., Которые, возможно, не нужно передавать подписчикам. *

Ваш центральный сервер, скорее всего, станет для вас камнем преткновения, если таковые имеются, так как все остальные серверы будут направлять активность записи обратно на него. Расположение ваших распределенных сайтов, т. Е. То, как далеко они находятся от центрального сервера, также повлияет на задержку транзакций в вашей реплицированной среде.

Если вы хотите представить все данные своей базы данных только для чтения на распределенных сайтах, то вы можете рассмотреть возможность использования Log Shipping для этого. Недостаток этой реализации, если ваше приложение должно знать, что на локальном сервере можно обрабатывать только операции чтения, а все операции записи необходимо направлять на центральный сервер.

Надеюсь, это поможет, но, пожалуйста, не стесняйтесь задавать дополнительные вопросы.

Ура, Джон

0 голосов
/ 04 февраля 2009

Не конкретный ответ на ваш вопрос, но Масштабирование Youtube - интересное видео о масштабировании YouTube Возможно, это даст вам некоторые идеи.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...