МАСШТАБИРОВАНИЕ RAILS Голубев Павел Июнь 2009 20 июня 2009 г.
МАСШТАБИРОВАНИЕ RAILSГолубев ПавелИюнь 2009
20 июня 2009 г.
МАСШТАБИРОВАНИЕ RAILSГолубев ПавелИюнь 2009
Кто-то еще пользуется gif?
20 июня 2009 г.
МАСШАТАБИРОВАНИЕ
ГоризантальноеУвеличение производительности системы за счет подключения дополнительных серверов.Функциональное разделение.Шардинг.
ВертикальноеУвеличение производительности за счет наращивания мощности
сервера.
20 июня 2009 г.
ОБЩИЕ РЕСУРСЫ
Статика— Файловая система— Организация кеша— Распределенная ФС
Application сервера— Как их незаметно деплоить
База данных— Большое количество записей— Функциональное разделение— Денормализация
Shared memory
20 июня 2009 г.
ОБЩИЕ РЕСУРСЫ
Статика— Файловая система— Организация кеша— Распределенная ФС
Application сервера— Как их незаметно деплоить
База данных— Большое количество записей— Функциональное разделение— Денормализация
Shared memory
Секретарша— Длительный рабочий день— Большая команда— Месячные
20 июня 2009 г.
СТАТИКА
Файловая системаМного маленьких файлов? Наш выбор — ReiserFS.
Древовидный кеш/users/g/o/lubeff.html вместо /users/golubeff.html
Распределенная файловая системаЖелезо и DFS
NFS хорош, но есть нюансы
20 июня 2009 г.
NFS
Пишем только из одного местаРельсы вообще не используем для генерации статики. Вместо этого пишем простенькие крон-таски.
Пишем из разных мест, читаем только с masterПроксирование по url на уровне nginx.
20 июня 2009 г.
КАК ДЕПЛОИТЬ
Вариат 1. Nginx
20 июня 2009 г.
КАК ДЕПЛОИТЬ
Вариат 2. No restart, baby!
20 июня 2009 г.
ОЧЕРЕДИ
Front-end:
Back-end:
20 июня 2009 г.
ОЧЕРЕДИ
Позволяет выполнить логику, не занимая railsПолучили запрос, отдали пустой ответ.Через несколько секунд вычислили ответ, сообщили поль-лю.
Забудь про reload
20 июня 2009 г.
ОЧЕРЕДИ
Слишком много задач в очереди?Запускаем множество демонов
20 июня 2009 г.
БАЗА ДАННЫХ
Выносим старые данные
Функциональное разбиение
20 июня 2009 г.
БАЗА ДАННЫХ
Денормализация
cardscharacters
storages
character_id
storage_id
20 июня 2009 г.
БАЗА ДАННЫХ
Денормализация
cardscharacters
storages
character_id
storage_idcharacter_id
20 июня 2009 г.
[email protected]Голубев Павел
20 июня 2009 г.