phantomjs Can not connect to the Service phantomjs错误
尝试方法一:
打开hosts文件配置
cat /etc/hosts
添加
127.0.0.1 localhost
重新运行
尝试方法二:
1,抛开服务,直接调用phantomjs定位问题
由于我是从服务的日志中看到报错的,可能是因为phantomjs这个出错了,于是我就在88服务器上直接运行如个代码:
[root(songxianfeng01@58OS)@bjm6--88ershouservices]# python
>>> from selenium import webdriver
>>>dr=webdriver.PhantomJS('phantomjs')
结果报如下错误:
Traceback (most recent call last):
File"/usr/local/python2.7/lib/python2.7/site-packages/selenium-3.6.0-py2.7.egg/selenium/webdriver/phantomjs/webdriver.py",
line , in __init__self.service.start()
File
"/usr/local/python2.7/lib/python2.7/site-packages/selenium-3.6.0-py2.7.egg/selenium/webdriver/common/service.py",
line , in start
raise WebDriverException("Can not connect to the
Service %s" % self.path)
selenium.common.exceptions.WebDriverException:
Message: Can not connect to the Service
phantomjsdriver
没有看出直接原因是什么,于是就采取常规的办法:重新安装相关软件
于是就:
./easy_install -m selenium
将selenium重新卸载了再安装,同时也将phantomjs删除了
rm -rf /usr/local/phantomjs rm -f /usr/local/bin/phantomjs
而后按网上提供的方案重新安装完成!
结果发现:问题依然存在,没有什么用处!
2,查看源码,精准进行定位
重新安装没有任何效果后,我就将上面的两个文件webdriver.py和service.py下载了下来。
(1)先去service.py中搜索报错的代码段:
count= 0
while True:
self.assert_process_still_running()
if self.is_connectable():
break
count+= 1
time.sleep(1)
if count
==30:
raise WebDriverException("Can not connect to the Service %s"
% self.path)
直接原因是count到了30了,相当于尝试了30次self.is_connectable都失败了。
(2)查看函数is_connectable这个函数是什么意思?
def is_connectable(self): return utils.is_connectable(self.port)
看来直接原因是utils.is_connectable这个函数报错的,不过这个port的值是什么呢?我好像没有传这个值啊?
(3)查看self.port的值
在webdirver.py中,port默认值为0:
def __init__(self,executable_path="phantomjs", port=0, desired_capabilities=DesiredCapabilities.PHANTOMJS,service_args=None,service_log_path=None):
在调用service.py文件中的类的时候,如果port值等于0,则随机获取一个端口
class Service(object): def __init__(self,executable, port=0, log_file=DEVNULL, env=None, start_error_message=""): self.path =executable self.port =port if self.port== 0: self.port =utils.free_port()
于是我们就直接验证utils相关的代码:
>>> from selenium.webdriver.common import utils >>> utils.free_port() 49439 >>>utils.is_connectable(49439) False
发现无论端口号是多少,都会返回false,所以self.is_connectable函数永远都是失败,尝试30次之后就会报异常。
(4)查看utils.is_connectable函数源码,看能否找到原因?
def is_connectable(port):
"""
Tries to connect to the server at port to see if it is running.
:Args:
- port: The port to connect.
"""
try:
socket_ = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
socket_.settimeout(1)
socket_.connect(("127.0.0.1", port))
socket_.close()
return True
except socket.error:
return False
看出最终的原因应该是socket连接出错了。于是就手功尝试一下:
>>> import socket
>>> socket_
=socket.socket(socket.AF_INET, socket.SOCK_STREAM)
>>>socket_.connect(("127.0.0.1",49439))
Traceback (most recent call last):
File "", line 1, inFile"/usr/local/python2.7/lib/python2.7/socket.py",
line 228, in meth
return
getattr(self._sock,name)(*args)
socket.error: [Errno 111] Connection
refused
>>>
通过查询socket 111错误与phantomjs,webdriver相关的内容,发现可能是webdirver与phantomjs不匹配的问题。可是我不记得原来的webdirver的版本是什么了?
3,最终尝试,解决问题
通过上面的分析,最终问题定位是:可能是有人重新安装了服务器的python selenium了,造成的不兼容问题。
解决方案:安装最新的selenium和phantomjs.
(1)selenium更新
通过访问相关的官网,发现selenium的最新版本是3.7.0,而通过easy_install安装的是3.6.0,果断更新之!
https://pypi.python.org/pypi/selenium/#downloads
(2)phantomjs更新
因为phantomjs是刚刚安装过的,是最新的版本2.1.1,下载地址是:
http://phantomjs.org/download.html
(3)全部更新后再次尝试
>>> from selenium import webdriver
>>> dr = webdriver.PhantomJS('phantomjs')
>>>
>>>
没有任何报错,开心一下。
phantomjs Can not connect to the Service phantomjs错误的更多相关文章
- iTunes Connect TERMS OF SERVICE
iTunes Connect TERMS OF SERVICE THESE TERMS OF SERVICE CONSTITUTE A LEGAL AGREEMENT BETWEEN YOU AND ...
- java.lang.RuntimeException: Fail to connect to camera service
玩自定义照相机的时候出现了:java.lang.RuntimeException: Fail to connect to camera service 讲过百度和Google后知道是权限少加了.(试验 ...
- py+selenium运行时报错Can not connect to the Service IEDriverServer.exe
问题: 运行用例时,出现报错(host文件已加入127.0.0.1 localhost): raise WebDriverException("Can not connect to the ...
- 【打印机】无法连接 fail to connect to server cups 服务器错误 打印机
打印机 fail to connect to server cups 服务器错误兆芯 打印机 连不上了####message可知 服务fail## systemd: cups.servi ...
- 【Oracle】ORA-00257:archiver error. Connect internal only, until freed 错误的处理方法
archive log 日志已满ORA-00257: archiver error. Connect internal only, until freed 错误的处理方法 1. 用sys用户登录 s ...
- ORA-00257: archiver error. Connect internal only, until freed 错误的处理方法
转帖:原文地址http://blog.csdn.net/panys/article/details/3838846 archive log 日志已满ORA-00257: archiver error. ...
- LR回放https协议脚本失败: 错误 -27778: 在尝试与主机“www.baidu.com”connect 时发生 SSL 协议错误
今天用LR录制脚本协议为https协议,回放脚本时出现报错: Action.c(14): 错误 -27778: 在尝试与主机"www.baidu.com"connect 时发生 S ...
- 关于ORA-00257: archiver error. Connect internal only, until freed 错误的处理方法
转 关于ORA-00257: archiver error. Connect internal only, until freed 错误的处理方法 2016年03月31日 10:14:59 阅读数:1 ...
- DEBUG : Eclipse Debug 时出现 Cannot connect to VM select failed错误
Eclipse在执行Debug操作时, 出现“Eclipse Debug 时出现 "Cannot connect to VM select failed"”错误, 在网上查找该错误 ...
随机推荐
- linux设备驱动模块引用和依赖
/modules/04 # lsmod test 787 0 - Live 0xbf010000 (PO) func 633 1 test, Live 0xbf00c000 (PO) test -&g ...
- LeetCode - 二叉树的最大深度
自己解法,欢迎拍砖 给定一个二叉树,找出其最大深度. 二叉树的深度为根节点到最远叶子节点的最长路径上的节点数. 说明: 叶子节点是指没有子节点的节点. 示例:给定二叉树 [3,9,20,null,nu ...
- pyqt5 动画在QThread线程中无法运行问题
自己做了一个tcp工具,在学习动画的时候踩了坑,需求是根据上线变绿色,离线变灰色,如果连接断开了,则变为灰色 问题现象: 可以看到点击"连接","离线"的时候动 ...
- Eclipse 3.5 以后安装插件很慢的解决办法
1 .除非你需要,否则不要选择"联接到所有更新站点" 在安装对话框里有一个小复选框,其标示为"在安装过程中联接到所有更新站点从而找到所需的软件."从表面上看,这 ...
- java原子操作
一.何谓Atomic? Atomic一词跟原子有点关系,后者曾被人认为是最小物质的单位.计算机中的Atomic是指不能分割成若干部分的意思.如果一段代码被认为是Atomic,则表示这段代码在执行过程中 ...
- MySQL 的索引优化
索引类似大学图书馆建书目索引,可以提高数据检索的效率,降低数据库的IO成本.MySQL在300万条记录左右性能开始逐渐下降,虽然官方文档说500~800w记录,所以大数据量建立索引是非常有必要的.My ...
- [译文]Domain Driven Design Reference(二)—— 让模型起作用
本书是Eric Evans对他自己写的<领域驱动设计-软件核心复杂性应对之道>的一本字典式的参考书,可用于快速查找<领域驱动设计>中的诸多概念及其简明解释. 其它本系列其它文章 ...
- Kudu vs HBase
本文由 网易云发布. 背景 Cloudera在2016年发布了新型的分布式存储系统--kudu,kudu目前也是apache下面的开源项目.Hadoop生态圈中的技术繁多,HDFS作为底层数据存储的 ...
- 在UltraEdit中如何像NotePad++一样实现双击单词在全文中高亮
NotePad++中有个功能特别好用,就是双击某个单词,这个单词就会在全文档中高亮,如下图 我经常用UltraEdit,结果是UE中没有这个功能,这么实用的功能居然没有? 没关系,在UE中shift+ ...
- SOFA 源码分析 —— 服务发布过程
前言 SOFA 包含了 RPC 框架,底层通信框架是 bolt ,基于 Netty 4,今天将通过 SOFA-RPC 源码中的例子,看看他是如何发布一个服务的. 示例代码 下面的代码在 com.ali ...