Project

General

Profile

Actions

Bug #17506

closed

Ractor isolation broken by ThreadGroup

Added by marcandre (Marc-Andre Lafortune) over 4 years ago. Updated 26 days ago.

Status:
Closed
Assignee:
Target version:
-
ruby -v:
ruby 3.0.0p0 (2020-12-25 revision 95aff21468) [x86_64-darwin18]
[ruby-core:101894]

Description

Ractors currently share the ThreadGroup.

This doesn't seem very useful as there is no possible communication between the Threads of different Ractors.

It is also an isolation error:

ThreadGroup.attr_accessor :foo
var = Thread.current.group.foo = [:example]
Ractor.new { Thread.current.group.foo << [:oops] }.take
var # => [:example, [:oops]]

Should Ractor.new create a new ThreadGroup? Should ThreadGroup not have (non-shareable) instance variables? Or should Ractor.new { Thread.current.group }.take be nil? See also https://bugs.ruby-lang.org/issues/17505 about nil.

Note that Ractor respects the ThreadGroup's state:

Thread.current.group.enclose
Ractor.new { Thread.current.group.add(Thread.current) }.take # => can't move to the enclosed thread group

Thread.current.group.freeze
Ractor.new {} # => ThreadError (can't start a new thread (frozen ThreadGroup))

I am not sure what is the best behavior as I don't have enough experience with how ThreadGroups are used, especially enclosed ThreadGroups.

Updated by byroot (Jean Boussier) 27 days ago

  • Assignee set to ractor

Retested on 3.4.2, and it seems the bug is still present.

Actions #2

Updated by byroot (Jean Boussier) 26 days ago

  • Status changed from Open to Closed

Applied in changeset git|5e421ce8d949a4f92568db359be0d188b66e58ca.


ractor: don't inherit the default thread group

[Bug #17506]

Thread.current.group isn't shareable so it shouldn't be inherited
by the main thread of a new Ractor.

This cause an extra allocation when spawning a ractor, which could
be elided with a bit of extra work, but not sure if it's worth
the effort.

Actions

Also available in: Atom PDF

Like0
Like0Like0