Праздничные котята от VK.com. kPHP – PHP со скоростью C++::Журнал СА 4.2014
www.samag.ru
     
Поиск   
              
 www.samag.ru    Web  0 товаров , сумма 0 руб.
E-mail
Пароль  
 Запомнить меня
Регистрация | Забыли пароль?
Журнал "Системный администратор"
Журнал «БИТ»
Наука и технологии
Подписка
Где купить
Авторам
Рекламодателям
Магазин
Архив номеров
Вакансии
Контакты
   

  Опросы

Какие курсы вы бы выбрали для себя?  

Очные
Онлайновые
Платные
Бесплатные
Я и так все знаю

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

1001 и 1 книга  
20.12.2019г.
Просмотров: 4349
Комментарии: 0
Dr.Web: всё под контролем

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

04.12.2019г.
Просмотров: 5651
Комментарии: 0
Особенности сертификаций по этичному хакингу

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

28.05.2019г.
Просмотров: 6881
Комментарии: 2
Анализ вредоносных программ

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

28.05.2019г.
Просмотров: 7272
Комментарии: 1
Микросервисы и контейнеры Docker

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

28.05.2019г.
Просмотров: 6345
Комментарии: 0
Django 2 в примерах

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

Друзья сайта  

Форум системных администраторов  

sysadmins.ru

 Праздничные котята от 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-41
Fax: (499) 277-12-45
E-mail: sa@samag.ru