返回到文章
优化文章格式

采纳

编辑于 3年前

引用的路径:

static {
        ClassLoader loader = Thread.currentThread().getContextClassLoader();
        System.setProperty("java.security.auth.login.config",
                loader.getResource("").getPath() + File.separator + "com/shenyue/collectionpro/kafka_client_jaas.conf");
    }

文件内容:

KafkaClient {
    org.apache.kafka.common.security.plain.PlainLoginModule required
    username="*****"
    password="****";
};
2021-08-13 09:03:00.786  INFO 4576 --- [   scheduling-1] o.a.k.clients.producer.KafkaProducer     : [Producer clientId=producer-4] Closing the Kafka producer with timeoutMillis = 0 ms.
2021-08-13 09:03:00.786 ERROR 4576 --- [   scheduling-1] o.s.s.s.TaskUtils$LoggingErrorHandler    : Unexpected error occurred in scheduled task
org.apache.kafka.common.KafkaException: Failed to construct kafka producer
    at org.apache.kafka.clients.producer.KafkaProducer.<init>(KafkaProducer.java:434) ~[kafka-clients-2.5.1.jar!/:na]
    at org.apache.kafka.clients.producer.KafkaProducer.<init>(KafkaProducer.java:287) ~[kafka-clients-2.5.1.jar!/:na]
    at org.springframework.kafka.core.DefaultKafkaProducerFactory.createRawProducer(DefaultKafkaProducerFactory.java:668) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
    at org.springframework.kafka.core.DefaultKafkaProducerFactory.createKafkaProducer(DefaultKafkaProducerFactory.java:542) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
    at org.springframework.kafka.core.DefaultKafkaProducerFactory.doCreateProducer(DefaultKafkaProducerFactory.java:519) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
    at org.springframework.kafka.core.DefaultKafkaProducerFactory.createProducer(DefaultKafkaProducerFactory.java:480) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
    at org.springframework.kafka.core.DefaultKafkaProducerFactory.createProducer(DefaultKafkaProducerFactory.java:474) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
    at org.springframework.kafka.core.KafkaTemplate.getTheProducer(KafkaTemplate.java:665) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
    at org.springframework.kafka.core.KafkaTemplate.doSend(KafkaTemplate.java:551) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
    at org.springframework.kafka.core.KafkaTemplate.send(KafkaTemplate.java:363) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
    at com.shenyue.collectionpro.mdb.Business.AccessServerBusiness.business(AccessServerBusiness.java:56) ~[classes!/:2.4.0]
    at com.shenyue.collectionpro.mdb.convert.DBConvert.convertType(DBConvert.java:158) ~[classes!/:2.4.0]
    at com.shenyue.collectionpro.mdb.service.impl.TestServicelmpl.testMedthod(TestServicelmpl.java:22) ~[classes!/:2.4.0]
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_191]
    at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[na:1.8.0_191]
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[na:1.8.0_191]
    at java.lang.reflect.Method.invoke(Unknown Source) ~[na:1.8.0_191]
    at org.springframework.scheduling.support.ScheduledMethodRunnable.run(ScheduledMethodRunnable.java:84) ~[spring-context-5.2.10.RELEASE.jar!/:5.2.10.RELEASE]
    at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54) ~[spring-context-5.2.10.RELEASE.jar!/:5.2.10.RELEASE]
    at org.springframework.scheduling.concurrent.ReschedulingRunnable.run(ReschedulingRunnable.java:93) [spring-context-5.2.10.RELEASE.jar!/:5.2.10.RELEASE]
    at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) [na:1.8.0_191]
    at java.util.concurrent.FutureTask.run(Unknown Source) [na:1.8.0_191]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(Unknown Source) [na:1.8.0_191]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(Unknown Source) [na:1.8.0_191]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) [na:1.8.0_191]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) [na:1.8.0_191]
    at java.lang.Thread.run(Unknown Source) [na:1.8.0_191]
Caused by: java.lang.SecurityException: java.io.IOException: 配置错误: 没有此文件或目录
    at sun.security.provider.ConfigFile$Spi.<init>(Unknown Source) ~[na:1.8.0_191]
    at sun.security.provider.ConfigFile.<init>(Unknown Source) ~[na:1.8.0_191]
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) ~[na:1.8.0_191]
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) ~[na:1.8.0_191]
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) ~[na:1.8.0_191]
    at java.lang.reflect.Constructor.newInstance(Unknown Source) ~[na:1.8.0_191]
    at java.lang.Class.newInstance(Unknown Source) ~[na:1.8.0_191]
    at javax.security.auth.login.Configuration$2.run(Unknown Source) ~[na:1.8.0_191]
    at javax.security.auth.login.Configuration$2.run(Unknown Source) ~[na:1.8.0_191]
    at java.security.AccessController.doPrivileged(Native Method) ~[na:1.8.0_191]
    at javax.security.auth.login.Configuration.getConfiguration(Unknown Source) ~[na:1.8.0_191]
    at org.apache.kafka.common.security.JaasContext.defaultContext(JaasContext.java:114) ~[kafka-clients-2.5.1.jar!/:na]
    at org.apache.kafka.common.security.JaasContext.load(JaasContext.java:98) ~[kafka-clients-2.5.1.jar!/:na]
    at org.apache.kafka.common.security.JaasContext.loadClientContext(JaasContext.java:84) ~[kafka-clients-2.5.1.jar!/:na]
    at org.apache.kafka.common.network.ChannelBuilders.create(ChannelBuilders.java:134) ~[kafka-clients-2.5.1.jar!/:na]
    at org.apache.kafka.common.network.ChannelBuilders.clientChannelBuilder(ChannelBuilders.java:73) ~[kafka-clients-2.5.1.jar!/:na]
    at org.apache.kafka.clients.ClientUtils.createChannelBuilder(ClientUtils.java:105) ~[kafka-clients-2.5.1.jar!/:na]
    at org.apache.kafka.clients.producer.KafkaProducer.newSender(KafkaProducer.java:442) ~[kafka-clients-2.5.1.jar!/:na]
    at org.apache.kafka.clients.producer.KafkaProducer.<init>(KafkaProducer.java:423) ~[kafka-clients-2.5.1.jar!/:na]
    ... 26 common frames omitted
Caused by: java.io.IOException: 配置错误: 没有此文件或目录
    at sun.security.provider.ConfigFile$Spi.init(Unknown Source) ~[na:1.8.0_191]
    at sun.security.provider.ConfigFile$Spi.init(Unknown Source) ~[na:1.8.0_191]
    ... 45 common frames omitted

提问说明

1、KafkaClient {
org.apache.kafka.common.security.plain.PlainLoginModule required
username="*"
password="**";
};

代码块

2021-08-13 09:03:00.786 INFO 4576 --- [ scheduling-1] o.a.k.clients.producer.KafkaProducer : [Producer clientId=producer-4] Closing the Kafka producer with timeoutMillis = 0 ms.
2021-08-13 09:03:00.786 ERROR 4576 --- [ scheduling-1] o.s.s.s.TaskUtils$LoggingErrorHandler : Unexpected error occurred in scheduled task

org.apache.kafka.common.KafkaException: Failed to construct kafka producer
at org.apache.kafka.clients.producer.KafkaProducer.(KafkaProducer.java:434) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.clients.producer.KafkaProducer.(KafkaProducer.java:287) ~[kafka-clients-2.5.1.jar!/:na]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.createRawProducer(DefaultKafkaProducerFactory.java:668) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.createKafkaProducer(DefaultKafkaProducerFactory.java:542) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.doCreateProducer(DefaultKafkaProducerFactory.java:519) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.createProducer(DefaultKafkaProducerFactory.java:480) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.createProducer(DefaultKafkaProducerFactory.java:474) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.KafkaTemplate.getTheProducer(KafkaTemplate.java:665) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.KafkaTemplate.doSend(KafkaTemplate.java:551) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.KafkaTemplate.send(KafkaTemplate.java:363) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at com.shenyue.collectionpro.mdb.Business.AccessServerBusiness.business(AccessServerBusiness.java:56) ~[classes!/:2.4.0]
at com.shenyue.collectionpro.mdb.convert.DBConvert.convertType(DBConvert.java:158) ~[classes!/:2.4.0]
at com.shenyue.collectionpro.mdb.service.impl.TestServicelmpl.testMedthod(TestServicelmpl.java:22) ~[classes!/:2.4.0]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_191]
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[na:1.8.0_191]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[na:1.8.0_191]
at java.lang.reflect.Method.invoke(Unknown Source) ~[na:1.8.0_191]
at org.springframework.scheduling.support.ScheduledMethodRunnable.run(ScheduledMethodRunnable.java:84) ~[spring-context-5.2.10.RELEASE.jar!/:5.2.10.RELEASE]
at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54) ~[spring-context-5.2.10.RELEASE.jar!/:5.2.10.RELEASE]
at org.springframework.scheduling.concurrent.ReschedulingRunnable.run(ReschedulingRunnable.java:93) [spring-context-5.2.10.RELEASE.jar!/:5.2.10.RELEASE]
at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.FutureTask.run(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) [na:1.8.0_191]
at java.lang.Thread.run(Unknown Source) [na:1.8.0_191]
Caused by: java.lang.SecurityException: java.io.IOException: 配置错误:
没有此文件或目录
at sun.security.provider.ConfigFile$Spi.(Unknown Source) ~[na:1.8.0_191]
at sun.security.provider.ConfigFile.(Unknown Source) ~[na:1.8.0_191]
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) ~[na:1.8.0_191]
at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) ~[na:1.8.0_191]
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) ~[na:1.8.0_191]
at java.lang.reflect.Constructor.newInstance(Unknown Source) ~[na:1.8.0_191]
at java.lang.Class.newInstance(Unknown Source) ~[na:1.8.0_191]
at javax.security.auth.login.Configuration$2.run(Unknown Source) ~[na:1.8.0_191]
at javax.security.auth.login.Configuration$2.run(Unknown Source) ~[na:1.8.0_191]
at java.security.AccessController.doPrivileged(Native Method) ~[na:1.8.0_191]
at javax.security.auth.login.Configuration.getConfiguration(Unknown Source) ~[na:1.8.0_191]
at org.apache.kafka.common.security.JaasContext.defaultContext(JaasContext.java:114) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.common.security.JaasContext.load(JaasContext.java:98) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.common.security.JaasContext.loadClientContext(JaasContext.java:84) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.common.network.ChannelBuilders.create(ChannelBuilders.java:134) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.common.network.ChannelBuilders.clientChannelBuilder(ChannelBuilders.java:73) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.clients.ClientUtils.createChannelBuilder(ClientUtils.java:105) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.clients.producer.KafkaProducer.newSender(KafkaProducer.java:442) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.clients.producer.KafkaProducer.(KafkaProducer.java:423) ~[kafka-clients-2.5.1.jar!/:na]
... 26 common frames omitted
Caused by: java.io.IOException: 配置错误:
没有此文件或目录
at sun.security.provider.ConfigFile$Spi.init(Unknown Source) ~[na:1.8.0_191]
at sun.security.provider.ConfigFile$Spi.init(Unknown Source) ~[na:1.8.0_191]
... 45 common frames omitted

记录

编辑于 3年前

kafka打包成服务后找不到权限文件,Caused by: java.lang.SecurityException: java.io.IOException: 配置错误: 没有此文件或目录

kafka

提问说明

1、KafkaClient {
org.apache.kafka.common.security.plain.PlainLoginModule required
username="*"
password="**";
};

代码块

2021-08-13 09:03:00.786 INFO 4576 --- [ scheduling-1] o.a.k.clients.producer.KafkaProducer : [Producer clientId=producer-4] Closing the Kafka producer with timeoutMillis = 0 ms.
2021-08-13 09:03:00.786 ERROR 4576 --- [ scheduling-1] o.s.s.s.TaskUtils$LoggingErrorHandler : Unexpected error occurred in scheduled task

org.apache.kafka.common.KafkaException: Failed to construct kafka producer
at org.apache.kafka.clients.producer.KafkaProducer.(KafkaProducer.java:434) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.clients.producer.KafkaProducer.(KafkaProducer.java:287) ~[kafka-clients-2.5.1.jar!/:na]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.createRawProducer(DefaultKafkaProducerFactory.java:668) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.createKafkaProducer(DefaultKafkaProducerFactory.java:542) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.doCreateProducer(DefaultKafkaProducerFactory.java:519) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.createProducer(DefaultKafkaProducerFactory.java:480) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.DefaultKafkaProducerFactory.createProducer(DefaultKafkaProducerFactory.java:474) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.KafkaTemplate.getTheProducer(KafkaTemplate.java:665) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.KafkaTemplate.doSend(KafkaTemplate.java:551) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at org.springframework.kafka.core.KafkaTemplate.send(KafkaTemplate.java:363) ~[spring-kafka-2.5.7.RELEASE.jar!/:2.5.7.RELEASE]
at com.shenyue.collectionpro.mdb.Business.AccessServerBusiness.business(AccessServerBusiness.java:56) ~[classes!/:2.4.0]
at com.shenyue.collectionpro.mdb.convert.DBConvert.convertType(DBConvert.java:158) ~[classes!/:2.4.0]
at com.shenyue.collectionpro.mdb.service.impl.TestServicelmpl.testMedthod(TestServicelmpl.java:22) ~[classes!/:2.4.0]
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_191]
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) ~[na:1.8.0_191]
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) ~[na:1.8.0_191]
at java.lang.reflect.Method.invoke(Unknown Source) ~[na:1.8.0_191]
at org.springframework.scheduling.support.ScheduledMethodRunnable.run(ScheduledMethodRunnable.java:84) ~[spring-context-5.2.10.RELEASE.jar!/:5.2.10.RELEASE]
at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54) ~[spring-context-5.2.10.RELEASE.jar!/:5.2.10.RELEASE]
at org.springframework.scheduling.concurrent.ReschedulingRunnable.run(ReschedulingRunnable.java:93) [spring-context-5.2.10.RELEASE.jar!/:5.2.10.RELEASE]
at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.FutureTask.run(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) [na:1.8.0_191]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) [na:1.8.0_191]
at java.lang.Thread.run(Unknown Source) [na:1.8.0_191]
Caused by: java.lang.SecurityException: java.io.IOException: 配置错误:
没有此文件或目录
at sun.security.provider.ConfigFile$Spi.(Unknown Source) ~[na:1.8.0_191]
at sun.security.provider.ConfigFile.(Unknown Source) ~[na:1.8.0_191]
at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) ~[na:1.8.0_191]
at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source) ~[na:1.8.0_191]
at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source) ~[na:1.8.0_191]
at java.lang.reflect.Constructor.newInstance(Unknown Source) ~[na:1.8.0_191]
at java.lang.Class.newInstance(Unknown Source) ~[na:1.8.0_191]
at javax.security.auth.login.Configuration$2.run(Unknown Source) ~[na:1.8.0_191]
at javax.security.auth.login.Configuration$2.run(Unknown Source) ~[na:1.8.0_191]
at java.security.AccessController.doPrivileged(Native Method) ~[na:1.8.0_191]
at javax.security.auth.login.Configuration.getConfiguration(Unknown Source) ~[na:1.8.0_191]
at org.apache.kafka.common.security.JaasContext.defaultContext(JaasContext.java:114) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.common.security.JaasContext.load(JaasContext.java:98) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.common.security.JaasContext.loadClientContext(JaasContext.java:84) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.common.network.ChannelBuilders.create(ChannelBuilders.java:134) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.common.network.ChannelBuilders.clientChannelBuilder(ChannelBuilders.java:73) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.clients.ClientUtils.createChannelBuilder(ClientUtils.java:105) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.clients.producer.KafkaProducer.newSender(KafkaProducer.java:442) ~[kafka-clients-2.5.1.jar!/:na]
at org.apache.kafka.clients.producer.KafkaProducer.(KafkaProducer.java:423) ~[kafka-clients-2.5.1.jar!/:na]
... 26 common frames omitted
Caused by: java.io.IOException: 配置错误:
没有此文件或目录
at sun.security.provider.ConfigFile$Spi.init(Unknown Source) ~[na:1.8.0_191]
at sun.security.provider.ConfigFile$Spi.init(Unknown Source) ~[na:1.8.0_191]
... 45 common frames omitted