Flink自定义Sink写入到HBase

本文介绍了一个使用Apache Flink实现自定义Sink Function的例子,该Sink Function用于将数据写入到HBase中。具体包括配置HBase连接、创建表及执行插入操作等步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import org.apache.flink.configuration.Configuration;
import org.apache.flink.streaming.api.datastream.DataStreamSource;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.streaming.api.functions.sink.RichSinkFunction;
import org.apache.hadoop.hbase.HBaseConfiguration;
import org.apache.hadoop.hbase.TableName;
import org.apache.hadoop.hbase.client.Connection;
import org.apache.hadoop.hbase.client.ConnectionFactory;
import org.apache.hadoop.hbase.client.Put;
import org.apache.hadoop.hbase.client.Table;

import java.nio.charset.StandardCharsets;

/**
 * Author:panghu
 * Date:2022-05-29
 * Description: 自定义source写入HBase
 */
public class _19SinkCustomtoHBase {
    public static void main(String[] args) throws Exception {
        StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
        env.setParallelism(1);

        DataStreamSource<String> streamSource = env.fromElements("hello", "world");

        streamSource.addSink(
                new RichSinkFunction<String>() {
                    //管理HBase的配置信息
                    //因为类重名的问题,将类的完整路径导入
                    org.apache.hadoop.conf.Configuration configuration;
                    Connection connection;

                    @Override
                    public void open(Configuration parameters) throws Exception {
                        super.open(parameters);
                        // HBase的链接参数
                        configuration = HBaseConfiguration.create();
                        configuration.set("hbase.zookeeper.quorum", "hadoop102:2181");
                        connection = ConnectionFactory.createConnection(configuration);
                    }

                    @Override
                    public void close() throws Exception {
                        super.close();
                        connection.close(); //关闭链接
                    }

                    @Override
                    public void invoke(String value, Context context) throws Exception {
                        Table tb = connection.getTable(TableName.valueOf("test")); // 表名
                        Put put = new Put("rowkey".getBytes(StandardCharsets.UTF_8)); // 指定rowkey

                        put.addColumn("info".getBytes(StandardCharsets.UTF_8),   // 列名
                                value.getBytes(StandardCharsets.UTF_8),     // 写入的数据
                                "1".getBytes(StandardCharsets.UTF_8)        // 写入的数据
                        );
                        // 执行put操作
                        tb.put(put);
                        // 关闭表
                        tb.close();
                    }
                }
        );

        env.execute();
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值