[#47135] [ruby-trunk - Feature #8024][Assigned] Lazy sweep を on/off するための機能 — "mrkn (Kenta Murata)" <muraken@...>

16 messages 2013/03/06

[ruby-dev:47194] [ruby-trunk - Feature #8024] Lazy sweep を on/off するための機能

From: "authorNari (Narihiro Nakamura)" <authorNari@...>
Date: 2013-03-24 03:35:24 UTC
List: ruby-dev #47194
Issue #8024 has been updated by authorNari (Narihiro Nakamura).


ko1 (Koichi Sasada) wrote:
> すみません、ちょっとわかってないんですが、
>  ObjectSpace.each_object 中って lazy GC 起きないようになってますよね。
>  
>  (1) lazy sweep を止めるときは、別スレッドで適当に
>  ObjectSpace.each_object を実行しておく
>  (で、その中で sleep させておく)、というので行けると思ったんですが、
>  あってますか?
>  

すみませんが、修正内容がよく理解できませんでした。
別スレッドで実行すると何が解決するのでしょうか?

>  (2) で、ヒープの拡張がうまくいかない問題は、ObjectSpace.each_object 中に
>  も同様に発生するでしょうか? もしそうなら、それはそれで修正しないといけ
>  ないような気がします。
>  

はい、修正が必要だと思います(のでなおしておきます)。
ただ、ObjectSpace.each_objectの中でヒープが拡張していくようなコードは無限ループになる可能性があるので、そもそもあまり推奨されるコードじゃないですね…。

----------------------------------------
Feature #8024: Lazy sweep を on/off するための機能
https://bugs.ruby-lang.org/issues/8024#change-37873

Author: mrkn (Kenta Murata)
Status: Open
Priority: Normal
Assignee: authorNari (Narihiro Nakamura)
Category: core
Target version: 


Lazy sweep を on/off する機能を追加するパッチを作りました。
このパッチは環境変数1つと GC のモジュール関数2つを追加します。

環境変数は RUBY_GC_DISABLE_LAZY_SWEEP です。
これに 0 以外の整数を設定して ruby を実行すると、
lazy sweep が off の状態で実行されます。

GC に追加されるモジュール関数は disable_lazy_sweep と enable_lazy_sweep です。
文字通り、lazy_sweep の on/off を切り替えるために使います。

このパッチを作るに至った経緯は、Lazy sweep が on の時だけ再現する SEGV が
弊社のテストコードで発生していたからです。
SEGV の発生条件がまだ絞れていないため、残念ながらバグ報告はまだできません。

運用上 Lazy sweep を止めておく必要があっために作ったパッチですが、
他の人の役にも立つかもしれませんので、こちらで提案させて頂きます。

trunk/2.0.0 用 → https://gist.github.com/mrkn/5096076

1.9.3 用 → https://gist.github.com/mrkn/5096071


-- 
http://bugs.ruby-lang.org/

In This Thread