使用watir-webdriver打开多个线程会导致"连接被拒绝"错误

Mic*_*elR 6 ruby selenium multithreading watir-webdriver

我有这个简单的例子:

require 'watir-webdriver'

arr = []
sites = [
"www.google.com",
"www.bbc.com",
"www.cnn.com",
"www.gmail.com"
]

sites.each do |site|
    arr << Thread.new {
        b = Watir::Browser.new :chrome
        b.goto site
        puts b.url
        b.close
    }
end
arr.each {|t| t.join}
Run Code Online (Sandbox Code Playgroud)

每次我运行这个脚本,我都会

ruby/2.1.0/net/http.rb:879:in `initialize': Connection refused - connect(2) for "127.0.0.1"      port 9517 (Errno::ECONNREFUSED)
Run Code Online (Sandbox Code Playgroud)

或者其中一个浏览器在至少其中一个线程上意外关闭.

另一方面,如果我sleep 2在每个循环周期结束时设置,一切运行顺利!知道为什么会这样吗?

必须与理解线程如何工作有关...

Joh*_*son 4

您基本上是在浏览器实例之间创建竞争条件,以连接到 watir-webdriver 正在查找的开放端口。在这种情况下,您的浏览器的第一个实例会发现端口 9517 已打开并连接到它。由于您并行启动这些实例,因此您的第二个实例也认为端口 9517 已打开并尝试连接。但糟糕的是,该端口已被第一个浏览器实例使用。这就是您收到此特定错误的原因。

这也解释了为什么sleep 2修复该问题。第一个浏览器实例连接到端口 9517,并且睡眠导致第二个浏览器实例看到 9517 已被占用。然后它连接到端口 9518。

编辑

Selenium::WebDriver::Chrome::Service#initialize您可以通过(此处)查看这是如何实现的,它调用Selenium::WebDriver::PortProber此处)。PortProber 是网络驱动程序确定哪个端口打开的方式。