Today, I participated in the RubyKaigi Takeout 2020 online conference. It was the first large-scale developer conference that I ever took part in and I am very excited to share my experience with you.
What is RubyKaigi?
RubyKaigi is the largest conference for Ruby programmers held annually in Japan since 2006. Due to the nature of the Ruby ecosystem, a significant portion of the presentations and discussions are done in Japanese, but since the conference organizers understand the importance and size of the international community, all talks presented in Japanese are also available with an English interpretation.
This year, RubyKaigi was originally postponed, then cancelled, and finally converted into an online conference. That way, truly anyone could join the event.
Sessions available
This year, there were two “tracks” available: #rubykaigiA
with mostly Japanese speakers, and #rubykaigiB
with all
talks being done in English. After looking at the first day’s
schedule page and reading through the descriptions of each talks,
I mostly decided to follow the #rubykaigiA
track from the start and switch to the #rubykaigiB
track just before
lunch; though I definitely want to catch up on some of the talks that I had to skip – there was just way too much good
content available there (which, I suppose, is a very good problem to have 😅)!
Ractor Report by Koichi Sasada
The conference kicked off (after just a little bit of technical issues because as beloved Murphy would say, “everything that could go wrong, will go wrong”) with a status report by Sasada-san on Ractor (previously known as Guild). Ractor will provide Ruby with a parallelism model that provides many benefits compared to the thread-based model seen in many other programming languages.
Compared to thread-based concurrency, Ractors are thread-safe (meaning you should not be running into dreaded issues such race condition) and don’t share most objects – in fact, the only objects that are shareable are immutable objects, class/module objects and some special shareable objects. To send any other data between two Ractors, either a push-based (where target Ractor is known) or pull-based (where sender Ractor is known) must be used.
Each Ractor can use one or more threads, and in the demonstration showed by Sasada-san, it seemed that Ractors can utilize available hardware resources quite a bit better than traditional threads.
Type Profiler: a Progress Report of a Ruby 3 Type Analyzer by Yusuke Endoh
Endoh-san showed everyone the impressive work he’s done on Type Profiler (tentative name), a Ruby interpreter that
executes Ruby programs at the type level and tries to determine type information. This information is then stored in
rbs
files, which are Ruby 3’s rough equivalent to TypeScript’s d.ts
type information files.
data:image/s3,"s3://crabby-images/67739/6773917c8ef7dbbe55fc7e08d1ba5a570d57b117" alt="Type Profiler".
On sending methods by Urabe, Shyouhei
In this talk, viewers were taken on a magical journey that resembled a detective story: it all started with an unusual profiler’s output that didn’t make much sense. After digging deeper and deeper into the mystery, a culprit in Rails’ ActiveRecord library was found, causing Ruby’s method cache to evict entries that shouldn’t be evicted. After fixing the issue in Ruby 2.7, the performance of Ruby and Rails apps increased!
Reflecting on Ruby Reflection for Rendering RBIs by Ufuk Kayserilioglu
After switching to the #rubykaigiB
track, I was shown Ruby’s powerful capabilities when it comes to reflection and
the many intricacies that one must be aware of when trying to automatically analyze the source code of third-party
dependencies. The work done by Ufuk is used in the Tapioca project, which can
automatically generate type information for your project’s Gem dependencies.
data:image/s3,"s3://crabby-images/4e40c/4e40c9630fa24a5e061713aa7d28655a1436808b" alt="Ruby Reflection", I was at first unsure as to why that would be necessary in the world of Ruby where we don’t have to worry about obsolete web browsers that don’t support the latest and greatest versions of JavaScript.
data:image/s3,"s3://crabby-images/6dd4c/6dd4c9a81eb7a2018378691bd5d69ae5bfb50103" alt="Transpiling"
Milan Vít
Back-end & Infrastructure Engineer
Recently fascinated and intrigued by Elixir 🧪 and the magic of functional programming 🧙♂️✨