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

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

(Batch edit: replace {{addconf-2011-videofile| with {{youtubelink|}} {{addconf-2011-videofile|)
(Batch edit: replace PCRE (\n\n)+(\n) with \2)
 
(не показано 39 промежуточных версий этого же участника)
== Аннотация ==
[[Категория:Александр Чистяков]]
;Докладчик: [[:Категория:Александр Чистяков{{Speaker|Александр Чистяков]]}}

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

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

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

{{vimeoembed|23900952|720|405}}

{{youtubelink|}}|AAVGy8OKqN8}}{{letscomment}}

{{addconf-2011-videofile|2b7-lamp-optimization-openx-chistyakov.avs.avi}}




<!-- == Подкаст ==
{{podfmembed|belonesox.podfm.ru/addconf/}} -->

<!-- == Презентация ==
[[Файл:Оптимизация LAMP-приложения на примере OpenX: разгоняемся до 1000 запросов в секунду (Александр Чистяков, ADD-2011).pdf|page=-|left|256px]]

 -->

== Примечания и отзывы ==
<!-- <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=2021-08-31T17:40:53.055956|vimeo_comments=0|vimeo_plays=292|youtube_comments=0|youtube_plays=14}}

[[Категория:ADD-2011]]
[[Категория: Программирование]]PHP]]
[[Категория:MySQL]]
[[Категория:Highload-архитектуры]]

Текущая версия на 12:22, 4 сентября 2021

Аннотация

Докладчик
Александр Чистяков.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:306   Comments:0