Архитектура сервера для масштабируемой игры Facebook - PullRequest
4 голосов
/ 03 февраля 2011

Некоторые друзья и я написали игру для Facebook, не задумываясь о реальной архитектуре игры - и представьте себе наше удивление, когда мы достигли более 300 000 уникальных игроков в месяц и когда наши серверы растаяли.

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

В настоящее время я новичок во всем масштабированииКонцепция, но из того, что я понял более или менее, это то, что нам нужно: 1. Балансировщик нагрузки 2. Веб-сервер на 20 000 ~ одновременных пользователей (Мы связались со сторонним разработчиком Comet, который утверждает, что он может поддерживать до 20 000 одновременных пользователей).количество соединений на узел) 3. Кэширующий кластер 4. Кластер баз данных

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

Имейте в виду, что:

  1. Мы стремимся охватить миллионы игроков
  2. Мы стремимся охватить 10/100 тысяч одновременно работающих пользователей
  3. Нам необходимо хранить как можно больше данных в кэше и каждый раз сбрасывать их в БД
  4. У нас естькакое-то взаимодействие между игроками (получение обновлений очков игрока и т. д.), и нам нужен централизованный или реплицируемый кеш для работы (в основном это означает, что нам нужны данные кеша, к которым все веб-серверы обращаются для полной синхронизации)

1 Ответ

1 голос
/ 03 февраля 2011

А как насчет развертывания в облаке Azure?Веря в то, что они говорят, масштабируемость больше не будет вас беспокоить.

Вместо создания кластера БД, как насчет разделения игроков на разные «серверы», «миры» или как бы вы ни назвали это в своей игре.Я не знаю, о какой игре вы говорите, но большинство браузерных игр, в которые я играю, делают это, чтобы справиться с нагрузкой.

...