Project

General

Profile

Actions

Bug #21158

closed

Ractor using 'receive_if' sits in busy wait when there are skipped messages in the incoming queue

Added by NeilW (Neil Wilson) 3 months ago. Updated 1 day ago.

Status:
Closed
Assignee:
Target version:
-
ruby -v:
ruby 3.4.2 (2025-02-15 revision d2930f8e7a) +PRISM [x86_64-linux]
[ruby-core:121182]

Description

When using the conditional receive example from the Ractor documentation (either as a script, or within irb)

r = Ractor.new do
  val = Ractor.receive_if{|msg| msg.is_a?(Array)}
  puts "Received successfully: #{val}"
end

r.send(1)
r.send('test')

ruby will sit in busy wait, pegging the processor at 100%, until it gets a message that matches the condition. Within irb it will often stop the REPL responding.

The same problem occurs on ruby 3.02, 3.3.7 and 3.4.1

Updated by luke-gru (Luke Gruber) 3 months ago

Thank you for the report, I'm able to reproduce it.

This is happening because if the proc doesn't match (receive_if fails), the basket value is changed from reserved to ref
so it never goes back to sleep (ractor_queue_empty_p always return false and we don't get into the ractor_sleep function.)

I'll take a closer look and try to get a patch out soon.

Actions #2

Updated by jhawthorn (John Hawthorn) 30 days ago

  • Assignee set to ractor
Actions #3

Updated by hsbt (Hiroshi SHIBATA) 26 days ago

  • Status changed from Open to Assigned

Updated by jhawthorn (John Hawthorn) 1 day ago

  • Status changed from Assigned to Closed

receive_if has been removed with the introduction of Ractor::Port, so this should no longer be an issue (and it does sound like it was receive_if specific)

Actions

Also available in: Atom PDF

Like0
Like0Like0Like0Like0