Hacker News new | past | comments | ask | show | jobs | submit login

Did we get JIT?



Yes, it was introduced in Ruby 2.6 (2018): https://www.ruby-lang.org/en/news/2018/12/25/ruby-2-6-0-rele...


Well, yes and no (althought the question is a bit open).

It's more or less beta quality, and very primitive. It's discouraged to be used with Rails, so I'd be inclined to state that "we didn't get it yet".

I'm also personally skeptical that the unusual approach (invoking a whole C compiler in a separate thread) will stand in the long term - but that's my own take.


The CRuby JIT is stable but whether it improves performance or not is workload dependent.

It's simple not primitive. MJIT is designed to take advantage of a C compilers optimization.

"Compile to C" worked for Chicken Scheme for the past 20 years and continues to be a popular way for functional langauges to compile. It's also how Nim works. It's all about different trade-offs.


Are there any benchmarks available? It seems I can find very little (OptCarrot, some microbenchmarks, and some general assessments about usage with Rails), and a broad(er) overview is crucial to assess the overall performance (I suppose that you can have workloads where the performance degrades).


Chicken Scheme compiles ahead of time, doesn't it?


Yeah but it's not an important distinction.


Isn't it? Compiling C takes time, with Ruby you would be doing it for each execution. Is there some catching involved?


Almost everything is in a pre-compiled header. Its actually similar overhead to an LLVM based JIT.

You wouldn’t want to do it for a browser JIT but for a server side app it’s OK.


Does Ruby ship with a compiler? How will this work on Windows?


Nim does too.


I wonder what happened to that old planned feature where the ruby code would be byte-compiled into .rbc files?


The capability is there since 2.3 at least, but Matz doesn't want it by default, and prefer to leave it to libraries.

If you use bootsnap, you use ".rbc" files already.

Source: https://bugs.ruby-lang.org/issues/16847#note-14


JRuby has a semi-optimizing JIT since JRuby 9000 was released in 2015. It's mostly non-speculative but still the fastest way to run Ruby in production. I've used it at several companies.




Consider applying for YC's Spring batch! Applications are open till Feb 11.

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: