#https://gist.github.com/mhayashi1120/9932930
間が空いてしまいましたが、この頃の話題についてです。 http://chaton.practical-scheme.net/gauche/a/2014/03/18
gist にあるスクリプト (exam-gosh2) をいくつか動かすとメモリの使用量が何かのタイミングでぐんぐん増えていくのです。(result.txt)
よくわからないのですが sys-pipe の使い方なにか間違ってるでしょうか。
実験した gosh は 2014-03-19 08:01 にコンパイルした当時の trunk です。
#それから機能を絞ってひたすら sample-stream を動かしたスクリプトは一週間ぐらい何事もなく動き続けていたので、先の Chaton への pull-req はきっと無害です。
#>mhayashi1120 ありがとうございます。gistのそれはSchemeレベルで特に怪しいところは見当たらないので、Gaucheの実装の方でリークしてる可能性がありますね。
#fd 16 の相手がいないのがおかしいのかな?あと、24.9, 35.9 て systime ですかね
#> USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
省略した ps の出力ヘッダはこんな感じです。
#fd 16が気になりますよね。forkで継承してるわけでもないだろうし、どっから来たんだろ。
#%mem でしたか。strace してたらなにかわかるかも。
#あ、してたら、じゃなくて、したら。途中からでも出来ます。
#なるほど。時間かかるかもですが try してみます。
#3.4 のほうとどちらが問題になっているものか、確認したいですね。
#んーと、3.4 と言うと何のことでしょう。pipe の fd?
#そうです。
#わかりました。
#node の値で 3,4 はペアだけど、16 は相手がいないのがわかります。
#読み方がだんだんわかってきました。何回も lsof を取得してるのですけど、コピペミスで切れちゃってるわけじゃなさそうです。とにかく試してみます。