jenkins 构建时 ERROR: transport error 202: bind failed: 地址已在使用

2024-08-27 16:08

本文主要是介绍jenkins 构建时 ERROR: transport error 202: bind failed: 地址已在使用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

环境

jenkins:2.25
java:1.7

场景

最近jenkins在自动构建项目时,总是失败;提示的错误信息如下:

ERROR: transport error 202: bind failed: 地址已在使用
ERROR: JDWP Transport dt_socket failed to initialize, TRANSPORT_INIT(510)
JDWP exit error AGENT_ERROR_TRANSPORT_INIT(197): No transports initialized [../../../src/share/back/debugInit.c:750]
FATAL ERROR in native method: JDWP No transports initialized, jvmtiError=AGENT_ERROR_TRANSPORT_INIT(197)

因为是play项目,所以构建时,我需要执行play precompile命令,上面错误,就是执行这道命令产生。
其实原因我是知道的,就是端口占用了,play编译时,需要使用8000端口,但是服务器上没有程序占用这个端口啊?

后面我分析,因为我沙盒和预正式都配置了该项目的自动升级,所以当检测到代码提交时,两个同时触发构建,总有那么一瞬间,该端口会被占用。

这里写图片描述

解决办法

第一步

将其中一个的SCM的时间该长点,比如我把预正式的改为H/3 * * * *,沙盒的是H/2 * * * *

这里写图片描述

第二步

这里写图片描述

构建触发器中选择Build after other projects are built
Projects to watch中,输入项目名称,当输入前几个字母后,其会模糊匹配出已有的项目;上图就是我沙盒项目的名称;
再勾选Trigger even if the build fails,表示,即使项目构建失败,也触发该项目构建。

成功后,会在(我的项目为zygt-web-test)页面中看到如下:

这里写图片描述

总结

写这博客的时候,有时会想,要是沙盒那个项目构建失败了怎么办?

jenkins在构建后操作这个阶段,有失败重试的机制,但是在构建Execute shell这个阶段没有。

所以出了问题,往往需要人工手动构建,或者等待下一回合。

本篇的问题根源是端口占用,即同一时间,同时构建两个相同端口号的项目,
更好的做法,是将这两个项目的构建时间错开了!

我的经历:
①仅仅只是错开时间,依然会出现这个问题;
②在编译项目之前,不管三七二十一,都强杀端口8000,—-依然没用。
③按照上面的流程,关键是第二步,虽然有时也会出错,但是其会上个项目构建完成后,紧接着立即构建,至少不需要人工干预了,效果如下图:

这里写图片描述

构建失败后,其立马又构建了一次,并且成功了;这里的立马,其实是,上个项目zygt-web-test构建完成,而此次又构建失败,所以jenkins又构建了一次。

修改

================2018年5月9号================start============
上面那个思路,虽然zygt-web-pre,这个项目虽然OK,但是zygt-web-test一旦出了问题,不人工点击构建,依然不会自动构建。

今天我换了个做法,从脚本入手,把脚本修改了下:

完整脚本:tcwhile.sh

#!/bin/bash

tc=$1
projectName=$2
if [[ "x" != "x$tc" ]] && [[ "$tc" =~ "错误" || "$tc" =~ "error" || "$tc" =~ "Exception" || "$tc" =~ "exception" ]]
thenecho "=====编译出错====="sleep 2secho "睡2秒,再次执行编译"count=1path=`dirname $0`while [[ "$count" -le 2 ]]; docd $path/$projectNameecho `pwd`tc=`play precompile 2>&1`if [[ "$tc" =~ "Done" ]]thenecho $countbreak;ficount=$((count+1))echo $countdoneecho "$tc"exit 1
elseecho "=====编译成功====="echo "$tc"
fi

我的构建脚本是这样的:

#!/bin/bash
export PATH=/opt/play-1.2.7:$PATH
#获得当前目录
cur=$(pwd)
echo "pwd:"${cur}
fielName="ggnews-web-test"#编译
tc=`play precompile 2>&1`# 验证编译是否出错
${WORKSPACE%/*}/tcwhile.sh "$tc" "$JOB_NAME"#进行打包和压缩,方便传输
rm -rf ${fielName}.tar.gz
rm -rf ./public/*
cp -r cdn/* public/
tar -czf ${fielName}.tar.gz ./app/* ./precompiled ./public

假设编译出错了,我上面的脚本,会休眠2秒后,再去执行编译,要是还是失败,就再循环一次,再编译一次,成功就break出来,失败,就把错误信息打印出来!
================2018年5月9号================end============

这篇关于jenkins 构建时 ERROR: transport error 202: bind failed: 地址已在使用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112145

相关文章

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

如何使用Java实现请求deepseek

《如何使用Java实现请求deepseek》这篇文章主要为大家详细介绍了如何使用Java实现请求deepseek功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1.deepseek的api创建2.Java实现请求deepseek2.1 pom文件2.2 json转化文件2.2

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

C++ Primer 多维数组的使用

《C++Primer多维数组的使用》本文主要介绍了多维数组在C++语言中的定义、初始化、下标引用以及使用范围for语句处理多维数组的方法,具有一定的参考价值,感兴趣的可以了解一下... 目录多维数组多维数组的初始化多维数组的下标引用使用范围for语句处理多维数组指针和多维数组多维数组严格来说,C++语言没

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2