【Flink】数据管道,MySQL-->Flink数据清洗-->MySQL (SpringBoot环境)

场景:从MySQL数据库中读取数据进过Flink清洗再存入到MySQL中

一、直接上代码,代码中的数据库连接参数、实体类可改成自己的

@PostMapping("dataStreamAPI")
    public void dataStreamAPI() throws Exception {

        //创建执行环境
        StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();

        //设置并行度
        env.setParallelism(1);

        //获取数据源
        DataStream<Event> stream = env.addSource(new RichSourceFunction<Event>() {

                    private volatile boolean isRunning = true;
                    private Connection conn = null;
                    private PreparedStatement ps = null;

                    // 打开数据库连接,只执行一次,之后一直使用这个连接
                    @Override
                    public void open(Configuration parameters) throws Exception {
                        super.open(parameters);
                        Class.forName("com.mysql.jdbc.Driver");  // 加载数据库驱动
                        conn = (Connection) DriverManager.getConnection(  // 获取连接
                                "jdbc:mysql://xxx.xxx.xxx.xxx:3306/talbe?useSSL=false&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&transformedBitIsBoolean=true&tinyInt1isBit=false&allowMultiQueries=true&serverTimezone=GMT%2B8&rewriteBatchedStatements=true",  // 数据库URL
                                "root",  // 用户名
                                "root");  // 登录密码
                        ps = (PreparedStatement) conn.prepareStatement(  // 获取执行语句
                                "SELECT stkcd,easy_name,publisher FROM bond_base_all LIMIT 0,10");  // 需要执行的SQL语句
                    }

                    // 执行查询并获取结果
                    @Override
                    public void run(SourceContext<Event> ctx) throws Exception {
//                while(isRunning) {  // 使用while循环可以不断读取数据
                        ResultSet resultSet = ps.executeQuery();
                        while (resultSet.next()) {
                            String value1 = resultSet.getString("stkcd");
                            String value2 = resultSet.getString("easy_name");
                            String value3 = resultSet.getString("publisher");
                            ctx.collect(new Event(value1, value2, value3));  // 以流的形式发送结果
                        }
//                    Thread.sleep(6000);  // 每隔6秒查询一次
//                }
                    }

                    // 取消数据生成
                    @Override
                    public void cancel() {
                        isRunning = false;
                    }

                    // 关闭数据库连接
                    @Override
                    public void close() throws Exception {
                        super.close();
                        if (conn != null) conn.close();
                        if (ps != null) ps.close();
                    }
                })

                //中间可以进行一些数据转换操作
                .map(new MapFunction<Event, Event>() {
                    @Override
                    public Event map(Event event) throws Exception {
                        return new Event(event.getValue1().split("\\.")[0], "债券简称:" + event.getValue2(), event.getValue3());
                    }
                });

        //把数据存入到mysql中
        stream.addSink(JdbcSink.sink(
                "INSERT INTO t_event VALUES (?,?,?)",//SQL语句 插值表达式
                (((statement, event) -> {//(进行数据插入,数据源的数据)
                    statement.setString(1, event.value1);
                    statement.setString(2, event.value2);
                    statement.setString(3, event.value3);
                })),
                new JdbcConnectionOptions.JdbcConnectionOptionsBuilder()
                        .withUrl("jdbc:mysql://xxx.xxx.xxx.xxx:3306/table?useSSL=false&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&transformedBitIsBoolean=true&tinyInt1isBit=false&allowMultiQueries=true&serverTimezone=GMT%2B8&rewriteBatchedStatements=true")//URL连接地址
                        .withDriverName("com.mysql.jdbc.Driver")//JDBC驱动
                        .withUsername("root")//用户名
                        .withPassword("root")//密码
                        .build()
        ));

        //启动
        env.execute();
    }

二、访问该接口进行任务执行

数据源表数据:

数据入库表数据:

总结:经过Flink简单的清洗已实现库到库的数据传输

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值