docs/mq/kafka/消息队列kafka详解:如何实现死信队列.md
ʶʹκοɿܵDZزٵġƪ̽** Apache Kafka ܹ****ʹŶʵִʵ**ЩѡԶʵ֡Kafka StreamsKafka ConnectSpring ܺͲߡʵоչʾ UberCrowdStrike ɣ̹Լ˹ģɿʵʱ
Apache Kafka ΪҵܹϲļмʹսԣҵҲ Kafka Ϊԭƽ̨ (iPaaS)
ҿʼƪ֮ǰ֪ڡJMSϢк Apache KafkaIJϵһ֣
Ŷ (DLQ)Ϣϵͳƽ̨ڵһַʵ֣洢δɹϢϵͳDZתϢǽƶŶС
ҵ**ģʽ (EIP)**ΪģʽͨǿԽͬʡ
صƽ̨ Apache Kafka** Kafka нϢ DLQ **ҪԭͨϢʽϢЧ/ȱʧ磬Ԥֵ߷ַᷢӦóڸ̬ĻУⲻڡ쳣Ϣһ
ˣͨҪʹме֪ʶMessage Queue м JMS IBM MQTIBCO EMS RabbitMQֲʽύ־ KafkaĹʽͬԭϢе DLQ ϢϵͳЩԭһһӳ䵽 Kafka磬MQ ϵͳеϢÿϢ TTLʱ䣩ڡ
ˣ** Kafka нϢ DLQ ҪԭϢʽϢЧ/ȱʧ**
Kafka еŶһ Kafka ⣬պʹ洢ڴһܵдϢ˸ʹ´ϢϢЧϢĴֹͣ
Kafka ܹ֧ broker r еDLQأKafka ִͬԭϣʹáƹܵܶ˵㡱ԭΪʲô봫ͳϢȣKafka չ֮á˺ʹڿͻӦóС
ƽ̨ʵָɾơÿӦóͨԼѡļͨŷʽʹʵ
ڴͳмϢУṩеĿչԺԽϲΪֻмŶӲʵּ
Kafka еŶжʹõĿܡһЩΪŶṩ˿伴õĹܡǣʹJavaGoC++Python καΪ Kafka ӦóдŶҲס
ŶʵԴһ try-catch Ԥڻ쳣ûзϢκ쳣뽫Ϣ͵רõ DLQ Kafka ⡣
ʧԭӦӵ Kafka ϢıͷСӦļֵԱ㽫ʷ¼´Ϸ
㲢ҪʵŶСͿѾṩǵ DLQ ʵ
ʹԼӦóͨԿƴڳִʱ롣ǣ** 3rd Ӧóļɲһܿ缯ϰĴ**ˣDLQ øҪijЩС
Kafka Connect Kafka ļɿڿԴ Kafka СҪ Connect Ⱥе
Ĭ£ʹЧϢʹô JSON תȷ AVRO תʱKafka Connect ֹͣɾЧϢһѡ̴
Kafka Connect DLQ úֻܼ轫ѡ ' errors.tolerance' ' errors.deadletterqueue.topic.name' ֵΪȷֵ
¡ Kafka Connect Deep Dive C ŶСʾʹ DLQ ϸִʾ
Kafka Connect ڴ DLQ еĴϢֻ貿һʹ te DLQ 磬Ӧó Avro ϢҴϢ JSON ʽȻʹ JSON ϢתΪ AVRO ϢԳɹ´
ע⣬Kafka Connect ûԴŶ
**Kafka Streams Kafka **ʽ Apache FlinkStormBeam ƹߡǣ Kafka ԭġζڵչҿɿĻܹйĶ˵
ֱʹ JavaJVM ̬ϵͳ Kafka Ӧó鼸ʹ Kafka Streams Kafka ı Java ͻΪʲô
Kafka Streamsù֮һĬϵķл쳣л¼쳣ݡȷлδļ¼Ͷܵ´ùܲΪŶУ伴õؽͬ⡣
Spring ܶ Apache Kafka кܺõ֧֡ṩģԱԼд롣Spring-Kafka Spring Cloud Stream Kafka ָ֧Ժʹѡʱ/ԡŶеȡ
Spring ܹܷdzḻеأһѧϰߡˣdzʺ½ĿѾ Spring Ŀ
кܶܰIJչʾ˲ͬʾѡŶеĹٷ Spring Cloud Stream ʾSpring ʹüע DLQ̷ֱһЩԱӰķһЩϲֻ˽ѡΪԼѡʵѡɡ
ͻԻУʵ֤ŶеҪԭͨǴӵⲿ Web ݿʧʱ Kafka зᵼijЩӦó̱һܺõĽ
Apache Kafka****Apache 2.0 ĿԴĿṩһпͻ˶еIJ Apache Kafka ͻ˰װһؼԵĸ/ APIԼչķ IO
ÿͨ Kafka Consumer дϢζڲҪеķ Kafka Consumer жȡͨ Kafka ĸӳ١µ缫˲ԡⲿݷḻŶӡ
һؼڵ Kafka Ӧóд/ظ Web ݿлһη͵ Web Ҫ
Parallel Consumer ͻ˾ǿõӳٺͶ̬ҲԷ͵ŶС
͵ŶкûɣϢҪٱأ
Ŷ¼дݴľѷʽζŴ¼ֿݱ䡣
ڴʹŶеĴԡDO DONT ̽ʵ;ѵ
мѡڴ洢ŶеϢ
Kafka ӦóʹŶндһЩʵ;ѵ
סDLQ б֤˳ֹʹκ͵ߴøˣKafka DQL ʺÿ
̽һ²ӦýЩ͵Ϣ Kafka ŶУ
ͬҪǣ̽ijЩŶеĿԡ
****Schema RegistryһȷԷֹڸгķ Kafka ǿִȷϢṹ
ģʽעģʽĿͻ˼顣Confluent Server һЩʵڴṩ˶ģʽ飬ԾܾδʹģʽעߵЧϢ
ǿUberCrowdStrike Santander Bank о Kafka ʩʵʲŶסЩǷdzӡÿĿҪôӡ
ڷֲʽϵͳУDzɱġ⣬ϵжϣģеķþŵʶʹϡ
Uber ӪΧٶȣϵͳݴʧʱЭUber Apache Kafka ڸּ˹ģʵһĿꡣ
ЩԣUber չŶչ Kafka ¼ܹеãͨʹ n**´Ŷʵֽɹ۲Ĵжʵʱ**òѡļʻԱ˺ƻ 200 пɿУΪעʻԱ۳ÿг̵ÿӢﱣѡ
Uber ʾήļֱ½ DLQ
йظϢĶ Uber dzϸļ£ʹ Apache Kafka ɿٴŶС
CrowdStrike һλڵ¿˹ݰ˹͡簲ȫ˾ṩƹغͶ˵㰲ȫв鱨繥Ӧ
CrowdStrike Ļʩ** ÿʹ Apache Kafka ڸ¼**ҵġ Apache Kaka 簲ȫϵСУҽκιģʵʱ̬Ƹ֪в鱨
CrowdStrike ʵ ɹʵŶкʹ
** CrowdStrike 簲ȫƽ̨УģʵʱݴҪҪҲڴһ繥ǹʵЧݵĶϢ** JavaScript ©ãˣͨŶʵʱ
ɣ̹Ӧóдݵͬݴپս¼ܹǵĻܹһҿչļܹΪSantander Mailbox 2.0
Santander ĹزתƵ** Apache Kafka ṩֵ֧¼Դ**
µĻ첽¼ļܹеһؼսǴ** Santander ʹԺ DQL Kafka Ĵ**Щ⣺
鿴 Santander ļɺ Consdata Kafka ݽԲԺ Apache Kafka еĿɿ¼ݡеϸϢ
ڹɿܵƽ̨Ҫڲͬ⡣ýŶеԶʵֻʹõĿܣ Kafka StreamsKafka ConnectSpring ܻ Kafka IJߡ
ŲCrowdStrike ɣ̹еİоǺʵ֡µӦóܹʱҪһʼͿǵһ㡣ʹ Apache Kafka ʵʱֻܹΪʱܳɹŶೡľѡ