2010-10-11(月)
Template-Toolkit-2.22のメモリリーク【再】
以前Template::Plugin::Filterのリークを直すパッチを書いて2.19_02で採用されていたのですが、不具合があってrevertされてしまってました*1。
2.22でリークするってのはこんなスクリプト書けばわかります(test::simple は自分でTemplate::Plugin::Filterを継承して作って)。
for my $l (1 .. 1000) { my $tpl = Template->new( PLUGIN_BASE => 'test', ); $tpl->context->plugin('simple', []); warn `ps -o rss= -p $$` if $l % 10 == 0; }
ってことで、パッチを書いてリベンジ。リークがあるとどうしても MaxRequestsPerChild の値を極端に小さくしなければいけなかったりと色々困りもんなので、直って欲しいです。
もしかして: Xslate
2010-10-13 追記
ぼやいていたら @tokuhirom さんからアドバイスをもらいました。
それにしても TT 使ってる人はみんなどうしているんだろ。メモリリーク気にせず使っているのか、それとも、そもそも Filter のサブクラスなんて作ってないのかなあ。
filter のプラグインつくるだけなら Template::Plugin 直接つかってもいいですよね。
確かに、もともとのマツモさんのエントリでもそのような解決法をとっていました。
- 親クラスをTemplate::Plugin::FilterからTemplate::Pluginに
- initをnewに
- $self->install_filterを$context->define_filterに
*1:致命的な不具合なので、送ったパッチが悪かったです。
トラックバック - http://d.hatena.ne.jp/hiratara/20101011/1286787124
リンク元
- 13 http://reader.livedoor.com/reader/
- 7 http://twitter.com/
- 5 http://d.hatena.ne.jp/yumatsumo/20070516
- 5 http://www.google.com/reader/view/
- 4 http://d.hatena.ne.jp/keywordblogmobile/パッチ
- 3 http://hiratara.dyndns.org/
- 2 http://d.hatena.ne.jp/keywordblogmobile/パッチ?guid=on
- 2 http://d.hatena.ne.jp/keywordmobile/パッチ?guid=on
- 2 http://ezsch.ezweb.ne.jp/search/?query=チャベリ+裏口&start-index=26&adpage=5&ct=1301&sr=0002&t=20110209031037&filter=1
- 2 http://namusyaka.info/





