小编Abh*_*raj的帖子

无法从 Kafka 中的消费者向死信主题发送消息

“我正在尝试将消息路由到 Kafka 中的死信主题,以防处理相应消息时出现任何失败。我已经为此功能设置了 SeektoCurrentErrorHandler 和 DeadLetterPublishingRecoverer。

消费者在执行此操作时抛出以下异常:

2020-08-07 12:09:38.841 ERROR 1 --- [ntainer#2-0-C-1] o.s.k.support.LoggingProducerListener    : Exception thrown when sending a message with key='a6558a22-470d-4708-b297-814996a42045' and payload='{123, 34, 101, 118, 101, 110, 116, 78, 97, 109, 101, 34, 58, 34, 116, 101, 115, 116, 95, 101, 120, 1...' to topic test_execution.DLT and partition 2:

org.apache.kafka.common.errors.TimeoutException: Topic test_execution.DLT not present in metadata after 60000 ms.

2020-08-07 12:09:38.846 ERROR 1 --- [ntainer#2-0-C-1] o.s.k.l.DeadLetterPublishingRecoverer    : Dead-letter publication failed for: ProducerRecord(topic=test_execution.DLT, partition=2, headers=RecordHeaders(headers = [RecordHeader(key = …
Run Code Online (Sandbox Code Playgroud)

java apache-kafka kafka-consumer-api kafka-producer-api spring-kafka

7
推荐指数
1
解决办法
3628
查看次数

Gradle 测试执行程序完成了一个非常奇怪的非零退出代码 (-1073740791)

我们在 gradle 中使用自定义测试任务,它接受包含要执行的测试列表的文本文件。除了其他参数(例如属性文件、测试结果位置等),我们还将 --no-daemon --no-build-cache --no-parallel 作为参数传递给此任务。

有时,我们在执行任务时会遇到失败。测试任务中的任务执行程序失败,并显示奇怪的非零退出代码

Caused by: org.gradle.process.internal.ExecException: Process 'Gradle Test Executor 4' finished with non-zero exit value -1073740791
This problem might be caused by incorrect test process configuration.

Run Code Online (Sandbox Code Playgroud)

这是完整的堆栈跟踪:

> Task :runTestlistFromFile FAILED
:runTestlistFromFile (Thread[Daemon worker,5,main]) completed. Took 36 mins 44.967 secs.

FAILURE: Build failed with an exception.

* What went wrong:
Execution failed for task ':runTestlistFromFile'.
> Process 'Gradle Test Executor 4' finished with non-zero exit value -1073740791
  This problem might be caused by incorrect …
Run Code Online (Sandbox Code Playgroud)

java junit jvm gradle

6
推荐指数
0
解决办法
564
查看次数

如何在通过 gradle 执行 JUnit 测试时设置 java 安全策略文件以仅避免 System.exit 调用?

我想通过 gradle 执行 JUnit 测试,我想避免在这些测试中调用 System.exit() 调用。我读过设置安全策略文件可以解决问题。

这是我正在使用的安全策略文件

grant {
    permission java.io.RuntimePermission "exitVM", "none";
};
Run Code Online (Sandbox Code Playgroud)

我在 gradle 构建文件中设置 seecurity.policy 和安全管理器属性,如下所示:

systemProperty 'java.security.policy', file(project.ext.projectHome + "/security.policy").absolutePath
jvmArgs "-Djava.security.manager"
Run Code Online (Sandbox Code Playgroud)

但是当我运行测试时,测试任务失败并显示以下堆栈跟踪:

uccessfully started process 'Gradle Test Executor 20'
Exception in thread "main" java.lang.reflect.InvocationTargetException
        at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
        at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.base/java.lang.reflect.Method.invoke(Method.java:566)
        at java.instrument/sun.instrument.InstrumentationImpl.loadClassAndStartAgent(InstrumentationImpl.java:513)
        at java.instrument/sun.instrument.InstrumentationImpl.loadClassAndCallPremain(InstrumentationImpl.java:525)
Caused by: java.lang.ExceptionInInitializerError
        at mockit.internal.state.TestRun.<init>(TestRun.java:43)
        at mockit.internal.state.TestRun.<clinit>(TestRun.java:22)
        at mockit.internal.faking.FakeMethods.registerFakeStates(FakeMethods.java:210)
        at mockit.internal.faking.FakeClassSetup.registerFakeClassAndItsStates(FakeClassSetup.java:57)
        at mockit.internal.faking.FakeClassSetup.<init>(FakeClassSetup.java:48)
        at mockit.internal.faking.FakeClassSetup.<init>(FakeClassSetup.java:35)
        at mockit.MockUp.redefineClass(MockUp.java:122)
        at mockit.MockUp.<init>(MockUp.java:80)
        at mockit.integration.junit4.FakeRunNotifier.<init>(FakeRunNotifier.java:24)
        at mockit.internal.startup.JMockitInitialization.applyInternalStartupFakesAsNeeded(JMockitInitialization.java:37)
        at mockit.internal.startup.JMockitInitialization.initialize(JMockitInitialization.java:26)
        at mockit.internal.startup.Startup.applyStartupFakes(Startup.java:58) …
Run Code Online (Sandbox Code Playgroud)

java junit gradle java-security java-security-manager

5
推荐指数
0
解决办法
85
查看次数