Flink CDC 实时同步mysql

1、创建环境

StreamExecutionEnvironment bsEnv = StreamExecutionEnvironment.getExecutionEnvironment();
EnvironmentSettings bsSettings = EnvironmentSettings.newInstance().useBlinkPlanner().inStreamingMode().build();
StreamTableEnvironment tEnv = StreamTableEnvironment.create(bsEnv, bsSettings);
//设置job名称
tEnv.getConfig().getConfiguration().setString("pipeline.name", "FlinkCDCTest");    

2、创建基于原mysql表的DWD表

connector = ‘mysql-cdc’

 String createSqlDwd = "CREATE TABLE dwd_order (" +
            "  GUID VARCHAR," +
            "  tenant_guid VARCHAR," +
            "  order_no VARCHAR," +
		    ....
            "  primary key(GUID)  NOT ENFORCED" +
            ") WITH (" +
            "'connector' = 'mysql-cdc'," +
            "'hostname'=''hostname," +
            "'port'='port'," +
            "'username'='username'," +
            "'password'='password'," +
            "'database-name'='datebase'," +
            "'table-name'='table'" +
            ")";
    tEnv.executeSql(createSqlDwd);

3、创建聚合后的主题宽表DWS表,作为目标表

connector’ = ‘jdbc’

String createSqlDws = "CREATE TABLE flink (" +
                "account_month varchar(6), " +
                "sales_territory_guid varchar(32), " +
                "primary key(account_month)  NOT ENFORCED" +
                ") WITH (" +
                "'connector' = 'jdbc'," +
                "'url' = 'jdbc:mysql://ip:port/database'," +
                "'username' = 'root'," +
                "'password' = 'password'," +
                "'table-name' = 'flink_test'," +
                "'sink.buffer-flush.max-rows' = '1'," +
                "'sink.buffer-flush.interval' = '1s'," +
                "'sink.max-retries' = '3'" +
                ")";
                
                tEnv.executeSql(createSqlDws);

3、实时监听DWD表处理数据到DWS表

String insertSql = "INSERT INTO flink (account_month,sales_territory_guid) " +
                "select account_month, " +
                "sales_territory_guid " +
                "from dwd_order ";

        tEnv.executeSql(insertSql);

4、pom.xml设置主程序入口

<build>
        <finalName>flink-test-job</finalName>
        <resources>
            <resource>
                <directory>src/main/java</directory>
            </resource>
            <resource>
                <directory>src/main/resources</directory>
            </resource>
        </resources>
        <testResources>
            <testResource>
                <directory>src/test/java</directory>
            </testResource>
        </testResources>
        <plugins>
            <plugin>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-assembly-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <descriptorRefs>
                        <descriptorRef>jar-with-dependencies</descriptorRef>
                    </descriptorRefs>
                    <archive>
                        <manifest>
                            <addClasspath>true</addClasspath>
                            <!-- 可以设置jar包的入口类(可选) -->
                            <mainClass>com.csbr.cloud.flinkserver.task.Test</mainClass>
                        </manifest>
                    </archive>

                </configuration>
                <executions>
                    <execution>
                        <id>make-assembly</id>
                        <phase>package</phase>
                        <goals>
                            <goal>single</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

项目目录:
在这里插入图片描述
Flink 使用之 MySQL CDC:
https://www.jianshu.com/p/0a47e387de51

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值