目录
- 一. 常用设置
- 二. 一些坑
- 问题1. Error fetching remote repo ‘origin’ caused by: ... command "git clean -fdx" returned status code 1: .... permission denied
- 问题2. package ... is already associated with another repository.
- 问题3. 构建失败但不显示错误
- 问题4. dial tcp 151.101.228.133:443: connect: connection refused
- 问题5. The JVM should have exited but did not.
- 问题6. Failed to connect to api.github.com/13.250.168.23:443
- 问题7. 反向代理设置有误,导致始终无法加载
- 问题8. warning: failed to remove src/boat-house-android-proj/.gradle/buildOutputCleanup/outputFiles.bin: Permission denied
- 问题9. found orphan containers (xxxx) for this project.If you removed or renamed this service in your compose file, you can run this command with the --remove-orphans flag to clean it up.
- 问题10. 初始化时,插件安装失败
一. 常用设置
修改Jenkinsfile的路径
注意大小写
修改时区
【系统管理】->【脚本命令行】运行下面的命令
System.setProperty('org.apache.commons.jelly.tags.fmt.timeZone', 'Asia/Shanghai')
一旦容器重启就失效了,所以要进入到用户设置里面,修改 用户自定义时区
允许匿名用户访问
系统设置 >> 全局安全设置,勾选 “匿名用户具有可读权限”
自动删除过期的流水线
为防止无用的数据占用太多的存储空间,可以配置自动删除策略。
jenkins首页,点击任务链接 >> 配置 >> 勾选 删除旧的流水线,设置 保留旧的流水线的最大数
二. 一些坑
问题1. Error fetching remote repo ‘origin’ caused by: ... command "git clean -fdx" returned status code 1: .... permission denied
分析:
这个步骤在jenkinsfile中没有配置,是系统的默认行为,看日志是在 clean git -fdx 的时候删除文件没有权限导致的。
所能想到的办法就是删除workspace中的文件,重新来过
解决方法:
进入workspace文件夹,删除里面的全部文件,再重新触发流水线
遗留问题:
- 为什么git clean要去删除target目录下的文件
- 为什么有两个workspace目录,而真正起作用确不是docker中配置的
问题2. package ... is already associated with another repository.
分析:package 不在指定的git库下面
解决方案:查看printdev信息,找到变量的值(如果是全局变量,建议直接在jenkins file脚本中写死repo的路径)
到指定的位置修改该变量的值
问题3. 构建失败但不显示错误
找到错误的办法:
点击 构建历史,点击历史构建中对应的 图标
问题4. dial tcp 151.101.228.133:443: connect: connection refused
分析:github的相应域名背后是有cdn服务的,但是cdn指向的ip通常只是近一些,比如日本之类的亚洲IP,但是访问并不稳定,需要使用https://www.ipaddress.com/ 查看到对应的域名能够快速的访问的ip
解决方案:
- 在hosts里面增加配置的方式,暂时解决了问题,很难确保后续IP是否会变动
sudo vim /etc/hosts
增加如下内容:
140.82.114.34 docker.pkg.github.com
199.232.68.133 githubusercontent.com
199.232.68.133 pkg.githubusercontent.com
140.82.112.6 api.github.com
- 使用acr(容器注册表)的方式,即把package存储到本地的服务器,这种方式需要评估费用,并做好调试
问题5. The JVM should have exited but did not.
The following non-daemon threads are still running (DestroyJavaVM is OK):
Thread[AWT-Shutdown,5,system], stackTrace:java.lang.Object#wait
sun.awt.AWTAutoShutdown#run at line:314
java.lang.Thread#run at line:748
分析:发生这种情况是由于BeanShell服务器正在运行,由于某种原因而没有退出。结果,java进程将永远不会退出并且会挂起。
解决方案:
如果jmeter是docker部署的,那么加上
--systemproperty jmeterengine.force.system.exit=true
docker run --interactive --rm --volume `pwd`/test/jmeter:/jmeter egaillardon/jmeter --nongui --testfile boat-house.jmx --logfile output/result.jtl -Jdomain=HOST -e -o ./output --systemproperty jmeterengine.force.system.exit=true
问题6. Failed to connect to api.github.com/13.250.168.23:443
分析:
出现这种问题的时候Github站点访问一般都有问题,要不就是访问过慢,要不就是500错误
遗留问题:
设置了host,确定不是这个IP;运行命令的jenkins服务器IP也不是这个;我所有部署的服务器都不是这个IP。
所以我的疑问有两个
- 这个斜杠后面的IP究竟代表什么
- 这个IP是从哪里来的
问题7. 反向代理设置有误,导致始终无法加载
分析:按照wiki上的说明,分别对jenkins系统 以及 blue 插件进行配置
参考:https://wiki.jenkins.io/display/JENKINS/Jenkins+says+my+reverse+proxy+setup+is+broken
https://wiki.jenkins.io/display/JENKINS/Running+Jenkins+behind+Nginx
问题8. warning: failed to remove src/boat-house-android-proj/.gradle/buildOutputCleanup/outputFiles.bin: Permission denied
分析:没有权限,jenkins流水线一开始跑的时候,都会运行 git clean -fdx,以确保删除build过程产生的文件,从而保证每次build都是最新的
解决方案:
post {
always {
# 删除所有没有版本管理的文件,在jenkins流水线一开是
sh "sudo git clean -fdx"
# 太暴力,不建议使用,删除所有文件,意味着流水线下一次要重新下载所有文件
# sh "sudo rm -rf *"
# 删除指定的文件夹,这种做法不通用,增加了复杂度
sh "sudo rm -rf src/product-service/api/target"
sh "sudo rm -rf src/account-service/api/target"
}
}
问题9. found orphan containers (xxxx) for this project.If you removed or renamed this service in your compose file, you can run this command with the --remove-orphans flag to clean it up.
解决方案:查看是否缺少基础镜像
问题10. 初始化时,插件安装失败
解决方案:进入linux,删除jenkins容器,删除jenkins容器的运行目录,重新配置和安装
标签:实战,删除,--,问题,clean,jenkins,Jenkins,com From: https://www.cnblogs.com/smallidea/p/16987620.html