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

в 16:55, , рубрики: async, java, javascript, node.js, vert.x, метки: , ,

Всем привет!
На данный момент очень трендово использовать 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/ОК респонс
Vert.x — асинхронный, event driven фреймворк, созданный под влиянием node.js. Часть 1
Второй тест отдает 72-байтную html страницу:
Vert.x — асинхронный, event driven фреймворк, созданный под влиянием node.js. Часть 1
тесты взяты отсюда. Данные тесты проводились относительно давно. У меня готовы материалы более детального тестирования. Расскажу о нем в третьей части.
К сожалению данные тесты не содержат scala-тесты. Как известно, scala во многих случаях, оказывается быстрее java.
Пожалуй, для пятничного поста, этого достаточно. В следующей части расскажу об основных принципах и патернах используемых в vert.x.
Cайт проекта. По ссылке отличная документация.

Автор: sneer

Источник


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js