網(wǎng)站首頁 編程語言 正文
?最近,在寫關(guān)于Kafka的消費(fèi)端代碼,發(fā)現(xiàn)若要消費(fèi),需要登錄的時(shí)候,對對端Kafka服務(wù)進(jìn)行認(rèn)證,研究了一番,以下將代碼放出來
參考了文章
Kafka配置安全認(rèn)證_月下茶涼的博客-CSDN博客_kafka安全認(rèn)證Kafka配置安全認(rèn)證提示:本人提示:寫完文章后,目錄可以自動(dòng)生成,如何生成可參考右邊的幫助文檔文章目錄系列文章目錄前言一、pandas是什么?二、使用步驟1.引入庫2.讀入數(shù)據(jù)總結(jié)前言提示:這里可以添加本文要記錄的大概內(nèi)容:例如:隨著人工智能的不斷發(fā)展,機(jī)器學(xué)習(xí)這門技術(shù)也越來越重要,很多人都開啟了學(xué)習(xí)機(jī)器學(xué)習(xí),本文就介紹了機(jī)器學(xué)習(xí)的基礎(chǔ)內(nèi)容。提示:以下是本篇文章正文內(nèi)容,下面案例可供參考一、pandas是什么?示例:pan..https://blog.csdn.net/qq_42057890/article/details/117564848java?登錄代碼
// 注意 kafka_client_jaas.conf 是認(rèn)證登錄配置文件,里面記錄使用了什么登錄方式和登錄賬號密碼
// 如果沒有這個(gè)文件,程序運(yùn)行的時(shí)候可能沒有任何提示并且無法消費(fèi)數(shù)據(jù)!
System.setProperty("java.security.auth.login.config","kafka_client_jaas.conf");
Properties props = new Properties();
props.put("bootstrap.servers", "xxx.xxx.xxx.xxx");
props.put("group.id", UUID.randomUUID().toString());
props.put("enable.auto.commit", "true");
props.put("auto.commit.interval.ms", "1000");
props.put("key.deserializer", StringDeserializer.class.getName());
props.put("value.deserializer", StringDeserializer.class.getName());
props.put("auto.offset.reset","earliest");
//加密傳輸協(xié)議
props.put("security.protocol","SASL_PLAINTEXT");
//加密方式
props.put("sasl.mechanism","SCRAM-SHA-256");
//載入?yún)?shù)
KafkaConsumer kafkaConsumer = new KafkaConsumer(props);
kafka_client_jaas.conf?文件配置
KafkaClient {
org.apache.kafka.common.security.plain.PlainLoginModule required
username="XXXX"
password="XXXX";
};
注意!
這里演示的是使用了
org.apache.kafka.common.security.plain.PlainLoginModule?模塊
也有可能會使用其他模塊,例如我項(xiàng)目需要用到
org.apache.kafka.common.security.scram.ScramLoginModule
如果使用了錯(cuò)誤模塊,運(yùn)行程序的時(shí)候可能沒有任何提示,并且不能消費(fèi)數(shù)據(jù)!
原文鏈接:https://blog.csdn.net/qq_15083919/article/details/124851755
相關(guān)推薦
- 2022-05-08 python刪除列表元素del,pop(),remove()及clear()_python
- 2022-11-04 Android自定義View實(shí)現(xiàn)時(shí)鐘功能_Android
- 2022-12-22 C/C++?活動(dòng)預(yù)處理器詳解_C 語言
- 2023-03-29 python中文字符如何轉(zhuǎn)url編碼_python
- 2022-04-23 Docker?Compose快速部署多容器服務(wù)實(shí)戰(zhàn)的實(shí)例詳解_docker
- 2022-12-07 深入了解Rust中函數(shù)與閉包的使用_Rust語言
- 2022-03-25 在?ASP.NET?Core?中為?gRPC?服務(wù)添加全局異常處理_ASP.NET
- 2022-10-26 jQuery?表單事件與遍歷詳情_jquery
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支