Google выпустила Grumpy для трансляции кода Python на язык Go и лучшей производительности

Вчера компания Google сообщила о выпуске экспериментальной среды исполнения кода Python на языке Go, которая получила название Grumpy.

В инфраструктуре Google задействованы миллионы строк кода на Python. Например, frontend-сервер, обслуживающий youtube.com и различные API этого сервиса, в основном написаны на Python и обслуживают миллионы запросов в секунду. Фронтенд YouTube запущен на CPython 2.7, что привело инженеров Google к необходимости «выполнять огромную работу по улучшению исполняемой среды и адаптации приложения для оптимальной работы в этой среде». Несмотря на то, что их усилия приносили определённые результаты, постоянно возникала проблема производительности в CPython при обслуживании большого числа одновременных процессов. Для её решения были исследованы многие исполняемые среды Python: у каждой из них были обнаружены свои плюсы и минусы, но в итоге в Google пришли к необходимости созданию своей runtime, специально оптимизированной для задач реального времени. Так появился проект Grumpy.

Сравнение производительности CPython и Grumpy при масштабировании
Сравнение производительности CPython и Grumpy при масштабировании / Иллюстрация с сайта Google Open Source Blog

Grumpy от Google — это не просто ещё одна исполняемая среда (runtime) для Python, а транскомпилятор кода Python в код Go. Транслированные с помощью Grumpy приложения могут (без необходимости в дальнейшей модификации) запускаться в среде языка Go: «Для нас было необходимо обеспечить поддержку большой существующей кодовой базе Python, поэтому важно иметь высокую степень совместимости с CPython. Цель Grumpy — служить любому проекту, написанному на чистом Python, готовой заменой для среды исполнения».

У Grumpy есть некоторые ограничения — например, отсутствует поддержка модулей расширения к Python на языке Си. Но есть и примечательные достоинства — в частности, отсутствие глобальной блокировки интерпретатора и использование сбора мусора Go для управления жизненным циклом объектов (вместо подсчёта указателей). «Мы считаем, что у Grumpy есть потенциал более гладкого масштабирования, чем с CPython, для многих реальных нагрузок», — заявляют в Google, подтверждая своё мнение результатами одного из тестов производительности (см. иллюстрацию к новости).

Исходный код Grumpy написан на языках Python и Go, опубликован на GitHub на условиях свободной лицензии Apache License 2.0.

Дмитрий Шурупов по материалам Google Open Source Blog.




!

Если для Вас конкретно эта новость оказалась важной или интересной - пожалуйста, поделитесь ею в своей любимой социальной сети с помощью кнопок, расположенных под этим текстом. Это поможет нам в будущем делать более качественную подборку материалов, исходя из Ваших потребностей\интересов.




Коды для вставки в блог\форум

blog comments powered by Disqus


Вспомним другие новости из этого раздела?


Soft

«« ОС UNIX — 47 лет
31.12.2016 21:24
←+Ctrl+→

Интересные новости
Бесплатная школа программирования UNIT Factory запустила второй набор студентовБесплатная школа программирования UNIT Factory запустила второй набор студентов
Средняя выплата хакерам за «вирусы-вымогатели» превышает $1000. И люди готовы платитьСредняя выплата хакерам за «вирусы-вымогатели» превышает $1000. И люди готовы платить
Microsoft научилась запускать родные Linux-контейнеры на Windows Server с помощью Hyper-VMicrosoft научилась запускать родные Linux-контейнеры на Windows Server с помощью Hyper-V
Linkerd 1.0 ­— связующее звено для сервисов в облачной инфраструктуреLinkerd 1.0 ­— связующее звено для сервисов в облачной инфраструктуре
Linux Foundation запустила EdgeX Foundry для стандартизации интернета вещейLinux Foundation запустила EdgeX Foundry для стандартизации интернета вещей
Блок рекламы


Похожие новости

Пчелы против меда: Google, возможно, делает свой адблокер для Chrome
Эталонный компилятор языка D — DMD — лицензирован как Open SourceЭталонный компилятор языка D — DMD — лицензирован как Open Source
Apple выпустила первую публичную бета-версию macOS Sierra 10.12.5Apple выпустила первую публичную бета-версию macOS Sierra 10.12.5
Google запустила новый сайт со своими Open Source-проектами и связанной документациейGoogle запустила новый сайт со своими Open Source-проектами и связанной документацией
Kubernetes 1.6: первый релиз без менеджмента Google и с поддержкой 5000 нодKubernetes 1.6: первый релиз без менеджмента Google и с поддержкой 5000 нод
Google открыла код Guetzli для более компактных качественных JPEG-изображений в интернетеGoogle открыла код Guetzli для более компактных качественных JPEG-изображений в интернете
Cisco выпустила Contiv для гибкого управления сетями в Docker-контейнерахCisco выпустила Contiv для гибкого управления сетями в Docker-контейнерах
Upspin — новый Open Source-проект Google для безопасного обмена файлами по сетиUpspin — новый Open Source-проект Google для безопасного обмена файлами по сети
Google добавила в Open Source-проект Chromium код мобильного веб-браузера Chrome для iOSGoogle добавила в Open Source-проект Chromium код мобильного веб-браузера Chrome для iOS
Google Chrome начал предупреждать о небезопасных HTTP-страницахGoogle Chrome начал предупреждать о небезопасных HTTP-страницах
Последние новости

Подгружаем последние новости