Vert.x — асинхронный, event-dirven фреймворк, созданный под влиянием node.js. Часть 1

от автора

Всем привет!
На данный момент очень трендово использовать node.js. Однако не всем он нравится. В данном обзоре, я бы хотел рассказать немного о конкуренте, который был написан под влиянием node.js
Vert.x это асинхронный, event-driven фреймворк, написанный под вилянием node.js.
Первая версия фрейворка, была выпущена в 2012 году, в то время как node.js был выпущен в 2009. Однако, уже поддерживается VMware и может запускаться на CloudFoundry.
Основные характеристики продукта под катом:

  • Мульти-язычный. Вы можете использовать JavaScript, Ruby, Groovy, Java,Python. Практически готова поддержка Scala and Closure
  • opensource. лицензия ASL 2.0
  • настоящий параллелизм, и высокая производительность
  • написан на java, и использует все прелести JVM, масштабируясь легко между ядрами, без необходимости заботиться об межпроцессорном взаимодействии
  • Использует Hazelcast — In-Memory Data Grid систему. Прозрачно для пользователя, естественно
  • Использует Netty
  • Супер простая модель параллелизма. Никаких synchronized or volatile, или явных блокировок
  • Никакой лапши xml конфигов. Все предельно просто
  • Модульная система, с общедоступным репозиторием
  • Распределенная шина сообщений, которая охватывает и сервер и клиент.
  • Доступна встраиваемая версия
  • По различным тестам, едва ли не самый производительный фреймворк, в своем классе
  • Требует JDK 1.7
  • WebSockets,SockJS поддержка

Интересно? Пример rest helloworld на scala:

class SampleResticle extends Resticle { override def handles = { GET("/hello")      :>  OK( _ => "world ") } } 

или же более простой пример сервера, обслуживающий webroot директорию. Пример на Groovy:

vertx.createHttpServer().requestHandler { req ->     def file = req.uri == "/" ? "index.html" : req.uri     req.response.sendFile "webroot/$file" }.listen(8080) 

Для того что бы запустить к примеру последний хеловорлд, вам необходимо выполнить:

vertx run Server.groovy -instances 32

Как видите все предельно просто и ясно.

Посмотрев примеры кода, и почитав принципы, я естественно решил проверить заявление авторов о супер производительности.Искал сравнения с node.js.
Первый график показывает результаты теста когда отдается только 200/ОК респонс

Второй тест отдает 72-байтную html страницу:

К сожалению данные тесты не содержат scala-тесты. Как известно, scala во многих случаях, оказывается быстрее java.
Пожалуй, для пятничного поста, этого достаточно. В следующей части расскажу об основных принципах и патернах используемых в vert.x.
Cайт проекта. По ссылке отличная документация.

ссылка на оригинал статьи http://habrahabr.ru/post/181686/


Комментарии

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

Ваш адрес email не будет опубликован. Обязательные поля помечены *