作为标题所述,我有一个处理大量数据的Ruby程序。该程序占用了所有内存,并在其中调用系统命令
此外,我使用Ruby 2.1和CentOS 6.4。
hostname
时出现了错误。
Cannot allocate memory - hostname
我尝试过GC.start
但没有起作用。
那么我该如何强制Ruby释放未使用的内存呢?
好的,这是其他人的测试代码,最后的错误显示big_var
已被回收,但内存仍未释放。
require "weakref"
def report
puts "#{param}:\t\t Memory " + `ps ax -o pid,rss | grep -E "^[[:space:]]*#{$$}"`
.strip.split.map(&:to_i)[1].to_s + 'KB'
end
big_var = ""
#big_var = WeakRef.new(big_var)
report
big_var = 1_000_000.times.map(&:to_s)
report
big_var = WeakRef.new(big_var)
GC.start
sleep 1
report
p big_var.length
#Memory 7508KB
#Memory 61516KB
#Memory 53700KB
#test.rb:20:in `<main>': Invalid Reference - probably recycled (WeakRef::RefError)
好的,我尝试了下面的事情,但不明白为什么在执行$big_var=nil
和GC.start
后,GC.stat[:heap_used]
仍然如此之大。
puts GC.stat[:heap_used]
$big_var = []
5000000.times { |i|
$big_var << i.to_s
}
puts GC.stat[:heap_used]
$big_var = nil
puts GC.stat[:heap_used]
GC.start
puts GC.stat[:heap_used]
#70
#12286
#12286
#9847
此外,我使用Ruby 2.1和CentOS 6.4。