Sounds fantastic! On Monday, February 29, 2016 at 4:13:53 PM UTC-5, Jim Crossley wrote: > > Sounds good, Dmitri. I'll work up something on a fork in the next few > days and ping you. We can go from there. > > Jim > > > On Mon, Feb 29, 2016 at 2:33 PM, Dmitri <dmitri....@gmail.com > <javascript:>> wrote: > > Hi Jim, > > > > I'm the author of Luminus, and I'd love tow work with you to tune up the > > performance. Feel free to ping me via email or on GitHub. > > > > > > On Sunday, February 28, 2016 at 8:17:13 PM UTC-5, Jim Crossley wrote: > >> > >> I just tried a few experiments and realized the :dispatch? option is > >> broken in the latest Immutant release. :( > >> > >> This is a result of some changes we made to better support WebSockets. > >> > >> We were already hoping to get a release out this week, so we'll add > that > >> to the list of fixes. > >> > >> Sorry about that, > >> Jim > >> > >> On Sunday, February 28, 2016 at 1:32:09 PM UTC-5, Jim Crossley wrote: > >>> > >>> Hi, > >>> > >>> Luminus uses Immutant, which uses Undertow, so it should be possible > >>> to tune the Luminus app to approach the performance of the TechEmpower > >>> Undertow app. The relevant options to immutant.web/run [1] are > >>> :dispatch?, :io-threads, and :worker-threads. > >>> > >>> The Undertow app sets IO threads here [2] and worker threads here [3], > >>> so you can easily set those same values in the Luminus app. > >>> > >>> But the real performance bump will come from the :dispatch? option. By > >>> default, :dispatch? is true, i.e. requests handled by threads in the > >>> IO pool are dispatched to a thread in the worker pool. For > >>> compute-bound tasks like the JSON serialization benchmark, that > >>> context switch is far more expensive than just having the IO thread > >>> return the response. So you'd want to set :dispatch? to false in that > >>> case. > >>> > >>> The tricky bit here is that the Luminus app defines all its routes in > >>> a single handler [4]. But for the more io-bound tasks, e.g. > >>> DbSqlHandler [5], you'll want the default true value of :dispatch?. So > >>> in order to get the best results for all the benchmarks, you'll need > >>> to re-organize that app to run two handlers: one that dispatches and > >>> one that doesn't. In Immutant, the simplest way to do this is to > >>> distinguish each handler with a unique :path option. > >>> > >>> I'm happy to assist whoever is maintaining that app with the tuning. > >>> > >>> Thanks, > >>> Jim > >>> > >>> [1] > >>> > http://immutant.org/documentation/current/apidoc/immutant.web.html#var-run > >>> [2] > >>> > https://github.com/TechEmpower/FrameworkBenchmarks/blob/master/frameworks/Java/undertow/src/main/java/hello/HelloWebServer.java#L122 > > >>> [3] > >>> > https://github.com/TechEmpower/FrameworkBenchmarks/blob/master/frameworks/Java/undertow/src/main/java/hello/HelloWebServer.java#L160 > > >>> [4] > >>> > https://github.com/TechEmpower/FrameworkBenchmarks/blob/master/frameworks/Clojure/luminus/hello/src/hello/routes/home.clj#L44 > > >>> [5] > >>> > https://github.com/TechEmpower/FrameworkBenchmarks/blob/master/frameworks/Java/undertow/src/main/java/hello/DbSqlHandler.java#L38 > > >>> > >>> On Sat, Feb 27, 2016 at 9:40 PM, gvim <gvi...@gmail.com> wrote: > >>> > In the latest round of Techempower benchmarks: > >>> > > >>> > > >>> > > https://www.techempower.com/benchmarks/#section=data-r12&hw=peak&test=json > >>> > > >>> > ... I was surprised to find Luminus performing no better than Hapi > >>> > (Node) > >>> > and significantly worse than Java frameworks. Figures are > >>> > requests/second: > >>> > > >>> > FORTUNES > >>> > - Hapi: 1.9 > >>> > - Luminus: 0.9 > >>> > - Gemini: 55.5 > >>> > > >>> > JSON SERIALISATION > >>> > - Hapi: 0.3 (Raw db) > >>> > - Luminus: 0.8 > >>> > - Rapidoid: 78.4 > >>> > > >>> > > >>> > SINGLE QUERY > >>> > - Hapi: 2.9 > >>> > - Luminus: 8.7 > >>> > - Gemini: 75.8 > >>> > > >>> > MULTI-QUERY > >>> > - Hapi: 33.0 > >>> > - Luminus: 20.4 > >>> > - Dropwizard: 65.8 > >>> > > >>> > DATA UPDATES > >>> > - Hapi: 20.9 > >>> > - Luminus: 20.0 > >>> > - Ninja: 54.7 > >>> > > >>> > PLAINTEXT > >>> > - Hapi: 0.7 > >>> > - Luminus: 0.0 > >>> > - Rapidoid: 100.0 > >>> > > >>> > > >>> > > >>> > Any ideas? > >>> > > >>> > gvim > >>> > > >>> > > >>> > > >>> > > >>> > > >>> > > >>> > > >>> > > >>> > -- > >>> > You received this message because you are subscribed to the Google > >>> > Groups "Clojure" group. > >>> > To post to this group, send email to clo...@googlegroups.com > >>> > Note that posts from new members are moderated - please be patient > with > >>> > your > >>> > first post. > >>> > To unsubscribe from this group, send email to > >>> > clojure+u...@googlegroups.com > >>> > For more options, visit this group at > >>> > http://groups.google.com/group/clojure?hl=en > >>> > --- You received this message because you are subscribed to the > Google > >>> > Groups "Clojure" group. > >>> > To unsubscribe from this group and stop receiving emails from it, > send > >>> > an > >>> > email to clojure+u...@googlegroups.com. > >>> > For more options, visit https://groups.google.com/d/optout. > > > > -- > > You received this message because you are subscribed to the Google > > Groups "Clojure" group. > > To post to this group, send email to clo...@googlegroups.com > <javascript:> > > Note that posts from new members are moderated - please be patient with > your > > first post. > > To unsubscribe from this group, send email to > > clojure+u...@googlegroups.com <javascript:> > > For more options, visit this group at > > http://groups.google.com/group/clojure?hl=en > > --- > > You received this message because you are subscribed to the Google > Groups > > "Clojure" group. > > To unsubscribe from this group and stop receiving emails from it, send > an > > email to clojure+u...@googlegroups.com <javascript:>. > > > > For more options, visit https://groups.google.com/d/optout. >
-- You received this message because you are subscribed to the Google Groups "Clojure" group. To post to this group, send email to clojure@googlegroups.com Note that posts from new members are moderated - please be patient with your first post. To unsubscribe from this group, send email to clojure+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/clojure?hl=en --- You received this message because you are subscribed to the Google Groups "Clojure" group. To unsubscribe from this group and stop receiving emails from it, send an email to clojure+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.