我有一个像这样的
ruby代码:
begin doc = Nokogiri::HTML(open(url).read.strip) rescue Exception => ex log.error "Error: #{ex}" end
我得到的日志是:
ERROR -- : Error: execution expired
我希望块重新执行直到成功.
我该怎么做?
解决方法
我会稍微扩展一下我的评论.您可以使用重试返回到开头:
begin doc = Nokogiri::HTML(open(url).read.strip) rescue Exception => ex log.error "Error: #{ex}" retry end
这将继续尝试(和记录错误),直到它工作或手动杀死它.这可能不是你想要的,因为一个小错误会让你陷入无限循环.一个简单的方法就是让它尝试10次,然后放弃:
MAX_ATTEMPTS = 10 doc = nil begin doc = Nokogiri::HTML(open(url).read.strip) rescue Exception => ex log.error "Error: #{ex}" attempts = attempts + 1 retry if(attempts < MAX_ATTEMPTS) end if(doc.nil?) # Do something about the persistent error # so that you don't try to access a nil # doc later on. end
这样的事情会尝试几次然后放弃.如果您想在下一次尝试之前等待一段时间或调查异常(可能有多个救援块)以选择是否应立即放弃,等待并重试或立即重试,您也可以在重试之前拨打sleep
.