加入收藏 | 设为首页 | 会员中心 | 我要投稿 开发网_郴州站长网 (http://www.0735zz.com/)- 云通信、区块链、物联设备、云计算、站长网!
当前位置: 首页 > 运营中心 > 网站设计 > 教程 > 正文

Apache Flink 漫谈系列 - 流表对偶(duality)性

发布时间:2018-11-10 01:19:34 所属栏目:教程 来源:孙金城
导读:副标题#e# 实际问题 很多大数据计算产品,都对用户提供了SQL API,比如Hive, Spark, Flink等,那么SQL作为传统关系数据库的查询语言,是应用在批查询场景的。Hive和Spark本质上都是Batch的计算模式(在《Apache Flink 漫谈系列 - 概述》我们介绍过Spark是Mic

打开binlog.txt 内容如下:

  1. /*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=1*/; 
  2. /*!50003 SET @OLD_COMPLETION_TYPE=@@COMPLETION_TYPE,COMPLETION_TYPE=0*/; 
  3. DELIMITER /*!*/; 
  4. # at 4 
  5. #180430 22:29:33 server id 1  end_log_pos 124 CRC32 0xff61797c  Start: binlog v 4, server v 8.0.11 created 180430 22:29:33 at startup 
  6. # Warning: this binlog is either in use or was not closed properly. 
  7. ROLLBACK/*!*/; 
  8. # at 124 
  9. #180430 22:29:33 server id 1  end_log_pos 155 CRC32 0x629ae755  Previous-GTIDs 
  10. # [empty] 
  11. # at 155 
  12. #180430 22:32:11 server id 1  end_log_pos 228 CRC32 0xbde49fca  Anonymous_GTID  last_committed=0        sequence_number=1       rbr_only=no     original_committed_timestamp=1525098731207902   immediate_commit_timestamp=1525098731207902     transaction_length=213 
  13. # original_commit_timestamp=1525098731207902 (2018-04-30 22:32:11.207902 CST) 
  14. # immediate_commit_timestamp=1525098731207902 (2018-04-30 22:32:11.207902 CST) 
  15. /*!80001 SET @@session.original_commit_timestamp=1525098731207902*//*!*/; 
  16. SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/; 
  17. # at 228 
  18. #180430 22:32:11 server id 1  end_log_pos 368 CRC32 0xe5f330e7  Query   thread_id=9     exec_time=0     error_code=0    Xid = 22 
  19. use `Apache Flinkdb`/*!*/; 
  20. SET TIMESTAMP=1525098731/*!*/; 
  21. SET @@session.pseudo_thread_id=9/*!*/; 
  22. SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1/*!*/; 
  23. SET @@session.sql_mode=1168113696/*!*/; 
  24. SET @@session.auto_increment_increment=1, @@session.auto_increment_offset=1/*!*/; 
  25. /*!C utf8mb4 *//*!*/; 
  26. SET @@session.character_set_client=255,@@session.collation_connection=255,@@session.collation_server=255/*!*/; 
  27. SET @@session.lc_time_names=0/*!*/; 
  28. SET @@session.collation_database=DEFAULT/*!*/; 
  29. /*!80005 SET @@session.default_collation_for_utf8mb4=255*//*!*/; 
  30. DROP TABLE `tab` /* generated by server */ 
  31. /*!*/; 
  32. # at 368 
  33. #180430 22:32:21 server id 1  end_log_pos 443 CRC32 0x50e5acb7  Anonymous_GTID  last_committed=1        sequence_number=2       rbr_only=no     original_committed_timestamp=1525098741628960   immediate_commit_timestamp=1525098741628960     transaction_length=302 
  34. # original_commit_timestamp=1525098741628960 (2018-04-30 22:32:21.628960 CST) 
  35. # immediate_commit_timestamp=1525098741628960 (2018-04-30 22:32:21.628960 CST) 
  36. /*!80001 SET @@session.original_commit_timestamp=1525098741628960*//*!*/; 
  37. SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/; 
  38. # at 443 
  39. #180430 22:32:21 server id 1  end_log_pos 670 CRC32 0xe1353dd6  Query   thread_id=9     exec_time=0     error_code=0    Xid = 23 
  40. SET TIMESTAMP=1525098741/*!*/; 
  41. create table tab( 
  42.    id INT NOT NULL AUTO_INCREMENT, 
  43.    user VARCHAR(100) NOT NULL, 
  44.    clicks INT NOT NULL, 
  45.    PRIMARY KEY (id) 
  46. /*!*/; 
  47. # at 670 
  48. #180430 22:36:53 server id 1  end_log_pos 745 CRC32 0xcf436fbb  Anonymous_GTID  last_committed=2        sequence_number=3       rbr_only=yes    original_committed_timestamp=1525099013988373   immediate_commit_timestamp=1525099013988373     transaction_length=301 
  49. /*!50718 SET TRANSACTION ISOLATION LEVEL READ COMMITTED*//*!*/; 
  50. # original_commit_timestamp=1525099013988373 (2018-04-30 22:36:53.988373 CST) 
  51. # immediate_commit_timestamp=1525099013988373 (2018-04-30 22:36:53.988373 CST) 
  52. /*!80001 SET @@session.original_commit_timestamp=1525099013988373*//*!*/; 
  53. SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/; 
  54. # at 745 
  55. #180430 22:36:53 server id 1  end_log_pos 823 CRC32 0x71c64dd2  Query   thread_id=9     exec_time=0     error_code=0 
  56. SET TIMESTAMP=1525099013/*!*/; 
  57. BEGIN 
  58. /*!*/; 
  59. # at 823 
  60. #180430 22:36:53 server id 1  end_log_pos 890 CRC32 0x63792f6b  Table_map: `Apache Flinkdb`.`tab` mapped to number 96 
  61. # at 890 
  62. #180430 22:36:53 server id 1  end_log_pos 940 CRC32 0xf2dade22  Write_rows: table id 96 flags: STMT_END_F 
  63. ### INSERT INTO `Apache Flinkdb`.`tab` 
  64. ### SET 
  65. ###   @11=1 
  66. ###   @2='Mary' 
  67. ###   @3=1 
  68. # at 940 
  69. #180430 22:36:53 server id 1  end_log_pos 971 CRC32 0x7db3e61e  Xid = 25 
  70. COMMIT/*!*/; 
  71. # at 971 
  72. #180430 22:37:06 server id 1  end_log_pos 1046 CRC32 0xd05dd12c         Anonymous_GTID  last_committed=3        sequence_number=4       rbr_only=yes    original_committed_timestamp=1525099026328547   immediate_commit_timestamp=1525099026328547     transaction_length=300 
  73. /*!50718 SET TRANSACTION ISOLATION LEVEL READ COMMITTED*//*!*/; 
  74. # original_commit_timestamp=1525099026328547 (2018-04-30 22:37:06.328547 CST) 
  75. # immediate_commit_timestamp=1525099026328547 (2018-04-30 22:37:06.328547 CST) 
  76. /*!80001 SET @@session.original_commit_timestamp=1525099026328547*//*!*/; 
  77. SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/; 
  78. # at 1046 
  79. #180430 22:37:06 server id 1  end_log_pos 1124 CRC32 0x80f259e0         Query   thread_id=9     exec_time=0     error_code=0 
  80. SET TIMESTAMP=1525099026/*!*/; 
  81. BEGIN 
  82. /*!*/; 
  83. # at 1124 
  84. #180430 22:37:06 server id 1  end_log_pos 1191 CRC32 0x255903ba         Table_map: `Apache Flinkdb`.`tab` mapped to number 96 
  85. # at 1191 
  86. #180430 22:37:06 server id 1  end_log_pos 1240 CRC32 0xe76bfc79         Write_rows: table id 96 flags: STMT_END_F 
  87. ### INSERT INTO `Apache Flinkdb`.`tab` 
  88. ### SET 
  89. ###   @1=2 
  90. ###   @2='Bob' 
  91. ###   @3=1 
  92. # at 1240 
  93. #180430 22:37:06 server id 1  end_log_pos 1271 CRC32 0x83cddfef         Xid = 26 
  94. COMMIT/*!*/; 
  95. # at 1271 
  96. #180430 22:37:15 server id 1  end_log_pos 1346 CRC32 0x7095baee         Anonymous_GTID  last_committed=4        sequence_number=5       rbr_only=yes    original_committed_timestamp=1525099035811597   immediate_commit_timestamp=1525099035811597     transaction_length=326 
  97. /*!50718 SET TRANSACTION ISOLATION LEVEL READ COMMITTED*//*!*/; 
  98. # original_commit_timestamp=1525099035811597 (2018-04-30 22:37:15.811597 CST) 
  99. # immediate_commit_timestamp=1525099035811597 (2018-04-30 22:37:15.811597 CST) 
  100. /*!80001 SET @@session.original_commit_timestamp=1525099035811597*//*!*/; 
  101. SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/; 
  102. # at 1346 
  103. #180430 22:37:15 server id 1  end_log_pos 1433 CRC32 0x70ef97e2         Query   thread_id=9     exec_time=0     error_code=0 
  104. SET TIMESTAMP=1525099035/*!*/; 
  105. BEGIN 
  106. /*!*/; 
  107. # at 1433 
  108. #180430 22:37:15 server id 1  end_log_pos 1500 CRC32 0x75f1f399         Table_map: `Apache Flinkdb`.`tab` mapped to number 96 
  109. # at 1500 
  110. #180430 22:37:15 server id 1  end_log_pos 1566 CRC32 0x256bd4b8         Update_rows: table id 96 flags: STMT_END_F 
  111. ### UPDATE `Apache Flinkdb`.`tab` 
  112. ### WHERE 
  113. ###   @11=1 
  114. ###   @2='Mary' 
  115. ###   @3=1 
  116. ### SET 
  117. ###   @11=1 
  118. ###   @2='Mary' 
  119. ###   @3=2 
  120. # at 1566 
  121. #180430 22:37:15 server id 1  end_log_pos 1597 CRC32 0x93c86579         Xid = 27 
  122. COMMIT/*!*/; 
  123. # at 1597 
  124. #180430 22:37:27 server id 1  end_log_pos 1672 CRC32 0xe8bd63e7         Anonymous_GTID  last_committed=5        sequence_number=6       rbr_only=yes    original_committed_timestamp=1525099047219517   immediate_commit_timestamp=1525099047219517     transaction_length=300 
  125. /*!50718 SET TRANSACTION ISOLATION LEVEL READ COMMITTED*//*!*/; 
  126. # original_commit_timestamp=1525099047219517 (2018-04-30 22:37:27.219517 CST) 
  127. # immediate_commit_timestamp=1525099047219517 (2018-04-30 22:37:27.219517 CST) 
  128. /*!80001 SET @@session.original_commit_timestamp=1525099047219517*//*!*/; 
  129. SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/; 
  130. # at 1672 
  131. #180430 22:37:27 server id 1  end_log_pos 1750 CRC32 0x5356c3c7         Query   thread_id=9     exec_time=0     error_code=0 
  132. SET TIMESTAMP=1525099047/*!*/; 
  133. BEGIN 
  134. /*!*/; 
  135. # at 1750 
  136. #180430 22:37:27 server id 1  end_log_pos 1817 CRC32 0x37e6b1ce         Table_map: `Apache Flinkdb`.`tab` mapped to number 96 
  137. # at 1817 
  138. #180430 22:37:27 server id 1  end_log_pos 1866 CRC32 0x6ab1bbe6         Write_rows: table id 96 flags: STMT_END_F 
  139. ### INSERT INTO `Apache Flinkdb`.`tab` 
  140. ### SET 
  141. ###   @1=3 
  142. ###   @2='Llz' 
  143. ###   @3=1 
  144. # at 1866 
  145. #180430 22:37:27 server id 1  end_log_pos 1897 CRC32 0x3b62b153         Xid = 28 
  146. COMMIT/*!*/; 
  147. # at 1897 
  148. #180430 22:37:36 server id 1  end_log_pos 1972 CRC32 0x603134c1         Anonymous_GTID  last_committed=6        sequence_number=7       rbr_only=yes    original_committed_timestamp=1525099056866022   immediate_commit_timestamp=1525099056866022     transaction_length=324 
  149. /*!50718 SET TRANSACTION ISOLATION LEVEL READ COMMITTED*//*!*/; 
  150. # original_commit_timestamp=1525099056866022 (2018-04-30 22:37:36.866022 CST) 
  151. # immediate_commit_timestamp=1525099056866022 (2018-04-30 22:37:36.866022 CST) 
  152. /*!80001 SET @@session.original_commit_timestamp=1525099056866022*//*!*/; 
  153. SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/; 
  154. # at 1972 
  155. #180430 22:37:36 server id 1  end_log_pos 2059 CRC32 0xe17df4e4         Query   thread_id=9     exec_time=0     error_code=0 
  156. SET TIMESTAMP=1525099056/*!*/; 
  157. BEGIN 
  158. /*!*/; 
  159. # at 2059 
  160. #180430 22:37:36 server id 1  end_log_pos 2126 CRC32 0x53888b05         Table_map: `Apache Flinkdb`.`tab` mapped to number 96 
  161. # at 2126 
  162. #180430 22:37:36 server id 1  end_log_pos 2190 CRC32 0x85f34996         Update_rows: table id 96 flags: STMT_END_F 
  163. ### UPDATE `Apache Flinkdb`.`tab` 
  164. ### WHERE 
  165. ###   @1=2 
  166. ###   @2='Bob' 
  167. ###   @3=1 
  168. ### SET 
  169. ###   @1=2 
  170. ###   @2='Bob' 
  171. ###   @3=2 
  172. # at 2190 
  173. #180430 22:37:36 server id 1  end_log_pos 2221 CRC32 0x877f1e23         Xid = 29 
  174. COMMIT/*!*/; 
  175. # at 2221 
  176. #180430 22:37:45 server id 1  end_log_pos 2296 CRC32 0xfbc7e868         Anonymous_GTID  last_committed=7        sequence_number=8       rbr_only=yes    original_committed_timestamp=1525099065089940   immediate_commit_timestamp=1525099065089940     transaction_length=326 
  177. /*!50718 SET TRANSACTION ISOLATION LEVEL READ COMMITTED*//*!*/; 
  178. # original_commit_timestamp=1525099065089940 (2018-04-30 22:37:45.089940 CST) 
  179. # immediate_commit_timestamp=1525099065089940 (2018-04-30 22:37:45.089940 CST) 
  180. /*!80001 SET @@session.original_commit_timestamp=1525099065089940*//*!*/; 
  181. SET @@SESSION.GTID_NEXT= 'ANONYMOUS'/*!*/; 
  182. # at 2296 
  183. #180430 22:37:45 server id 1  end_log_pos 2383 CRC32 0x8a514364         Query   thread_id=9     exec_time=0     error_code=0 
  184. SET TIMESTAMP=1525099065/*!*/; 
  185. BEGIN 
  186. /*!*/; 
  187. # at 2383 
  188. #180430 22:37:45 server id 1  end_log_pos 2450 CRC32 0xdf18ca60         Table_map: `Apache Flinkdb`.`tab` mapped to number 96 
  189. # at 2450 
  190. #180430 22:37:45 server id 1  end_log_pos 2516 CRC32 0xd50de69f         Update_rows: table id 96 flags: STMT_END_F 
  191. ### UPDATE `Apache Flinkdb`.`tab` 
  192. ### WHERE 
  193. ###   @11=1 
  194. ###   @2='Mary' 
  195. ###   @3=2 
  196. ### SET 
  197. ###   @11=1 
  198. ###   @2='Mary' 
  199. ###   @33=3 
  200. # at 2516 
  201. #180430 22:37:45 server id 1  end_log_pos 2547 CRC32 0x94f89393         Xid = 30 
  202. COMMIT/*!*/; 
  203. SET @@SESSION.GTID_NEXT= 'AUTOMATIC' /* added by MySQLbinlog */ /*!*/; 
  204. DELIMITER ; 
  205. # End of log file 
  206. /*!50003 SET COMPLETION_TYPE=@OLD_COMPLETION_TYPE*/; 
  207. /*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=0*/; 
  • 梳理操作和binlog的记录关系
  • Apache Flink 漫谈系列 - 流表对偶(duality)性

    梳理操作和binlog的记录关系

    Apache Flink 漫谈系列 - 流表对偶(duality)性

  • 简化一下binlog
  • Apache Flink 漫谈系列 - 流表对偶(duality)性

  • replay binlog会得到如下表数据(按timestamp顺序)
  • Apache Flink 漫谈系列 - 流表对偶(duality)性

  • 表与binlog的关系简单示意如下
  • Apache Flink 漫谈系列 - 流表对偶(duality)性

流表对偶(duality)性

(编辑:开发网_郴州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读