Flink读Kafka写入HBase

Flink从kafka读数据写入HBase

Flink官网帮助文档链接
先导入依赖

<dependency>
            <groupId>org.apache.flink</groupId>
            <artifactId>flink-connector-hbase_2.11</artifactId>
            <version>1.11.2</version>
</dependency>
import org.apache.flink.streaming.api.scala._
import org.apache.flink.table.api._
import org.apache.flink.table.api.bridge.scala._


object Demo8ToHbase {
  def main(args: Array[String]): Unit = {
    val bsEnv: StreamExecutionEnvironment = StreamExecutionEnvironment.getExecutionEnvironment

    val bsSettings: EnvironmentSettings = EnvironmentSettings
      .newInstance()
      .useBlinkPlanner() //使用blink的计划器
      .inStreamingMode() //使用流模型
      .build()

    //窗口table 环境
    val bsTableEnv: StreamTableEnvironment = StreamTableEnvironment.create(bsEnv, bsSettings)

    /**
     * source表
     */
    bsTableEnv.executeSql(
      """CREATE TABLE canal_student (
        | id STRING,
        | name STRING,
        | age BIGINT,
        | gender STRING,
        | clazz STRING
        |) WITH (
        | 'connector' = 'kafka',
        | 'topic' = 'student.student',
        | 'properties.bootstrap.servers' = 'master:9092',
        | 'properties.group.id' = 'aaa',
        | 'format' = 'canal-json',
        | 'scan.startup.mode' = 'earliest-offset',
        | 'canal-json.ignore-parse-errors'='true'
        |)
      """.stripMargin)

    /**
     * hbase sink表
     * 需要先在HBase里创建表
     * create 'student','info'
     */
    bsTableEnv.executeSql(
      """
        |CREATE TABLE hbase_sink (
        | id INT,
        | info ROW<name STRING,age BIGINT,gender STRING,clazz STRING>,
        | PRIMARY KEY (id) NOT ENFORCED
        |) WITH (
        | 'connector' = 'hbase-1.4',
        | 'table-name' = 'student',
        | 'zookeeper.quorum' = 'master:2181'
        |)
        |""".stripMargin)

    bsTableEnv.executeSql(
      """
        |
        |insert into hbase_sink
        |select id,ROW(name,age,gender,clazz) as info from canal_student
        |
      """.stripMargin)
  }
}

idea运行代码

在这里插入图片描述
然后在HBase里查看数据

scan 'student'

在这里插入图片描述

读取Hbase数据

package com.liu.sql

import org.apache.flink.streaming.api.scala._
import org.apache.flink.table.api._
import org.apache.flink.table.api.bridge.scala._

object Demo9Readhbase {
  def main(args: Array[String]): Unit = {
    val bsEnv: StreamExecutionEnvironment = StreamExecutionEnvironment.getExecutionEnvironment

    val bsSettings: EnvironmentSettings = EnvironmentSettings
      .newInstance()
      .useBlinkPlanner() //使用blink的计划器
      .inStreamingMode() //使用流模型
      .build()

    //窗口table 环境
    val bsTableEnv: StreamTableEnvironment = StreamTableEnvironment.create(bsEnv, bsSettings)

    /**
     * 读取HBase---有界流
     */
    bsTableEnv.executeSql(
      """
        |CREATE TABLE hbase_sink (
        | id INT,
        | info ROW<name STRING,age BIGINT,gender STRING,clazz STRING>,
        | PRIMARY KEY (id) NOT ENFORCED
        |) WITH (
        | 'connector' = 'hbase-1.4',
        | 'table-name' = 'student',
        | 'zookeeper.quorum' = 'master:2181'
        |)
        |""".stripMargin)

    bsTableEnv.executeSql(
      """
        |CREATE TABLE print_table WITH ('connector' = 'print')
        |LIKE hbase_source (EXCLUDING ALL)
        |""".stripMargin)
    
    bsTableEnv.executeSql(
      """
        |insert into print_table
        |select * from hbase_source
        |""".stripMargin)
  }
}

  • 0
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值