www.samag.ru
     
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Подписка
Архив номеров
Где купить
Авторам
Рекламодателям
Контакты
   

  Опросы
1001 и 1 книга  
19.03.2018г.
Просмотров: 10866
Комментарии: 0
Машинное обучение с использованием библиотеки Н2О

 Читать далее...

12.03.2018г.
Просмотров: 10972
Комментарии: 0
Особенности киберпреступлений в России: инструменты нападения и защита информации

 Читать далее...

12.03.2018г.
Просмотров: 8442
Комментарии: 0
Глубокое обучение с точки зрения практика

 Читать далее...

12.03.2018г.
Просмотров: 5155
Комментарии: 0
Изучаем pandas

 Читать далее...

12.03.2018г.
Просмотров: 6000
Комментарии: 0
Программирование на языке Rust (Цветное издание)

 Читать далее...

19.12.2017г.
Просмотров: 5925
Комментарии: 0
Глубокое обучение

 Читать далее...

19.12.2017г.
Просмотров: 8749
Комментарии: 0
Анализ социальных медиа на Python

 Читать далее...

19.12.2017г.
Просмотров: 5323
Комментарии: 0
Основы блокчейна

 Читать далее...

19.12.2017г.
Просмотров: 5568
Комментарии: 0
Java 9. Полный обзор нововведений

 Читать далее...

16.02.2017г.
Просмотров: 9744
Комментарии: 0
Опоздавших не бывает, или книга о стеке

 Читать далее...

17.05.2016г.
Просмотров: 13137
Комментарии: 0
Теория вычислений для программистов

 Читать далее...

30.03.2015г.
Просмотров: 14610
Комментарии: 0
От математики к обобщенному программированию

 Читать далее...

18.02.2014г.
Просмотров: 16351
Комментарии: 0
Рецензия на книгу «Читаем Тьюринга»

 Читать далее...

13.02.2014г.
Просмотров: 11235
Комментарии: 0
Читайте, размышляйте, действуйте

 Читать далее...

12.02.2014г.
Просмотров: 9198
Комментарии: 0
Рисуем наши мысли

 Читать далее...

10.02.2014г.
Просмотров: 7465
Комментарии: 4
Страна в цифрах

 Читать далее...

18.12.2013г.
Просмотров: 6574
Комментарии: 0
Большие данные меняют нашу жизнь

 Читать далее...

18.12.2013г.
Просмотров: 5482
Комментарии: 0
Компьютерные технологии – корень зла для точки роста

 Читать далее...

04.12.2013г.
Просмотров: 5100
Комментарии: 0
Паутина в облаках

 Читать далее...

03.12.2013г.
Просмотров: 5380
Комментарии: 1
Рецензия на книгу «MongoDB в действии»

 Читать далее...

Друзья сайта  

 Праздничные котята от VK.com. kPHP – PHP со скоростью C++

Архив номеров / 2014 / Выпуск №4 (137) / Праздничные котята от VK.com. kPHP – PHP со скоростью C++

Рубрика: Разработка /  Веб-технологии

Александр Календарев АЛЕКСАНДР КАЛЕНДАРЕВ, программист, РБК Медиа, akalend@mail.ru

Праздничные котята от VK.com
kPHP – PHP со скоростью C++

В преддверии Международного женского дня проект ВКонтакте открыл исходные коды своих внутренних разработок. Очевидно, таким образом решили преподнести праздничный подарок всем женщинам-программисткам. Исторически сложилось, что все продукты имеют префикс kitten, так что речь пойдет о разных котятах

Центральное и наиболее обсуждаемое решение – это PHP-котята (kitten-PHP), или сокращенно kPHP. Так разберемся, что же это за зверь – PHP-котята? Это транслятор кода с языка PHP в язык С++. По сообщению представителей VK, данной разработкой они занимаются с 2010 года.

ВКонтакте – это проект с почти 10-летней историей, и его разработка велась тогда еще на РНР3. Как правило, уже действующие и приносящие прибыль проекты не переписываются, а только дополняются новыми функциональными возможностями. А при дополнении наиболее целесообразно писать код в общепринятом стиле и использовать существующее API. Из этого можно сделать вывод, что над миграцией кода на более новые версии долгое время особо незадумывались.

Проект рос, и в какой-то момент перевалил за 50 млн суточной посещаемости пользователей. По некоторой информации, сейчас новый дата-центр VK рассчитан на 25 тыс. серверов. Если как-то и можно сократить число серверов хотя бы на 10%, то при таких количествах это уже экономически выгодно. Очевидно, после неудачных попыток использования HHVM (о HHVM будет рассказано ниже), что представители VK не отрицают, было принято решение изобрести собственный велосипед.

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

Рисунок 1. Среднее время загрузки страниц

Рисунок 1. Среднее время загрузки страниц

Коротко о технологии. Исходный код ВКонтакте с помощью транслятора kPHP транслируется в C++. После этого сгенерированный C++ код автоматически компилируется средствами gcc, в результате чего получается исполняемый файл, готовый для запуска.

В зависимости от опций компиляции исполняемый файл может быть представлен как специализируемый веб-сервер, принимающий http-запросы и генерирующий страницы.

Статью целиком читайте в журнале «Системный администратор», №4 за 2014 г. на страницах 54-57.


Комментарии отсутствуют

Добавить комментарий

Комментарии могут оставлять только зарегистрированные пользователи

               Copyright © Системный администратор

Яндекс.Метрика
Tel.: (499) 277-12-45
E-mail: sa@samag.ru