当前位置: 首页 > 知识库问答 >
问题:

通过电子邮件发送Jenkins错误日志(无法提取日志的错误部分)

尉迟高澹
2023-03-14

我需要提取jenkins日志中仅包含错误描述和堆栈跟踪的部分,以便我可以在电子邮件中发送它(我使用管道中的jenkins电子邮件文本插件来完成)。

例如,在下面的日志片段中,我需要“org.jenkinsci.plugins.scriptsecurity”之后的所有行


    ...
    Sending build end EMAIL
    [Pipeline] echo
    Build Number: 218
    [Pipeline] }
    [Pipeline] // stage
    [Pipeline] }
    [Pipeline] // withEnv
    [Pipeline] }
    [Pipeline] // node
    Scripts not permitted to use method hudson.model.Actionable getAction java.lang.Class. Administrators can decide whether to approve or reject this signature.
    [Pipeline] End of Pipeline
    org.jenkinsci.plugins.scriptsecurity.sandbox.RejectedAccessException: Scripts not permitted to use method hudson.model.Actionable getAction java.lang.Class
        at org.jenkinsci.plugins.scriptsecurity.sandbox.whitelists.StaticWhitelist.rejectMethod(StaticWhitelist.java:175)
        at org.jenkinsci.plugins.scriptsecurity.sandbox.groovy.SandboxInterceptor.onMethodCall(SandboxInterceptor.java:137)
        at org.kohsuke.groovy.sandbox.impl.Checker$1.call(Checker.java:155)
        at org.kohsuke.groovy.sandbox.impl.Checker.checkedCall(Checker.java:159)
        at org.kohsuke.groovy.sandbox.impl.Checker$checkedCall$0.callStatic(Unknown Source)
        at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallStatic(CallSiteArray.java:56)
        at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callStatic(AbstractCallSite.java:194)
        at WorkflowScript.sendBuildEmail(WorkflowScript:141)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
        at java.lang.reflect.Method.invoke(Unknown Source)
        at org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:93)
        at groovy.lang.MetaMethod.doMethodInvoke(MetaMethod.java:325)
        at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1213)
        at groovy.lang.MetaClassImpl.invokeMethod(MetaClassImpl.java:1022)
        at org.codehaus.groovy.runtime.callsite.PogoMetaClassSite.call(PogoMetaClassSite.java:42)
        at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:48)
        at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:113)
        at org.kohsuke.groovy.sandbox.impl.Checker$1.call(Checker.java:157)
        at org.kohsuke.groovy.sandbox.GroovyInterceptor.onMethodCall(GroovyInterceptor.java:23)
        at org.jenkinsci.plugins.scriptsecurity.sandbox.groovy.SandboxInterceptor.onMethodCall(SandboxInterceptor.java:133)
        at org.kohsuke.groovy.sandbox.impl.Checker$1.call(Checker.java:155)
        at org.kohsuke.groovy.sandbox.impl.Checker.checkedCall(Checker.java:159)
        at org.kohsuke.groovy.sandbox.impl.Checker.checkedCall(Checker.java:124)
        at com.cloudbees.groovy.cps.sandbox.SandboxInvoker.methodCall(SandboxInvoker.java:17)
        at WorkflowScript.run(WorkflowScript:131)
        at
        ...

我怎样才能做到这一点?我将感谢任何帮助

这是我的管道结构:


       pipeline {
         agent {...} 
         environment {...}
         stages {...}
         post {...}
       }

共有1个答案

轩辕瑞
2023-03-14

一种方法是将整个管道脚本包装在< code > try /< code>catch块中,然后使用< code > catch 块中的< code>mail步骤发送电子邮件。我会这样写:

try {

    // your pipeline code
    // ...

} catch (e) {
    mail subject: "${env.JOB_NAME}#${env.BUILD_NUMBER} - Failed",
         body: """
 Build: ${env.BUILD_URL}

 Error message: 
 ${e.getMessage()}

 Stack Trace:
 ${e.getStackTrace().join('\n')}
         """,
         to: 'me@email.com'

    throw e // rethrow the error so that it gets printed in the job log, and so the job fails
}

您肯定需要批准getStackTrace作为一种“安全”方法,您可能需要对getMessage执行同样的操作。

要记住的是,此try/catch不会捕获“没有这样的DSL方法”错误,根据JENKINS-45469,这似乎不是错误。

如果您对更复杂的电子邮件行为感兴趣,您可以查看扩展的电子邮件插件。

 类似资料:
  • 我们已将电子邮件服务从Mandrill更改为Amazon SES。我们将它与SMTP一起使用。 在Mandrill中,我们可以访问一些详细信息,例如: 邮件的原始内容 交货日期 是收件人查看的邮件 是否点击了邮件中的链接 但是在

  • 描述: 提交大数据查询操作,会在2min内出现504报错(时间不定,有时候是1.5min有时候是1.6min) nginx与gunicorn超时时间同样是600,测试环境设置相同timeout等未复现此问题(不过测试环境未与正式环境100%一致,没有gunicorn),可以执行到4-5分钟乃至更长 nginx error中没有504错误日志 问题:什么原因导致504,往哪个方向大概率复现 技术:

  • 主要内容:启动和设置错误日志,查看错误日志,删除错误日志错误日志(Error Log)是 MySQL 中最常用的一种日志,主要记录 MySQL 服务器启动和停止过程中的信息、服务器在运行过程中发生的故障和异常情况等。 作为初学者,要学会利用错误日志来定位问题。下面介绍如何操作查看错误日志。 启动和设置错误日志 在 MySQL 数据库中,默认开启错误日志功能。一般情况下,错误日志存储在 MySQL 数据库的数据文件夹下,通常名称为 hostname.er

  • 简介 当你开始一个新的 Lumen 项目时,Lumen 已经帮你配置好错误和异常处理的操作。另外,Lumen 也集成了 Monolog 日志函数库,Monolog 支持和提供多种强大的日志处理功能。 有关日志的更多内容,请阅读 Laravel 的完整 日志文档.

  • 我在Azure中有一个Java web应用程序,它使用Logback进行跟踪日志记录。我正在尝试将跟踪日志记录与Azure中的应用程序洞察连接起来,并且我遵循了Azure文档中的所有说明。 下面是Maven的相关部分: 我得ApplicationInsights.xml: 我的logback.xml: 我的类测试记录器和应用程序的集成: 有一些错误与性能计数器相关联。我试图找到一些关于这些错误的信

  • 在Ubuntu web服务器[LAMP]上,我试图将PHP错误写入PHP_错误文件中,但不管我做什么,它们都会进入apache日志。 以下是我所做的尝试: > 编辑了php。ini文件: error_reporting=E_ALL|E_STRICT display_error=off log_errors=On error_log /var/logphp_errors.log 重启Apache 检