亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

目錄
3。在Java舉行活動(dòng)
4。與卡夫卡消費(fèi)者一起消費(fèi)活動(dòng)
5。與Java的Kafka一起EDA的最佳實(shí)踐
6。可選:為簡(jiǎn)單起見使用Spring Kafka
概括
首頁(yè) Java java教程 與Apache Kafka的Java事件驅(qū)動(dòng)的架構(gòu)

與Apache Kafka的Java事件驅(qū)動(dòng)的架構(gòu)

Jul 29, 2025 am 02:02 AM

與Apache Kafka在Java中以事件為導(dǎo)向的體系結(jié)構(gòu)可以通過(guò)使用異步通信的事件進(jìn)行可擴(kuò)展的,鬆散的耦合系統(tǒng)。 1。生產(chǎn)者將事件發(fā)布給主題,消費(fèi)者無(wú)直接依賴性做出反應(yīng)。 2。 Kafka提供具有可重複性和高吞吐量的耐用,劃分的日誌。 3。使用kafkaproducer和kafkaconsumer使用Java的Kafka-Clients庫(kù)進(jìn)行手動(dòng)控制。 4。生產(chǎn)商將結(jié)構(gòu)化事件(最好是JSON或AVRO)使用帶回調(diào)處理的ProductErrecord進(jìn)行主題。 5。消費(fèi)者在循環(huán)中進(jìn)行調(diào)查,對(duì)其進(jìn)行處理並提交偏移,可選地使用消費(fèi)者組進(jìn)行水平縮放。 6。最佳實(shí)踐包括有意義的主題命名,事件版本,錯(cuò)誤處理,避免阻止操作,監(jiān)視消費(fèi)者滯後和確保持續(xù)性。 7??蛇x的是,將Spring Kafka與@Kafkalistener和Kafkatemplate一起使用,以簡(jiǎn)化註釋驅(qū)動(dòng)的開發(fā)。通過(guò)從單個(gè)工作流程(例如訂單處理和利用Kafka的可靠性)開始,基於Java的分佈式系統(tǒng)可以通過(guò)事件驅(qū)動(dòng)的設(shè)計(jì)實(shí)現(xiàn)實(shí)時(shí)響應(yīng)能力,彈性和可維護(hù)性。

與Apache Kafka的Java事件驅(qū)動(dòng)的架構(gòu)

與Apache Kafka的Java中的事件驅(qū)動(dòng)的體系結(jié)構(gòu)(EDA)是一種強(qiáng)大的組合,用於構(gòu)建可擴(kuò)展,彈性和鬆散耦合的系統(tǒng)。它們沒(méi)有直接互相呼喚,而是通過(guò)事件進(jìn)行交流,而其他人發(fā)生了反應(yīng)。 Apache Kafka由於其高吞吐量,耐用性和實(shí)時(shí)處理功能而脫穎而出,成為此類體系結(jié)構(gòu)的骨幹。

與Apache Kafka的Java事件驅(qū)動(dòng)的架構(gòu)

這是您可以有效地在Java中實(shí)現(xiàn)EDA的方法。


1。事件驅(qū)動(dòng)體系結(jié)構(gòu)的核心概念

在EDA中:

與Apache Kafka的Java事件驅(qū)動(dòng)的架構(gòu)
  • 生產(chǎn)者將事件(消息)發(fā)佈到主題。
  • 消費(fèi)者訂閱主題並對(duì)事件做出反應(yīng)。
  • 溝通是異步脫鉤的。
  • 組件不需要彼此了解,而只需要了解這些事件。

與kafka:

  • 主題耐用,分區(qū)日誌。
  • 事件存儲(chǔ)在可配置的時(shí)間中,允許重播。
  • 多重消費(fèi)者可以獨(dú)立閱讀相同的事件流。

這使Kafka非常適合微服務(wù),實(shí)時(shí)分析,審計(jì)記錄等。

與Apache Kafka的Java事件驅(qū)動(dòng)的架構(gòu)

2.在Java項(xiàng)目中設(shè)置Kafka

在您的Maven或Gradle項(xiàng)目中使用Apache Kafka客戶庫(kù)庫(kù)。

Maven依賴性:

 <依賴項(xiàng)>
    <groupId> org.apache.kafka </groupid>
    <Artifactid> kafka-clients </artifactid>
    <版本> 3.7.0 </version>
</dependency>

您將主要使用:

  • KafkaProducer - 發(fā)送事件
  • KafkaConsumer - 接收和處理活動(dòng)

還要考慮使用Spring Kafka ,如果您使用的是Spring Boot,它簡(jiǎn)化了配置和註釋驅(qū)動(dòng)的開發(fā)。


3。在Java舉行活動(dòng)

要發(fā)布事件,請(qǐng)創(chuàng)建KafkaProducer並將消息發(fā)送到主題。

導(dǎo)入org.apache.kafka.clients.producer。 *;
導(dǎo)入java.util.properties;

公共類訂單生產(chǎn)商{
    私人最終生產(chǎn)者<string,string> producer;

    public Order orderproducer(){
        屬性props = new Properties();
        props.put(“ bootstrap.servers”,“ localhost:9092”);
        props.put(“鍵。
        props.put(“ value.serializer”,org.apache.kafka.common.serialization.stringserializer&#39;);

        this.producer =新的kafkaproducer <>(props);
    }

    public void sendorderevent(字符串順序,字符串狀態(tài)){
        字符串主題=“訂單事件”;
        ProducerRecord <String,String> record = 
            new producterRecord <>(主題,orderID,“ order” orderid&#39;is is status status);

        producer.send(記錄,(元數(shù)據(jù),異常) - > {
            如果(異常!= null){
                system.err.println(“未能發(fā)送消息:” except.getMessage());
            } 別的 {
                system.out.println(“發(fā)送到分區(qū)” Metadata.partition()   
                                   “帶有偏移” Metadata.offset());
            }
        });
    }

    public void close(){
        producer.close();
    }
}

提示:使用JSON或AVRO進(jìn)行結(jié)構(gòu)化事件,而不是生產(chǎn)中的普通字符串。


4。與卡夫卡消費(fèi)者一起消費(fèi)活動(dòng)

創(chuàng)建一個(gè)消費(fèi)者,從主題中進(jìn)行調(diào)查並處理它們。

導(dǎo)入org.apache.kafka.clients.consumer。 *;
導(dǎo)入Java.Time.Duration;
導(dǎo)入java.util.collections;
導(dǎo)入java.util.properties;

公共班級(jí)訂購(gòu){
    私有最終的kafkaconsumer <字符串,字符串>消費(fèi)者;
    私有最終字符串主題=“訂單事件”;

    Public Ordorconsumer(){
        屬性props = new Properties();
        props.put(“ bootstrap.servers”,“ localhost:9092”);
        props.put(“ group.id”,“訂單處理組”);
        props.put(“鍵。
        props.put(“ value.deserializer”,“ org.apache.kafka.common.serialization.stringDeserializer”);
        props.put(“ auto.offset.reset”,“最早”); //或“最新”

        this.consumer = new kafkaconsumer <>(props);
    }

    public void start(){
        consumer.subscribe(collections.singletonList(toble));

        嘗試 {
            而(true){
                commuterRecords <string,string> records = computer.poll(listation.ofmillis(1000));
                for(commuterRecord <string,string> record:record){
                    system.out.printf(“接收:key =%s,value =%s,分區(qū)=%d,offset =%d%n”,
                            record.key(),record.value(),record.partition(),record.offset());

                    //處理事件
                    processOrderevent(record.value());
                }
                //如果需要,請(qǐng)手動(dòng)承諾偏移
                commuter.commitsync();
            }
        } 最後 {
            consumer.close();
        }
    }

    私有void processorderevent(字符串值){
        //業(yè)務(wù)邏輯:更新DB,通知用戶,觸發(fā)下一步,等。
        system.out.println(“處理事件:”值);
    }
}

使用消費(fèi)者組水平擴(kuò)展 - 在組中讀取不同分區(qū)中的實(shí)例。


5。與Java的Kafka一起EDA的最佳實(shí)踐

  • 使用有意義的主題名稱:例如, user-signed-up , payment-failedinventory-updated 。
  • 版本您的事件:在事件有效載荷中包含架構(gòu)版本或使用Confluent模式註冊(cè)表。
  • 優(yōu)雅地處理錯(cuò)誤:不要崩潰不好的消息 - log,重試或發(fā)送到一個(gè)書信主題。
  • 避免消費(fèi)者中的長(zhǎng)時(shí)間阻止操作:如果需要,將工作卸載到線程或消息隊(duì)列。
  • 監(jiān)視滯後:跟蹤消費(fèi)者組滯後以檢測(cè)處理延遲。
  • 使用IDEMTOTENT消費(fèi)者:確保處理事件兩次不會(huì)引起副作用。

6。可選:為簡(jiǎn)單起見使用Spring Kafka

使用Spring Boot,您可以使用@KafkaListener@SendTo之類的註釋。

 @服務(wù)
公共類KafkaconsumerService {

    @kafkalistener(topics =“ order-events”,groupId =“ order-group”)
    public void listing(字符串消息){
        System.out.println(“通過(guò)Spring Kafka收到:”消息);
        //處理事件
    }
}

並容易產(chǎn)生:

 @Autowired
私有kafkatemplate <字符串,字符串> kafkatemplate;

public void sendevent(字符串主題,字符串鍵,字符串有效載荷){
    kafkatemplate.send(主題,鍵,有效載荷);
}

Spring Kafka處理序列化,線程和錯(cuò)誤處理的序列化處理。


概括

使用Apache Kafka在Java中構(gòu)建事件驅(qū)動(dòng)的系統(tǒng),讓您:

  • 切換服務(wù)
  • 獨(dú)立擴(kuò)展
  • 實(shí)時(shí)反應(yīng)
  • 重播恢復(fù)或分析的事件

開始?。哼x擇一個(gè)工作流程(例如,訂單處理),將其建模為事件,然後將生產(chǎn)者和消費(fèi)者連接。然後根據(jù)需要擴(kuò)展。

憑藉Kafka的可靠性和Java的生態(tài)系統(tǒng),EDA不僅可以可行,而且可以在大規(guī)模上保持且績(jī)效。

基本上,如果您在Java建造分佈式系統(tǒng),Kafka是進(jìn)行事件驅(qū)動(dòng)的最佳工具之一。

以上是與Apache Kafka的Java事件驅(qū)動(dòng)的架構(gòu)的詳細(xì)內(nèi)容。更多資訊請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本網(wǎng)站聲明
本文內(nèi)容由網(wǎng)友自願(yuàn)投稿,版權(quán)歸原作者所有。本站不承擔(dān)相應(yīng)的法律責(zé)任。如發(fā)現(xiàn)涉嫌抄襲或侵權(quán)的內(nèi)容,請(qǐng)聯(lián)絡(luò)admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅(qū)動(dòng)的應(yīng)用程序,用於創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強(qiáng)大的PHP整合開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁(yè)開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1597
29
PHP教程
1488
72
現(xiàn)代爪哇的異步編程技術(shù) 現(xiàn)代爪哇的異步編程技術(shù) Jul 07, 2025 am 02:24 AM

Java支持異步編程的方式包括使用CompletableFuture、響應(yīng)式流(如ProjectReactor)以及Java19 中的虛擬線程。 1.CompletableFuture通過(guò)鍊式調(diào)用提升代碼可讀性和維護(hù)性,支持任務(wù)編排和異常處理;2.ProjectReactor提供Mono和Flux類型實(shí)現(xiàn)響應(yīng)式編程,具備背壓機(jī)制和豐富的操作符;3.虛擬線程減少並發(fā)成本,適用於I/O密集型任務(wù),與傳統(tǒng)平臺(tái)線程相比更輕量且易於擴(kuò)展。每種方式均有適用場(chǎng)景,應(yīng)根據(jù)需求選擇合適工具並避免混合模型以保持簡(jiǎn)潔性

在Java中使用枚舉的最佳實(shí)踐 在Java中使用枚舉的最佳實(shí)踐 Jul 07, 2025 am 02:35 AM

在Java中,枚舉(enum)適合表示固定常量集合,最佳實(shí)踐包括:1.用enum表示固定狀態(tài)或選項(xiàng),提升類型安全和可讀性;2.為枚舉添加屬性和方法以增強(qiáng)靈活性,如定義字段、構(gòu)造函數(shù)、輔助方法等;3.使用EnumMap和EnumSet提高性能和類型安全性,因其基於數(shù)組實(shí)現(xiàn)更高效;4.避免濫用enum,如動(dòng)態(tài)值、頻繁變更或複雜邏輯場(chǎng)景應(yīng)使用其他方式替代。正確使用enum能提升代碼質(zhì)量並減少錯(cuò)誤,但需注意其適用邊界。

了解Java Nio及其優(yōu)勢(shì) 了解Java Nio及其優(yōu)勢(shì) Jul 08, 2025 am 02:55 AM

JavaNIO是Java1.4引入的新型IOAPI,1)面向緩衝區(qū)和通道,2)包含Buffer、Channel和Selector核心組件,3)支持非阻塞模式,4)相比傳統(tǒng)IO更高效處理並發(fā)連接。其優(yōu)勢(shì)體現(xiàn)在:1)非阻塞IO減少線程開銷,2)Buffer提升數(shù)據(jù)傳輸效率,3)Selector實(shí)現(xiàn)多路復(fù)用,4)內(nèi)存映射加快文件讀寫。使用時(shí)需注意:1)Buffer的flip/clear操作易混淆,2)非阻塞下需手動(dòng)處理不完整數(shù)據(jù),3)Selector註冊(cè)需及時(shí)取消,4)NIO並非適用於所有場(chǎng)景。

Java Classloader在內(nèi)部如何工作 Java Classloader在內(nèi)部如何工作 Jul 06, 2025 am 02:53 AM

Java的類加載機(jī)制通過(guò)ClassLoader實(shí)現(xiàn),其核心工作流程分為加載、鏈接和初始化三個(gè)階段。加載階段由ClassLoader動(dòng)態(tài)讀取類的字節(jié)碼並創(chuàng)建Class對(duì)象;鏈接包括驗(yàn)證類的正確性、為靜態(tài)變量分配內(nèi)存及解析符號(hào)引用;初始化則執(zhí)行靜態(tài)代碼塊和靜態(tài)變量賦值。類加載採(cǎi)用雙親委派模型,優(yōu)先委託父類加載器查找類,依次嘗試Bootstrap、Extension和ApplicationClassLoader,確保核心類庫(kù)安全且避免重複加載。開發(fā)者可自定義ClassLoader,如URLClassL

有效處理常見的Java例外 有效處理常見的Java例外 Jul 05, 2025 am 02:35 AM

Java異常處理的關(guān)鍵在於區(qū)分checked和unchecked異常並合理使用try-catch、finally及日誌記錄。 1.checked異常如IOException需強(qiáng)制處理,適用於可預(yù)期的外部問(wèn)題;2.unchecked異常如NullPointerException通常由程序邏輯錯(cuò)誤引起,屬於運(yùn)行時(shí)錯(cuò)誤;3.捕獲異常時(shí)應(yīng)具體明確,避免籠統(tǒng)捕獲Exception;4.推薦使用try-with-resources自動(dòng)關(guān)閉資源,減少手動(dòng)清理代碼;5.異常處理中應(yīng)結(jié)合日誌框架記錄詳細(xì)信息,便於後

Hashmap在Java內(nèi)部如何工作? Hashmap在Java內(nèi)部如何工作? Jul 15, 2025 am 03:10 AM

HashMap在Java中通過(guò)哈希表實(shí)現(xiàn)鍵值對(duì)存儲(chǔ),其核心在於快速定位數(shù)據(jù)位置。 1.首先使用鍵的hashCode()方法生成哈希值,並通過(guò)位運(yùn)算轉(zhuǎn)換為數(shù)組索引;2.不同對(duì)象可能產(chǎn)生相同哈希值,導(dǎo)致衝突,此時(shí)以鍊錶形式掛載節(jié)點(diǎn),JDK8後鍊錶過(guò)長(zhǎng)(默認(rèn)長(zhǎng)度8)則轉(zhuǎn)為紅黑樹提升效率;3.使用自定義類作鍵時(shí)必須重寫equals()和hashCode()方法;4.HashMap動(dòng)態(tài)擴(kuò)容,當(dāng)元素?cái)?shù)超過(guò)容量乘以負(fù)載因子(默認(rèn)0.75)時(shí),擴(kuò)容並重新哈希;5.HashMap非線程安全,多線程下應(yīng)使用Concu

解釋:面向?qū)ο蟮木幊讨械腏ava多態(tài)性 解釋:面向?qū)ο蟮木幊讨械腏ava多態(tài)性 Jul 05, 2025 am 02:52 AM

多態(tài)是Java面向?qū)ο缶幊痰暮诵奶匦灾?,其核心在於“一個(gè)接口,多種實(shí)現(xiàn)”,它通過(guò)繼承、方法重寫和向上轉(zhuǎn)型實(shí)現(xiàn)統(tǒng)一接口處理不同對(duì)象的行為。 1.多態(tài)允許父類引用指向子類對(duì)象,運(yùn)行時(shí)根據(jù)實(shí)際對(duì)象調(diào)用對(duì)應(yīng)方法;2.實(shí)現(xiàn)需滿足繼承關(guān)係、方法重寫和向上轉(zhuǎn)型三個(gè)條件;3.常用於統(tǒng)一處理不同子類對(duì)象、集合存儲(chǔ)及框架設(shè)計(jì)中;4.使用時(shí)只能調(diào)用父類定義的方法,子類新增方法需向下轉(zhuǎn)型訪問(wèn),並註意類型安全。

有效使用爪哇枚舉和最佳實(shí)踐 有效使用爪哇枚舉和最佳實(shí)踐 Jul 07, 2025 am 02:43 AM

Java枚舉不僅表示常量,還可封裝行為、攜帶數(shù)據(jù)、實(shí)現(xiàn)接口。 1.枚舉是類,用於定義固定實(shí)例,如星期、狀態(tài),比字符串或整數(shù)更安全;2.可攜帶數(shù)據(jù)和方法,如通過(guò)構(gòu)造函數(shù)傳值並提供訪問(wèn)方法;3.可使用switch處理不同邏輯,結(jié)構(gòu)清晰;4.可實(shí)現(xiàn)接口或抽象方法,使不同枚舉值具有差異化行為;5.注意避免濫用、硬編碼比較、依賴ordinal值,合理命名與序列化。

See all articles