logoalt Hacker News

jeyjeyememlast Thursday at 6:15 PM2 repliesview on HN

Emissary is a simple-to-use, no dependency, yet BLAZING FAST messaging library for decoupling messages (requests and events) and message handlers.

Emissary aims to take advantage of the simplicity of using the annotations for handlers (e.g. @RequestHandler/@EventHandler) without the drawbacks of reflection (slow).

What differentiates Emissary from other messaging/dispatch libraries? It takes advantage of java.lang.invoke.LambdaMetafactory to avoid the cost of invoking methods reflectively. This results in performance close to directly invoking the request handler and event handler methods.

~ 1000% more throughput compared to other similar libraries (Spring's ApplicationEventPublisher, Pipelinr, EventBus) ~ 90% faster compared to other similar libraries (Spring's ApplicationEventPublisher, Pipelinr, EventBus)

Benchmarks found on the GitHub repository: https://github.com/joel-jeremy/emissary?tab=readme-ov-file#p...


Replies

azornathogrontoday at 9:46 AM

Assuming that you are the author of Emissary, this could be a Show HN, I think.

https://news.ycombinator.com/showhn.html

show 1 reply
throw_away_623today at 2:17 PM

Are you planning to add persistent events as well, so that events are not lost due to crashes