Оптимизация LAMP-приложения на примере OpenX: разгоняемся до 1000 запросов в секунду (Александр Чистяков, ADD-2011) — различия между версиями

Материал из 0x1.tv

== Примечания и отзывы ==
<!-- <blockquote>[©]</blockquote> -->
* [http://addconf.ru/event.sdf/ru/add_2011/authors/AlexanderChistyakov/372 страничка доклада на сайте конференции]

<blockquote>Александр Чистяков рассказал об опыте оптимизации производительности в условиях политического давления :). [http://outcorp-ru.blogspot.com/2011/05/application-developer-days-2011.html ©]</blockquote>

<blockquote>Александр Чистяков полгода оптимизировал php-приложение, не меняя его код. Очень сжатый и по существу доклад, построенный по принципу серии доктора Хауса. [http://tonsky.livejournal.com/230112.html ©]</blockquote>

<blockquote>Выступление Александра Чистякова с разгоном LAMP до второй космической скорости вообще целиком состояло из трюков и ощущалось как детективный сериал «Спрут». То мы их, то они нас,  и таких двести итераций. Интересно, но несколько однообразно. [http://ptiz-kem.livejournal.com/67244.html ©]</blockquote>


* {{libcustis-review|ADD 2011: Отчет Василия Маслова/Оптимизация LAMP-приложения на примере OpenX}}


<references/>




{{stats|disqus_comments=0|refresh_time=2017-12-21T17:41:3925T22:02:32.220651520985|vimeo_comments=0|vimeo_plays=2845|youtube_comments=0|youtube_plays=10}}

[[Категория:ADD-2011]]
[[Категория:LAMP]]
[[Категория:PHP]]

Версия 19:02, 25 декабря 2017

Аннотация

Докладчик
Александр Чистяков.jpg
Александр Чистяков

Типичная ситуация: имеется существующий веб-проект, написанный с применением Linux, Apache, MySQL и PHP, и заказчик хочет сделать проект быстрее с наиболее полным сохранением функциональности.

В данном случае в качестве существующего проекта выступает open source баннерная платформа OpenX, и существенное требование заказчика — разогнать OpenX до пиковой нагрузки в 1000 запросов в секунду и долговременной нагрузки в 600 запросов в секунду.

Постановка задачи: отдача JavaScript-баннеров с заданными параметрами производительности при заданном числе объектов системы.


  • Краткий обзор объектов предметной области OpenX: баннеры, кампании, зоны.
  • Особенности OpenX: подходы к оптимизации, предлагаемые производителем, несколько раундов оптимизации уже было.
  • Проблемы: алгоритм скрипта выбора баннеров плохо работает при требуемом количестве объектов, имеем CPU-bound систему (обычно IO-bound).
  • Решение: кэширование предрассчитанных данных в БД.
  • Новые вводные от заказчика, поиск компромисса.
  • Сбор информации о системе: точки профилирования в коде скрипта, мониторинг с помощью Cacti и Zabbix.
  • Архитектура системы: типы узлов и связи между узлами. Балансирование нагрузки: nginx vs. HAProxy.
  • Действия после перенесения нагрузки на уровень БД: кэширование в памяти, проблема: много записи на диск.
  • MySQL vs MySQL (выбор движка хранилища), MySQL vs MySQL (выбор сборки: stock, Percona Server, MariaDB), MySQL vs PostgreSQL, MySQL vs in-memory RDBMS, MySQL vs NoSQL.
  • Тюнинг MySQL: параметры конфигурации, параметры платформы (файловая система).
  • Нагрузочное тестирование: как получить 1000 rps от клиента? siege vs JMeter vs Tsung.
  • Эволюция архитектуры. Поиск возможностей шардирования данных.
  • Отказоустойчивость: memcached, moxi, Membase.
  • Управление конфигурацией: проблема развертывания нод и управления нодами.
  • Использование Puppet для управления конфигурацией.

Видео

on youtube





Примечания и отзывы

Александр Чистяков рассказал об опыте оптимизации производительности в условиях политического давления :). ©
Александр Чистяков полгода оптимизировал php-приложение, не меняя его код. Очень сжатый и по существу доклад, построенный по принципу серии доктора Хауса. ©
Выступление Александра Чистякова с разгоном LAMP до второй космической скорости вообще целиком состояло из трюков и ощущалось как детективный сериал «Спрут». То мы их, то они нас, и таких двести итераций. Интересно, но несколько однообразно. ©





Plays:295   Comments:0