我正在使用Selenium从客户端自动化服务器中的浏览器,但我希望服务器在启动时自动执行selenium。
我在/ etc / init中有3个文件:
proxyserver.conf:
respawn
start on runlevel [23]
script
exec java -jar selenium-server-standalone-2.20.0.jar -role hub -port 1111
end script
proxyserver2.conf 和 proxyserver3.conf 这些是相同的,只更改“脚本”的内容:
exec java -Dwebdriver.chrome.driver=/home/marco/selenium-client/chromedriver -jar selenium-server-standalone-2.20.0.jar -role node -port 2222 -hub http://192.168.1.12:1111 -browserName=chrome,maxInstances=5
如果我在启动时使用此方法执行此命令,当我在客户端上执行Selenium时,它会给我这个错误:
Exception in thread "main" org.openqa.selenium.remote.UnreachableBrowserException: Could not start a new session. Possible causes are invalid address of the remote server or browser start-up failure.
但是如果我在终端中执行与/ etc / init中使用的命令相同的命令,那么一切都很完美......为什么?!
最后一件事,如果我执行:
ps aux | grep selenium
当服务器启动脚本时它给了我:
root 746 0.0 12.1 677080 124468 ? Ssl Apr23 8:10 java -Dwebdriver...
root 749 0.0 12.7 685552 130280 ? Ssl Apr23 8.09 java -Dwebdriver...
root 755 0.0 1.9 680168 20240 ? Ssl Apr23 8.08 java -jar selenium...
当我在终端执行时,它给了我:
1000 9764 6.6 3.0 679236 30992 pts/0 Sl+ 10.33 0:01 java -jar...
1000 9783 14.0 3.0 677112 31752 pts/1 Sl+ 10.33 0:01 java -Dwebdriver...
1000 9792 12.6 3.0 675472 30944 pts/2 Sl+ 10.34 0:01 java -Dwebdriver...
为什么它不起作用?
谢谢!
答案 0 :(得分:0)
当chromedriver路径错误时,我看到了这个错误。如果您看到RC控制台,则应该找不到chromedriver错误消息。
chromedriver环境属性应作为参数传递给selenium jar文件。
exec java -Dwebdriver.chrome.driver=/home/marco/selenium-client/chromedriver -jar selenium-server-standalone-2.20.0.jar -role node -port 2222 -hub http://192.168.1.12:1111 -browserName=chrome,maxInstances=5
应改为
exec java -jar selenium-server-standalone-2.20.0.jar -role node -port 2222 -hub http://192.168.1.12:1111 -browserName=chrome,maxInstances=5 -Dwebdriver.chrome.driver=/home/marco/selenium-client/chromedriver