尝试方法一:

打开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错误的更多相关文章

  1. iTunes Connect TERMS OF SERVICE

    iTunes Connect TERMS OF SERVICE THESE TERMS OF SERVICE CONSTITUTE A LEGAL AGREEMENT BETWEEN YOU AND ...

  2. java.lang.RuntimeException: Fail to connect to camera service

    玩自定义照相机的时候出现了:java.lang.RuntimeException: Fail to connect to camera service 讲过百度和Google后知道是权限少加了.(试验 ...

  3. py+selenium运行时报错Can not connect to the Service IEDriverServer.exe

    问题: 运行用例时,出现报错(host文件已加入127.0.0.1 localhost): raise WebDriverException("Can not connect to the ...

  4. 【打印机】无法连接 fail to connect to server cups 服务器错误 打印机

       打印机     fail to connect to server cups 服务器错误兆芯 打印机 连不上了####message可知 服务fail## systemd: cups.servi ...

  5. 【Oracle】ORA-00257:archiver error. Connect internal only, until freed 错误的处理方法

    archive log 日志已满ORA-00257: archiver error. Connect internal only, until freed 错误的处理方法 1. 用sys用户登录  s ...

  6. ORA-00257: archiver error. Connect internal only, until freed 错误的处理方法

    转帖:原文地址http://blog.csdn.net/panys/article/details/3838846 archive log 日志已满ORA-00257: archiver error. ...

  7. LR回放https协议脚本失败: 错误 -27778: 在尝试与主机“www.baidu.com”connect 时发生 SSL 协议错误

    今天用LR录制脚本协议为https协议,回放脚本时出现报错: Action.c(14): 错误 -27778: 在尝试与主机"www.baidu.com"connect 时发生 S ...

  8. 关于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 ...

  9. DEBUG : Eclipse Debug 时出现 Cannot connect to VM select failed错误

    Eclipse在执行Debug操作时, 出现“Eclipse Debug 时出现 "Cannot connect to VM select failed"”错误, 在网上查找该错误 ...

随机推荐

  1. 记录一下Maven整合spring,hibernate,strusts2我程序中出的bug

    action类如下 package com.itheima.movenweb.action; import java.util.List; import org.apache.struts2.Serv ...

  2. pandas数据处理基础——筛选指定行或者指定列的数据

    pandas主要的两个数据结构是:series(相当于一行或一列数据机构)和DataFrame(相当于多行多列的一个表格数据机构). 本文为了方便理解会与excel或者sql操作行或列来进行联想类比 ...

  3. CRM客户关系管理系统(十)

    第十章.kingadmin+admin+actions功能开发 10.1. django admin的action  可以自己写个函数执行批量操作 crm/admin.py 后台admin actio ...

  4. java main方法执行sql语句

    public static void main(String[] args) throws Exception{ String driver = "oracle.jdbc.driver.Or ...

  5. 使用SecureCRT的SFTP在WINDOWS与LINUX之间传输文件(转载)

    参考文献: http://ice-k.iteye.com/blog/1068275 http://www.cnblogs.com/chen1987lei/archive/2010/11/26/1888 ...

  6. 双机热备ROSE HA工作原理

    双机热备ROSE HA工作原理 当双机热备软件启动后,ROSE HA首先启动HA Manager管理程序,根据高可靠性系统的配置结构初始化,然后启动必要的服务和代理程序来监控和管理系统服务.HA代理程 ...

  7. .net Entity Framework初识1

    利用EF可以直接操纵数据库,在一些简单的项目里甚至完全不用写sql. 一 code first 1.在web.config中设置连接字符串 这一步可以省略.如果跳过这一步,程序会默认生成一个可用的连接 ...

  8. FFMpeg编译之路

    为了编译这个东西,快折腾了一个星期了.期间经历了很多痛苦的过程,今天我把整个过程,以及在这个过程的感悟写下来,以备日后查看,也希望能帮到一些像我一样的兄弟姐妹. 在这一个星期里前前后后加起来总共使用了 ...

  9. FFPLAY的原理(三)

    播放声音 现在我们要来播放声音.SDL也为我们准备了输出声音的方法.函数SDL_OpenAudio()本身就是用来打开声音设备的.它使用一个叫做SDL_AudioSpec结构体作为参数,这个结构体中包 ...

  10. 关于JAVA中异常处理的简单阐释.

    ---恢复内容开始--- 这是我的一篇要在博客园发布的随笔,主要是简单的概括一下我本次所学的关于异常处理的知识.有讲的不妥当的地方,或者有需要补充的,还请各位高人给指点,共同学习,虚心求学.谢谢啦~ ...