2016-10-26 40 views
1

我为Jenkins ver安装了docker容器。 2.19.1。获取jenkins.BadHTTPException当试图从码头上运行的jenkins获取版本信息

docker ps 
CONTAINER ID  IMAGE    COMMAND     CREATED    STATUS    PORTS            NAMES 
f03c10935bb3  jenkins    "/bin/tini -- /usr/lo" 29 hours ago  Up 3 hours   0.0.0.0:8080->8080/tcp, 0.0.0.0:50000->50000/tcp cocky_colden 

安装python-jenkins模块访问jenkins服务器。

我试着在docs中给出的第一个代码示例。

import jenkins 

server = jenkins.Jenkins('http://localhost:8080', username='admin', password='mytoken') 
user = server.get_whoami() 
version = server.get_version() 
print('Hello %s from Jenkins %s' % (user['fullName'], version)) 

但它给出错误。

python /tmp/test.py 
Traceback (most recent call last): 
    File "/tmp/test.py", line 5, in <module> 
    version = server.get_version() 
    File "/usr/lib/python2.7/site-packages/jenkins/__init__.py", line 616, in get_version 
    % self.server) 
jenkins.BadHTTPException: Error communicating with server[http://localhost:8080/] 

我检查里面提到的文档:

从詹金斯vesion 1.426以后就可以进行身份​​验证时对詹金斯实例的用户指定的API令牌,而不是你真正的密码。

我用密码而不是token但得到相同的错误。

我试图curl

curl -X POST http://localhost:8080/job/testjob/build \ 
> --data token=mytoken \ 
> --data-urlencode json='{"parameter": [{"name":"id", "value":"123"}, {"name":"verbosity", "value":"high"}]}' 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/> 
<title>Error 403 No valid crumb was included in the request</title> 
</head> 
<body><h2>HTTP ERROR 403</h2> 
<p>Problem accessing /job/testjob/build. Reason: 
<pre> No valid crumb was included in the request</pre></p><hr><i><small>Powered by Jetty://</small></i><hr/> 

</body> 
</html> 

我从令牌名称 - >配置 - >显示API令牌...

还有什么我已经从詹金斯侧,使访问?意味着,API将访问此服务器?

+1

我有同样的问题,并解决它:' sudo apt-get install python-setuptools' –

+0

它也适合你吗? –

+0

我有完全相同的问题。在我的情况下安装python-setuptools没有帮助。 – Enfors

回答

2

尝试检查詹金斯的安全设置 - 那些原来是我的情况的问题。

+0

谢谢Enfors,这对我有用 – Nilesh

+0

很高兴能够提供帮助! – Enfors

5

get_version()函数中似乎有一个小错误。

如果詹金斯服务器启用设置的安全性和IF匿名用户不具备“整体阅读的权利,那么你需要通过授权钥匙的urlopen()

即文件”在詹金斯/ __ init__.py需要从改变”中,get_version()函数

def get_version(self): 
    try: 
     request = Request(self._build_url('')) 
     request.add_header('X-Jenkins', '0.0') 
     response = urlopen(request, timeout=self.timeout) 

到:

def get_version(self): 
    try: 
     request = Request(self._build_url('')) 
     if self.auth: 
      request.add_header('Authorization', self.auth) 
     request.add_header('X-Jenkins', '0.0') 
     response = urlopen(request, timeout=self.timeout) 

要查找这个模块是你的系统上,运行python,然后输入:

import jenkins 
jenkins.__file__ 

(我已报告的错误到模块的作者)

+0

这节省了我的一天。非常感谢你挖掘这个bug。 – MasonWinsauer