Ruby脚本'杀了'

时间:2012-12-21 00:34:55

标签: ruby amazon-web-services

我正在从命令行运行ruby脚本。该脚本下载一个文件(15 MB),解压缩,将其解析为JSON,然后用它填充一个mysql数据库。

当我运行它时,我会收到一条简单的“已杀死”消息。这是怎么回事?我怎样才能找出问题所在?

我在EC2微型实例上使用它。

由于

这是脚本

require 'open-uri'
require 'zlib'
require 'json'

require_relative '../db/db.rb'

dl = open('........')
ex = Zlib::GzipReader.new dl
json = JSON.parse ex.read
events = json['resultsPage']['results']['event']

puts "starting to parse #{events.count} event(s)..."
created = 0
updated = 0

events[1..10].each do |event|
    performances = event['performance']
    performances.each do  |performance|
        ar_show = Show.find_or_initialize_by_songkick_id performance['id']
        ar_show.artist_name = performance['displayName']
        ar_show.new_record? ? created += 1 : updated += 1
        ar_show.save!
    end
end

Import.create :updated => updated, :new => created
puts "complete. new: #{created}   -   updated: #{updated}"

1 个答案:

答案 0 :(得分:5)

您几乎肯定会耗尽内存,因为微型实例没有太多可用的内存或交换空间。我在Perl程序中遇到过这种情况。在处理大量数据时,动态语言可能会占用大量内存。

测试这个理论的最好方法是在一小时内启动一个小型或大型实例(因此你不会为此付出太多代价)并在那里尝试脚本。如果它运行,您就知道微实例太小而无法运行程序。