码迷,mamicode.com
首页 > 其他好文 > 详细

jenkins 安装 SVN Publisher 后向 svn 提交代码报错: E170001: Authentication required for...

时间:2015-03-20 14:30:51      阅读:1022      评论:0      收藏:0      [点我收藏+]

标签:

问题描述

    安装并启动 jenkins 后,添加了 SVN Publisher 插件,然后在构建任务的“构建后操作”操作中添加了“Publish to Subversion repository”相关的配置,如图所示:

技术分享
但是每次构建完成之后并没有将对应的 jar 包成功提交到 svn 仓库中,在 jenkins 构建任务的“Console Output”页面中也并没有提示相关的错误信息。

系统环境

操作系统:CentOS 6.5

JDK: 1.6.0_45

Jenkins:1.602

问题分析

    因为构建任务的“Console Output”页面没有显示任何错误信息,所以就查看 jenkins 的日志文件(/var/log/jenkins/jenkins.log)了。在日志文件的末尾处看到了相关的错误信息:

Mar 20, 2015 6:28:39 PM com.mtvi.plateng.subversion.SVNForceImport forceImport
INFO: null Name
SVNForceImport Error: svn: E170001: Authentication required for '<http://svn-server:80> CentOS Code Slave SVN1.7.16 Server'
Mar 20, 2015 6:28:40 PM com.mtvi.plateng.subversion.SVNForceImport forceImport
SEVERE: *SVNForceImport Error: svn: E170001: Authentication required for '<http://svn-server:80> CentOS Code Slave SVN1.7.16 Server'
从上述错误信息可得知是因为 SVN 的安全认证失败了,从而导致文件没有被正确提交到 SVN。于是尝试通过“系统管理”-->“系统设置”,修改 SVN Publisher 插件的全局设置,将 SVN 的用户名和密码给保存上,如下图所示:
技术分享

然后,重新执行对应的构建任务,发现问题依然存在,而且日志文件中的错误信息也还一模一样,所以只能继续寻找其他解决方案。最后终于在 stackoverflow 上找到了对应的解决方案,具体操作如下。

解决方案

1. 修改用户 jenkins 的默认 shell,将 /etc/passwd 文件中以 jenkins 开头的那一行末尾处的 /bin/false 改为 /bin/bash,修改后的结果为:

技术分享

2. 安装 subversion(如果没有安装过的话): # yum install subversion

3. 将 Linux 终端换为 jenkins 用户: # su - jenkins

4. 删除 ~/.subversion 目录(如果存在的话): $ rm -fr ~/.subversion

5. 执行一下 svn  的 checkout 操作,目的是保存 svn 的用户名和密码: $ svn checkout --username dev-ci(你的 SVN 用户名) http://svn-server/testRepository/trunk/,输入完密码后,会询问你是否需要保存密码,输入 yes 以保存 SVN 密码。

    至此,所有操作已经完成。你只需重新回到 jenkins 的视图页面,重新执行对应的构建任务即可。本次执行完成后,“Console Output”页面的末尾处多输出了几条将文件提交到 SVN 的信息:

SVN Publisher: target: /var/lib/jenkins/jobs/my-jenkins-task/workspace/target
SVN Publisher: Deleting Remote Item: xxx.jar
SVN Publisher: Importing Item: xxx.jar
Finished: SUCCESS
使用 TortoiseSVN 浏览版本库,看到确实将对应的 jar 提交上来了:

技术分享
参考资料:
http://stackoverflow.com/questions/18417597/svn-checkout-not-working-for-jenkins
http://stackoverflow.com/questions/17464993/jenkins-cannot-acces-to-svn-https

jenkins 安装 SVN Publisher 后向 svn 提交代码报错: E170001: Authentication required for...

标签:

原文地址:http://blog.csdn.net/hemingwang0902/article/details/44488897

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!