flink二阶提交(没有搞完)
舉例說明
甲乙丙丁四人要組織一個會議,需要確定會議時間,不妨設(shè)甲是協(xié)調(diào)者,乙丙丁是參與者。
投票階段:
(1)甲發(fā)郵件給乙丙丁,周二十點開會是否有時間;
(2)甲回復(fù)有時間;
(3)乙回復(fù)有時間;
(4)丙遲遲不回復(fù),此時對于這個活動,甲乙丙均處于阻塞狀態(tài),算法無法繼續(xù)進(jìn)行;
(5)丙回復(fù)有時間(或者沒有時間);
提交階段:
(1)協(xié)調(diào)者甲將收集到的結(jié)果反饋給乙丙丁(什么時候反饋,以及反饋結(jié)果如何,在此例中取決與丙的時間與決定);
(2)乙收到;
(3)丙收到;
(4)丁收到;
?
?
來源
代碼以[4]為主,我自己修正了一些bug,增加了依賴。
集群準(zhǔn)備工作
啟動Zookeeper集群、Kafka集群、Flink集群。
流程圖
?
?
?
Mysql準(zhǔn)備工作
create database test;
use test;
CREATE TABLE `mysqlExactlyOnce_test` (
? `id` bigint(20) NOT NULL AUTO_INCREMENT,
? `value` varchar(255) DEFAULT NULL,
? `insert_time` datetime DEFAULT NULL,
? PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
?
文件說明與聯(lián)系
| 文件 | 說明 | 需要設(shè)定的參數(shù) |
| DBConnectUtil.java | java連接數(shù)據(jù)庫 | 無 |
| KafkaUtils.java(生產(chǎn)者,頂層文件) | 生產(chǎn)者 | broker_list |
| MysqlExactlyOncePOJO.java | 一個pojo對象 | 無 |
| MySqlTwoPhaseCommitSink.java(被調(diào)用) | 插入數(shù)據(jù),制造異常 | jdbc:mysql://以及sql語句 |
| streamdemokafka2mysql.java(調(diào)用MySqlTwoPhaseCommitSink,頂層架構(gòu)) | Flink source與sink | BOOTSTRAP_SERVERS_CONFIG |
運行步驟
①運行StreamDemoKafka2Mysql.java
②運行KafkaUtils.java
?
調(diào)試用命令
$KAFKA/bin/kafka-topics.sh --list ?--zookeeper ?Desktop:2181
$KAFKA/bin/kafka-console-consumer.sh ?--bootstrap-server Desktop:9091 --from-beginning --topic mysql-exactly-Once-4
修改的主題的話,需要同時在kafkautils.java和StreamDemoKafka2Mysql.java中修改
實驗效果
?
?
?
tijiao最終代碼如下
?
Reference:
[1]Flink兩階段提交
[2]Flink 之 MySQL二階提交
[3]解決Flink消費Kafka信息,結(jié)果存儲在Mysql的重復(fù)消費問題
[4]Flink實現(xiàn)Kafka到Mysql的Exactly-Once
[5]Kafka常用命令
[6]一分鐘了解兩階段提交2PC(運營MM也懂了)
總結(jié)
以上是生活随笔為你收集整理的flink二阶提交(没有搞完)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Kafka实现MySQL增量同步
- 下一篇: Flink 完美搭档:数据存储层上的 P