一尘不染

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

selenium

我有一个简单的例子:

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}

每次我运行此脚本,我都会得到

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

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

另一方面,如果我sleep 2在每个循环周期的末尾进行设置,则一切运行都会很顺利!知道为什么吗?

必须与理解线程如何工作相关…


阅读 208

收藏
2020-06-26

共1个答案

一尘不染

您基本上是在浏览器实例之间创建竞争条件以连接到watir-
webdriver找到的开放端口。在这种情况下,浏览器的第一个实例将看到端口9517已打开并连接到该端口。因为要并行拆分这些实例,所以第二个实例也认为端口9517已打开并尝试连接。但是,哎呀,第一个浏览器实例已经在使用该端口。这就是为什么您会收到此特定错误的原因。

这也解释了为什么sleep 2解决此问题。第一个浏览器实例连接到端口9517,hibernate使第二个浏览器实例看到采用了9517。然后,它在端口9518上连接。

编辑

您可以看到如何通过Selenium::WebDriver::Chrome::Service#initializehere)调用Selenium::WebDriver::PortProberhere)来实现这一点。网络驱动程序通过PortProber确定打开哪个端口。

2020-06-26