flink-cdc使用小结

原理:

  • 同步原理:其实就是伪装成一个mysql 的从库会拉取主库的binlog日志读取数据,相当于mysql 的主从复制。然而flink的数据处理方式是流处理,实时收集清洗数据。
  • 相关联的checkpoint,其实就是一个容错恢复快照,没执行后,会保存一个当前处理数据的offset,如果有job异常停止,或者checkpoint失败,那么下次checkpoint将从上次失败的地方继续处理数据。容错恢复的算法是异步屏障算法

1.自定函数:
利用flink-table的TableFunction表函数
flink-core包的Tuple函数Api,实现代码:

public class ASI_UDTF extends TableFunction<Tuple1<String[]>> {

    public void eval(String str1) {
        if (Strings.isNullOrEmpty(str1)) {
            collect(null);
        } else {
            String[] split1 = str1.split(",");
            Tuple1<String[]> of1 = Tuple1.of(split1);
            collect(of1);
        }
    }
}


在flink控制台里把自定义函数的jar包生成一个对应的函数;
注意:

  • 函数的入参判空!!!
  • 用lateral table派生表关联时,也要注意如果是null值的情况,所以要外连接,例如:
LEFT JOIN lateral table (trans_to_array(gss.`goods_specification_values`)) as F(gss_array_values) ON TRUE


2.oracle-cdc同步到mysql-jdbc的场景:
oracle-cdc同步到mysql-jdbc,需要驱动jar,三个包:
flink-connector-jdbc-3.0.0-1.16.jar
flink-sql-connector-oracle-cdc-2.3.0.jar
mysql-connector-java-5.1.49.jar;
使用flinksql的方式:

oracle-cdc,create source table的参考格式
Flink SQL> CREATE TABLE products (
     ID INT NOT NULL,
     NAME STRING,
     DESCRIPTION STRING,
     WEIGHT DECIMAL(10, 3),
     PRIMARY KEY(id) NOT ENFORCED
     ) WITH (
     'connector' = 'oracle-cdc',
     'hostname' = 'localhost',
     'port' = '1521',
     'username' = 'flinkuser',
     'password' = 'flinkpw',
     'database-name' = 'XE',
     'schema-name' = 'inventory',
     'table-name' = 'products');
=======================================
mysql-jdbc,create sink table参考格式:
Flink SQL>CREATE TABLE vehicle_info (
  id BIGINT,
  company_name STRING,
    PRIMARY KEY (`id`) NOT ENFORCED
) WITH (
  'connector' = 'jdbc',
  'url' = 'jdbc:mysql://192.168.0.33:3306/mayi_user',
  'table-name' = 'vehicle_info',
  'username' = 'mayi_admin',
  'password' = '1q2w3e4r'
);

相关使用链接:https://ververica.github.io/flink-cdc-connectors/master/content/connectors/oracle-cdc.html

相关推荐

  1. flink-cdc使用小结

    2024-02-23 16:58:04       28 阅读
  2. <span style='color:red;'>Flink</span> <span style='color:red;'>CDC</span>

    Flink CDC

    2024-02-23 16:58:04      31 阅读
  3. <span style='color:red;'>Flink</span> <span style='color:red;'>CDC</span>

    Flink CDC

    2024-02-23 16:58:04      16 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-23 16:58:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-23 16:58:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-23 16:58:04       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-23 16:58:04       20 阅读

热门阅读

  1. 删除文件中的注释(C语言)

    2024-02-23 16:58:04       29 阅读
  2. 【Android 协程常见用法】

    2024-02-23 16:58:04       39 阅读
  3. Jmeter 学习目录(0)

    2024-02-23 16:58:04       32 阅读
  4. PyTorch中保存模型的两种方式

    2024-02-23 16:58:04       26 阅读
  5. Cpython和Jpython区别

    2024-02-23 16:58:04       29 阅读
  6. 中国工业废水处理行业报告

    2024-02-23 16:58:04       24 阅读
  7. Asp.Net web 文件服務快速搭建

    2024-02-23 16:58:04       22 阅读
  8. 【机器学习】机器学习是什么?

    2024-02-23 16:58:04       28 阅读
  9. SQL中为什么不要使用1=1

    2024-02-23 16:58:04       28 阅读
  10. HW面试常见知识点(新手认识版)

    2024-02-23 16:58:04       29 阅读
  11. android recyclerview 中的animation滚动中动画停止了?

    2024-02-23 16:58:04       30 阅读