WedX - журнал о программировании и компьютерных науках

Веб-сервер Racket, работающий в асинхронном режиме (на основе событий)

Я планирую разрабатывать сервисы на основе REST, используя Racket и его веб-сервер. Одно требование, которое у меня есть, — это веб-сервер, работающий в асинхронном режиме (неблокирующий, основанный на событиях).

Есть ли пример настройки или настройки веб-сервера Racket для работы в асинхронном режиме?

Я просмотрел документацию Racket, но не могу понять, как это сделать.

09.09.2013

  • Является ли ваше требование действительно конкретной реализацией, например, неблокирующей, основанной на событиях? Или это требование к производительности, такое как X запросов в секунду? Я спрашиваю, потому что AFAIK поставляемый racket/web-server использует потоки Racket (которые представляют собой легкие зеленые потоки, а не потоки ОС). Вы можете попробовать это, посмотреть, соответствует ли оно вашим требованиям к производительности. (Сказав это, Racket допускает неблокирующий ввод-вывод, поэтому я полагаю, что вы могли бы развернуть свой собственный сервер REST, если считаете, что реализация является основным соображением.) 09.09.2013
  • На данный момент это требование является особенностью спецификации. Я протестирую веб-сервер Racket, чтобы увидеть, сколько запросов он может обрабатывать в секунду, и сравнить это со Scala + Play Framework. 10.09.2013

Ответы:


1

Я автор веб-сервера Racket. Он всегда находится в асинхронном режиме. Как упоминает Грег, он использует потоки Racket, которые компилируются в продолжения, а когда вы выполняете блокирующие операции ввода-вывода, они сохраняются в структуре данных, связанной с заблокированным портом, который опрашивается с помощью kpoll/kqueue/etc, точно так же, как написанный вручную асинхронный IO серверы.

09.12.2015
Новые материалы

Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что это выглядит сложно…
Просто начните и учитесь самостоятельно Я хотел выучить язык программирования MVC4, но не мог выучить его раньше, потому что он кажется мне сложным, и я бросил его. Это в основном инструмент..

Лицензии с открытым исходным кодом: руководство для разработчиков и создателей
В динамичном мире разработки программного обеспечения открытый исходный код стал мощной парадигмой, способствующей сотрудничеству, инновациям и прогрессу, движимому сообществом. В основе..

Объяснение документов 02: BERT
BERT представил двухступенчатую структуру обучения: предварительное обучение и тонкая настройка. Во время предварительного обучения модель обучается на неразмеченных данных с помощью..

Как проанализировать работу вашего классификатора?
Не всегда просто знать, какие показатели использовать С развитием глубокого обучения все больше и больше людей учатся обучать свой первый классификатор. Но как только вы закончите..

Работа с цепями Маркова, часть 4 (Машинное обучение)
Нелинейные цепи Маркова с агрегатором и их приложения (arXiv) Автор : Бар Лайт Аннотация: Изучаются свойства подкласса случайных процессов, называемых дискретными нелинейными цепями Маркова..

Crazy Laravel Livewire упростил мне создание электронной коммерции (панель администратора и API) [Часть 3]
Как вы сегодня, ребята? В этой части мы создадим CRUD для данных о продукте. Думаю, в этой части я не буду слишком много делиться теорией, но чаще буду делиться своим кодом. Потому что..

Использование машинного обучения и Python для классификации 1000 сезонов новичков MLB Hitter
Чему может научиться машина, глядя на сезоны новичков 1000 игроков MLB? Это то, что исследует это приложение. В этом процессе мы будем использовать неконтролируемое обучение, чтобы..


Для любых предложений по сайту: [email protected]