一、背景
在日常的自动化测试或爬虫开发中,Selenium + ChromeDriver 是最常见的组合。
然而,在实际使用中,我们经常会遇到一些让人摸不着头脑的报错。
其中一个典型的错误就是:
Failed to read descriptor from node connection: 连到系统上的设备没有发挥作用。
这个报错往往出现在脚本运行到 webdriver.Chrome()
初始化阶段,而且并不是每次都发生,往往是偶尔出现,非常迷惑。
二、现象描述
- 报错并不是一开始就出现,有时候第一次运行没问题,但第二次就报错;
- 关闭所有程序再运行,又能恢复正常;
- 报错的堆栈信息大多停留在
ChromeDriver
调起浏览器的阶段,和具体页面操作无关; - 错误提示里提到 “连到系统上的设备没有发挥作用”,但实际上和硬件关系不大。
三、原因分析
经过多次测试和经验总结,可以发现:
-
Chrome Instance 没有正确关闭
- 当我们运行一次脚本时,Selenium 会调起一个 Chrome 实例;
- 如果脚本异常退出、或者人为强制停止进程,浏览器残留进程没有被关闭;
- 下一次再尝试调用 ChromeDriver 时,会因为 “旧实例占用通道” 导致启动失败。