ТЕХНОЛОГИИ ОН-ЛАЙН ОБЩЕНИЯ
FACEBOOK 9-КРАТНО УСКОРЯЕТ ЯЗЫК РАЗРАБОТКИ PHP
6 Октября 2013
Социальная сеть Facebook продолжает работать с популярной средой веб-разработки PHP, добиваясь ускорения ее работы на существующем оборудовании. Накануне в Facebook сообщили, что разработали PHP Virtual Machine, которая может выполнять инструкции на языке PHP до 9 раз быстрее, чем обычный интерпретатор PHP. "Наша цель - сделать PHP действительно быстрым", - говорит инженер Facebook Джоэль Побар.
Ранее компания Facebook уже применяла разные трюки для ускорения работы PHP и повышения его масштабируемости. Так, была создана виртуальная машина HipHop, которая до начала этого года активно использовалась на серверах Facebook.
PHP представляет собой интерпретируемый язык, то есть его исходный код преобразуется и выполняется напрямую процессором компьютера. В общем случае это значит, что интерпретируемые языки не транслируются в бинарные структуры и не могут выполняться также быстро, как низкоуровневые языки, такие как C или C++, однако по всему миру очень много поклонников PHP, так как этот язык прост в конструкции и обладает богатыми возможностями.
Чтобы облегчить работу с PHP на высоконаргуженных проектах, таких как Facebook, был создан интерпретатор HipHop, который транслировал PHP в C++код, чтобы тот выполнялся процессором быстрее. В Facebook говорят, что до недавнего времени их устраивал HipHop, однако с ростом базы пользователей и он перестал справляться с обслуживанием более чем миллиарда пользователей.
Новая виртуальная машина PHP является развитием HipHop и работает по принципу Just-in-time компилятора. Она на лету конвертирует PHP-код в байткод и сохраняет наиболее востребованные откомпилированные фрагменты в памяти для их скорейшего вызова по необходимости. По похожему алгоритму работает и Java-среда на сервере.
Компания уже разместила исходники виртуальной машины на ресурсе GitHub.
"Just-in-time позволяет виртуальной машине принимать более умные решения. К примеру, если в PHP происходит вызов MySQL, то компилятор сам определяет тип выдаваемых данных, после чего он генерирует или вызывает код, который наилучшим образом подходит для обработки подобных типов данных", - говорит Побар.
При этом, в Facebook говорят, что хотя компилятор достаточно умен, чтобы понять типы данных или понять, какие части кода лучше держать наготове, полный успех все-таки зависит от особенностей реализации кода руками программиста. Использование виртуальной машины целесообразно на больших проектах с высоким уровнем динамической генерации данных.
CyberSecurity
ЕЩЕ ПО ТЕМЕ:
НОВАЯ МОБИЛЬНАЯ СЕТЬ ПЕРЕДАЧИ ДАННЫХ - HSPA EVOLUTION
30.11.2013Компания Ericsson и мобильный оператор 3 Italia протестировали новую мобильную сеть передачи данных - HSPA Evolution, сообщает Лента со ссылкой на PC World. Скорость передачи данных к абоненту в ней достигла 14,4 мегабит в секунду, от абонента - 5,8 мегабит в секунду.
ЧТО ДОЛЖЕН УЧИТЫВАТЬ СИСТЕМНЫЙ АНАЛИТИК УЧАСТВУЮЩИЙ В РАЗВИТИЕ INTEGRATION BUS (С БЛАГОДАРНОСТЬЮ ПАШЕ МАЛЮТИНУ И ЭНДИ ПИПЕРУ)
6.09.2013Смотрю на мир и не перестаю удивляться. Есть два монстра по MB. Ну ладно один западник, до него не достучаться, но второй уже который год тусуется в российском IBMе, и практически всегда готов к пивным встречам J Так вот со вторым всегда можно договориться он обязательно поможет, вот такой он человек. И ГЛАВНОЕ лучше него про Message Broker сказать никто не сможете, ну кроме Энди. Так вот эта сладкая парочка уже давно пишет везде и повсюду как правильно создавать код под MB. Но наши системные интеграторы идут своим , небезопасным для клиента путем. Путем тернистым...
АРТЕМ БОНДАРЬ, GENIUS: "GX GAMING - "ЗАТОЧЕННЫЕ" ИСКЛЮЧИТЕЛЬНО ПОД ИГРЫ"
7.10.2013Продукт- и маркетинг-менеджер Genius в Украине раскрывает секреты готовящейся к анонсу игровой линейки устройств GX Gaming.
TOSHIBA 3.5-INCH EXTERNAL HDD
28.10.2013НАЧАЛО ПРОДАЖ: август 2009 ПРИМЕРНАЯ ЦЕНА: 5000 руб. АЛЬТЕРНАТИВЫ: Seagate Expansion, Seagate FreeAgent ...


