2016-06-17 253 views
0


首先,我是Ruby的初学者,对Ruby管理代码的方式不熟悉,所以我确实希望问题是我不知道如何使用红宝石正确。
我遇到的问题是死锁,但我没有在我的程序中使用任何线程。另外,错误只发生在每1000到1500次函数调用中,这使得查明和纠正非常困难。
下面是完整的错误消息时出现该问题:
Ruby:open会导致死锁

/usr/lib/ruby/2.3.0/timeout.rb:95:in `join': No live threads left. Deadlock? (fatal) 
    from /usr/lib/ruby/2.3.0/timeout.rb:95:in `ensure in block in timeout' 
    from /usr/lib/ruby/2.3.0/timeout.rb:95:in `block in timeout' 
    from /usr/lib/ruby/2.3.0/timeout.rb:101:in `timeout' 
    from /usr/lib/ruby/2.3.0/net/http.rb:878:in `connect' 
    from /usr/lib/ruby/2.3.0/net/http.rb:863:in `do_start' 
    from /usr/lib/ruby/2.3.0/net/http.rb:852:in `start' 
    from /usr/lib/ruby/2.3.0/open-uri.rb:319:in `open_http' 
    from /usr/lib/ruby/2.3.0/open-uri.rb:737:in `buffer_open' 
    from /usr/lib/ruby/2.3.0/open-uri.rb:212:in `block in open_loop' 
    from /usr/lib/ruby/2.3.0/open-uri.rb:210:in `catch' 
    from /usr/lib/ruby/2.3.0/open-uri.rb:210:in `open_loop' 
    from /usr/lib/ruby/2.3.0/open-uri.rb:151:in `open_uri' 
    from /usr/lib/ruby/2.3.0/open-uri.rb:717:in `open' 
    from /usr/lib/ruby/2.3.0/open-uri.rb:35:in `open' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/sources/utils.rb:85:in `get_pic' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/mangafox/MF_download.rb:87:in `page_link' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/mangafox/MF_download.rb:116:in `chapter_link' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/mangafox/MF_download.rb:142:in `chapter' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/mangafox/MF_update.rb:57:in `block in MF_manga_missing_chapters' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/mangafox/MF_update.rb:45:in `reverse_each' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/mangafox/MF_update.rb:45:in `MF_manga_missing_chapters' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/mangafox/MF_update.rb:80:in `MF_update' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/sources/update.rb:5:in `update_manga' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/sources/update.rb:15:in `block in update_all' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/sources/update.rb:14:in `each' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/sources/update.rb:14:in `update_all' 
    from /home/mat/travail_perso/RUBY/MangaScrapp_github/sources/update.rb:22:in `update' 
    from ./MangaScrap.rb:28:in `<main>' 

链接到完整的程序是在这里:https://github.com/Hellfire01/MangaScrap
问题发生在使用开放的3种不同的方法,这里是一个坠毁这段时间:

# conect to link and download picture 
def get_pic(link) 
    safe_link = link.gsub(/[\[\]]/) { '%%%s' % $&.ord.to_s(16) } 
    tries ||= 20 
    begin 
    page = open(safe_link, "User-Agent" => "Ruby/#{RUBY_VERSION}") 
    rescue URI::InvalidURIError => error 
    puts "Warning : bad url" 
    puts link 
    puts "message is : " + error.message 
    return nil 
    rescue => error 
    if tries > 0 
    tries -= 1 
    sleep(0.2) 
    retry 
    else 
     puts 'could not get picture ' + safe_link + ' after ' + $nb_tries.to_s + ' tries' 
     puts "message is : " + error.message 
     return nil 
    end 
    end 
    sleep(0.2) 
    return page 
end 

下面是该文件的链接:https://github.com/Hellfire01/MangaScrap/blob/master/sources/utils.rb

我想知道的是:
- 我该如何解决这个错误?
- 如果我无法修复这个错误,是否可以使用open-uri的替代方法?

任何帮助是非常值得欢迎

+1

仅供参考,为原因一个线程错误,尽管没有使用线程是ruby超时库正在被net/http使用(反过来由open-uri使用),并且超时使用线程 –

+1

是的,我把这么多,但我仍然不知道如何修复问题:/ –

+1

[curb](https://github.com/taf2/curb)比原始的Net :: HTTP更令人愉快。 – tadman

回答

2

你不在这里捕获所有异常。当在rescue之后没有指定任何内容时,这意味着您正在捕获不在异常的层次结构根目录中的StandardError

如果你想确保你赶上所有异常并尝试重新打开一个URL(或您想任何行为),你想要做的是: rescue Exception => error