From Fedora Project Wiki
(Editing Change for F40)
(adding release notes tracker)
 
(4 intermediate revisions by 2 users not shown)
Line 43: Line 43:
* [https://discussion.fedoraproject.org/t/f40-chnage-proposal-ruby-3-3-system-wide/94990 Discussion thread]
* [https://discussion.fedoraproject.org/t/f40-chnage-proposal-ruby-3-3-system-wide/94990 Discussion thread]
* FESCo issue: [https://pagure.io/fesco/issue/3102 #3102]
* FESCo issue: [https://pagure.io/fesco/issue/3102 #3102]
* Tracker bug: <will be assigned by the Wrangler>
* Tracker bug: [https://bugzilla.redhat.com/show_bug.cgi?id=2251105 #2251105]
* Release notes tracker: <will be assigned by the Wrangler>
* Release notes tracker: [https://pagure.io/fedora-docs/release-notes/issue/1079 #1079]
 
== Detailed Description ==
== Detailed Description ==
<!-- Expand on the summary, if appropriate.  A couple sentences suffices to explain the goal, but the more details you can provide the better. -->
<!-- Expand on the summary, if appropriate.  A couple sentences suffices to explain the goal, but the more details you can provide the better. -->
Ruby 3.3 is upstream's new major release of Ruby. Ruby 3.3 adds a new pure-Ruby JIT compiler named RJIT, uses Lrama as a parser generator, and many performance improvements especially YJIT.
Ruby 3.3 is upstream's new major release of Ruby. Ruby 3.3 adds a new parser named Prism, uses Lrama as a parser generator, adds a new pure-Ruby JIT compiler named RJIT, and many performance improvements especially YJIT.


=== RJIT ===
=== Prism ===


* Introduced a pure-Ruby JIT compiler RJIT and replaced MJIT.
* Introduced the Prism parser as a default gem
** RJIT supports only x86_64 architecture on Unix platforms.
** Prism is a portable, error tolerant, and maintainable recursive descent parser for the Ruby language
** Unlike MJIT, it doesn’t require a C compiler at runtime.
* Prism is production ready and actively maintained, you can use it in place of Ripper
* RJIT exists only for experimental purposes.
** There is extensive documentation on how to use Prism
** You should keep using YJIT in production.
* Prism is both a C library that will be used internally by CRuby and a Ruby gem that can be used by any tooling which needs to parse Ruby code
* You can now use `ruby --parser=prism` or `RUBYOPT="--parser=prism"` to experiment with the Prism compiler. Please note that this flag is for debugging only.


=== Use Lrama instead of Bison ===
=== Use Lrama instead of Bison ===
Line 68: Line 68:
** Registers are allocated for stack operations of the virtual machine.
** Registers are allocated for stack operations of the virtual machine.
** More calls with optional arguments are compiled.
** More calls with optional arguments are compiled.
** Exception handlers are also compiled.
** Instance variables no longer exit to the interpreter with megamorphic Object Shapes.
** Unsupported call types no longer exit to the interpreter.
** Unsupported call types no longer exit to the interpreter.
** Basic methods like Rails `#blank?` and specialized `#present?` are inlined.
** `Integer#!=`, `String#!=`, `Kernel#block_given?`, `Kernel#is_a?`, `Kernel#instance_of?`, `Module#===` are specially optimized.
** `Integer#!=`, `String#!=`, `Kernel#block_given?`, `Kernel#is_a?`, `Kernel#instance_of?`, `Module#===` are specially optimized.
** Now more than 3x faster than the interpreter on optcarrot!
** Compilation speed is now slightly faster than Ruby 3.2.
* Metadata for compiled code uses a lot less memory.
** Now more than 3x faster than the interpreter on Optcarrot!
* Generate more compact code on ARM64
* Significantly improved memory usage over Ruby 3.2
* Option to start YJIT in paused mode and then later enable it manually
** Metadata for compiled code uses a lot less memory.
** `--yjit-pause` and `RubyVM::YJIT.resume`
** More compact code is generated on Arm64.
** This can be used to enable YJIT only once your application is done booting
* Code GC is now disabled by default
* `ratio_in_yjit` stat produced by `--yjit-stats` is now available in release builds, a special stats or dev build is no longer required.
* Add `RubyVM::YJIT.enable` that can enable YJIT at run-time
* Exit tracing option now supports sampling
** You can start YJIT without modifying command-line arguments or environment variables. Rails 7.2 will enable YJIT by default using this method.
** `--trace-exits-sample-rate=N`
** This can also be used to enable YJIT only once your application is done booting. `--yjit-disable` can be used if you want to use other YJIT options while disabling YJIT at boot.
* More YJIT stats are available by default
* Add more profiling capabilities
* More thorough testing and multiple bug fixes
* More thorough testing and multiple bug fixes
=== RJIT ===
* Introduced a pure-Ruby JIT compiler RJIT and replaced MJIT.
** RJIT supports only x86_64 architecture on Unix platforms.
** Unlike MJIT, it doesn’t require a C compiler at runtime.
* RJIT exists only for experimental purposes.
** You should keep using YJIT in production.
=== M:N thread scheduler ===
* M:N thread scheduler was introduced.
** M Ruby threads are managed by N native threads (OS threads) so the thread creation and management cost are reduced.
** It can break C-extension compatibility so that M:N thread scheduler is disabled on the main Ractor by default.
** `RUBY_MAX_CPU=n` environment variable sets maximum number of N (maximum number of native threads). The default value is 8.
*** Since only one Ruby thread per Ractor can run at the same time, the number of native threads will be used, which is the smaller of the number specified in `RUBY_MAX_CPU` and the number of running Ractors. So that single Ractor applications (most of applications) will only use 1 native thread.
*** To support blocking operations, more than `N` native threads can be used.
=== Performance improvements ===
* `defined?(@ivar)` is optimized with Object Shapes.
* Name resolution such as Socket.getaddrinfo can now be interrupted (in environments where pthreads are available).
* Several performance improvements to the Garbage Collector


=== Other notable changes since 3.2 ===
=== Other notable changes since 3.2 ===


* Performance improvements
** `defined?(@ivar)` is optimized with Object Shapes.
* IRB has received several enhancements, including but not limited to:
* IRB has received several enhancements, including but not limited to:
** Advanced `irb:rdbg` integration that provides an equivalent debugging experience to `pry-byebug`.
** Advanced `irb:rdbg` integration that provides an equivalent debugging experience to `pry-byebug`.
** Pager support for commands like `ls` and `show_cmds`.
** Pager support for `ls`, `show_source` and `show_cmds` commands.
** More accurate and helpful information provided by the `ls` and `show_source` commands.
** More accurate and helpful information provided by the `ls` and `show_source` commands.
** Experimental autocompletion using type analysis
* ext/readline is retired
* ext/readline is retired
** Replaced by `reline` that is pure Ruby implementation compatible with `ext/readline` API.
** Replaced by `reline` that is pure Ruby implementation compatible with `ext/readline` API.
* RubyGems and Bundler warn if users require gem that is scheduled to become the bundled gems in the future version of Ruby.
* RubyGems and Bundler warn if users require gem that is scheduled to become the bundled gems in the future version of Ruby.


Line 218: Line 244:
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
<!-- REQUIRED FOR SYSTEM WIDE CHANGES -->
* [http://www.ruby-doc.org/ Help and documentation for the Ruby programming language]
* [http://www.ruby-doc.org/ Help and documentation for the Ruby programming language]
* [https://github.com/ruby/ruby/blob/master/NEWS.md Ruby 3.3.0 NEWS]
* [https://github.com/ruby/ruby/blob/ruby_3_3/NEWS.md Ruby 3.3.0 NEWS]
* [https://www.ruby-lang.org/en/news/2023/09/14/ruby-3-3-0-preview2-released/ Ruby 3.3.0-preview2 release announcement]
* [https://www.ruby-lang.org/en/news/2023/12/25/ruby-3-3-0-released/ Ruby 3.3.0 release announcement]


== Release Notes ==
== Release Notes ==
Line 230: Line 256:
* The Ruby 3.3 bumps soname, therefore Ruby packages, which use binary extensions, should be rebuilt. Nevertheless, since upstream paid great attention to source compatibility, no changes to your code are needed.
* The Ruby 3.3 bumps soname, therefore Ruby packages, which use binary extensions, should be rebuilt. Nevertheless, since upstream paid great attention to source compatibility, no changes to your code are needed.


https://github.com/ruby/ruby/blob/master/NEWS.md
https://github.com/ruby/ruby/blob/ruby_3_3/NEWS.md

Latest revision as of 20:07, 28 February 2024


Ruby 3.3

Summary

Ruby 3.3 is the latest stable version of Ruby. Many new features and improvements are included for the increasingly diverse and expanding demands for Ruby. With this major update from Ruby 3.2 in Fedora 39 to Ruby 3.3 in Fedora 40, Fedora becomes the superior Ruby development platform.

Owner

Current status

Detailed Description

Ruby 3.3 is upstream's new major release of Ruby. Ruby 3.3 adds a new parser named Prism, uses Lrama as a parser generator, adds a new pure-Ruby JIT compiler named RJIT, and many performance improvements especially YJIT.

Prism

  • Introduced the Prism parser as a default gem
    • Prism is a portable, error tolerant, and maintainable recursive descent parser for the Ruby language
  • Prism is production ready and actively maintained, you can use it in place of Ripper
    • There is extensive documentation on how to use Prism
  • Prism is both a C library that will be used internally by CRuby and a Ruby gem that can be used by any tooling which needs to parse Ruby code
  • You can now use ruby --parser=prism or RUBYOPT="--parser=prism" to experiment with the Prism compiler. Please note that this flag is for debugging only.

Use Lrama instead of Bison

  • Replace Bison with Lrama LALR parser generator

YJIT

  • Major performance improvements over 3.2
    • Support for splat and rest arguments has been improved.
    • Registers are allocated for stack operations of the virtual machine.
    • More calls with optional arguments are compiled.
    • Unsupported call types no longer exit to the interpreter.
    • Basic methods like Rails #blank? and specialized #present? are inlined.
    • Integer#!=, String#!=, Kernel#block_given?, Kernel#is_a?, Kernel#instance_of?, Module#=== are specially optimized.
    • Compilation speed is now slightly faster than Ruby 3.2.
    • Now more than 3x faster than the interpreter on Optcarrot!
  • Significantly improved memory usage over Ruby 3.2
    • Metadata for compiled code uses a lot less memory.
    • More compact code is generated on Arm64.
  • Code GC is now disabled by default
  • Add RubyVM::YJIT.enable that can enable YJIT at run-time
    • You can start YJIT without modifying command-line arguments or environment variables. Rails 7.2 will enable YJIT by default using this method.
    • This can also be used to enable YJIT only once your application is done booting. --yjit-disable can be used if you want to use other YJIT options while disabling YJIT at boot.
  • More YJIT stats are available by default
  • Add more profiling capabilities
  • More thorough testing and multiple bug fixes


RJIT

  • Introduced a pure-Ruby JIT compiler RJIT and replaced MJIT.
    • RJIT supports only x86_64 architecture on Unix platforms.
    • Unlike MJIT, it doesn’t require a C compiler at runtime.
  • RJIT exists only for experimental purposes.
    • You should keep using YJIT in production.

M:N thread scheduler

  • M:N thread scheduler was introduced.
    • M Ruby threads are managed by N native threads (OS threads) so the thread creation and management cost are reduced.
    • It can break C-extension compatibility so that M:N thread scheduler is disabled on the main Ractor by default.
    • RUBY_MAX_CPU=n environment variable sets maximum number of N (maximum number of native threads). The default value is 8.
      • Since only one Ruby thread per Ractor can run at the same time, the number of native threads will be used, which is the smaller of the number specified in RUBY_MAX_CPU and the number of running Ractors. So that single Ractor applications (most of applications) will only use 1 native thread.
      • To support blocking operations, more than N native threads can be used.

Performance improvements

  • defined?(@ivar) is optimized with Object Shapes.
  • Name resolution such as Socket.getaddrinfo can now be interrupted (in environments where pthreads are available).
  • Several performance improvements to the Garbage Collector

Other notable changes since 3.2

  • IRB has received several enhancements, including but not limited to:
    • Advanced irb:rdbg integration that provides an equivalent debugging experience to pry-byebug.
    • Pager support for ls, show_source and show_cmds commands.
    • More accurate and helpful information provided by the ls and show_source commands.
    • Experimental autocompletion using type analysis
  • ext/readline is retired
    • Replaced by reline that is pure Ruby implementation compatible with ext/readline API.
  • RubyGems and Bundler warn if users require gem that is scheduled to become the bundled gems in the future version of Ruby.

Feedback

Benefit to Fedora

With a latest release, Ruby language is supporting the newest language features, which enables even faster and easier development of Ruby applications.

Scope

  • Other developers:
    • Rebuild of packages with binary extensions (i.e. packages which depends on libruby) will be handled automatically, but some packages might need fixes/updates to support Ruby 3.3 properly.
  • Release engineering: #11753
    • The packages are going to be rebuild in side-tag, but that does not need releng involvement nowadays.
  • Policies and guidelines: N/A (not needed for this Change)
  • Trademark approval: N/A (not needed for this Change)
  • Alignment with Community Initiatives:

Upgrade/compatibility impact

  • User specific Ruby binary extensions need to be rebuild.
  • Ruby packages/application dependencies might need to be adjusted if newly bundled gems are used.

How To Test

  • No special hardware is needed.
  • To test, install Ruby 3.3. The test builds are published in PR or on Ruby-SIG ML
  • Try to locally rebuild your packages using Ruby 3.3.
  • Use the packages with your applications previously written in Ruby.
  • If something doesn't work as it should, let us know.

User Experience

The Ruby programs/scripts should behave as they were used to.

Dependencies

$ dnf repoquery --disablerepo=* --enablerepo=rawhide --enablerepo=rawhide-source --arch=src --whatrequires 'ruby-devel' | sort | uniq | wc -l
134

Contingency Plan

  • Contingency mechanism: We would like to get a special buildroot tag to be able to rebuild necessary the packages with Ruby 3.3. If anything goes wrong, the tag could be easily dropped and previous version of Ruby 3.2 and its dependencies stays intact. The tag would be merged into F40 after everything is rebuild.
  • Contingency deadline: Mass Rebuild
  • Blocks release? No


Documentation

Release Notes

  • The Ruby 3.3 bumps soname, therefore Ruby packages, which use binary extensions, should be rebuilt. Nevertheless, since upstream paid great attention to source compatibility, no changes to your code are needed.

https://github.com/ruby/ruby/blob/ruby_3_3/NEWS.md