Flink 输出至 Redis

【1】引入第三方Bahir提供的Flink-redis相关依赖包

xml 复制代码
<!-- https://mvnrepository.com/artifact/org.apache.bahir/flink-connector-redis -->
<dependency>
    <groupId>org.apache.bahir</groupId>
    <artifactId>flink-connector-redis_2.11</artifactId>
    <version>1.0</version>
</dependency>

【2】Flink连接Redis并输出Sink处理结果

java 复制代码
package com.zzx.flink

import org.apache.flink.streaming.api.scala._
import org.apache.flink.streaming.connectors.redis.RedisSink
import org.apache.flink.streaming.connectors.redis.common.config.FlinkJedisPoolConfig
import org.apache.flink.streaming.connectors.redis.common.mapper.{RedisCommand, RedisCommandDescription, RedisMapper}

object RedisSinkTest {
  def main(args: Array[String]): Unit = {
    // 创建一个流处理执行环境
    val env = StreamExecutionEnvironment.getExecutionEnvironment
    //从文件中读取数据并转换为 类
    val inputStreamFromFile: DataStream[String] = env.readTextFile("E:\\Project\\flink\\src\\main\\resources\\wordcount.txt")
    //转换  SensorReading为用户自定义的类,是从文件转换而来的
    val dataStream: DataStream[SensorReading] = inputStreamFromFile
      .map( data => {
        var dataArray = data.split(",")
        SensorReading(dataArray(0),dataArray(1).toLong,dataArray(2).toDouble)
      })
    //定义一个 redis 的配置类 继承了FlinkJedisConfigBase 正是 SensorReading需要传入的参数,底层将有些数据保存成了状态数据。
    val conf = new FlinkJedisPoolConfig.Builder().setHost("192.168.52.131").setPort(6379).setPassword("zzx").build()
    //定义 RedisMapper 数据保存的类型
    val myMapper = new RedisMapper[SensorReading] {
      //定义保存数据到 redis的命令,hset table key value
      override def getCommandDescription: RedisCommandDescription = {
        // hset tablesname
        new RedisCommandDescription(RedisCommand.HSET , "sensor_temp")
      }
      //设置key
      override def getKeyFromData(data: SensorReading): String = data.id
      //设置value
      override def getValueFromData(data: SensorReading): String = data.temperature.toString
    }
    dataStream.addSink(new RedisSink[SensorReading](conf,myMapper))

    env.execute("Redis Sink test")
  }
}

查看源码可知RedisSink是继承自RichSinkFunction<IN>

java 复制代码
public class RedisSink<IN> extends RichSinkFunction<IN> {

【3】查看Redis输出信息

相关推荐
飞飞9874 分钟前
spring mvc
java·服务器·前端
贺函不是涵4 分钟前
【沉浸式求职学习day47】【JSP详解】
java·开发语言·学习
Ultipa13 分钟前
云计算与大数据进阶 | 27、存储系统如何突破容量天花板?可扩展架构的核心技术与实践—— 分布式、弹性扩展、高可用的底层逻辑(上)
大数据·架构·云计算
曼岛_14 分钟前
[Java实战] Docker 快速启动 Sentinel 控制台(二十八)
java·docker·sentinel
旋风菠萝41 分钟前
八股--SSM(2)
java·开发语言·数据库·八股·八股文·复习
攻心的子乐1 小时前
Flyweight(享元)设计模式 软考 享元 和 代理属于结构型设计模式
java·开发语言
设计师小聂!1 小时前
Seata分布式事物案例及详解
java·spring·spring cloud
编程乐学(Arfan开发工程师)1 小时前
16、最佳实践-SpringBoot应用如何编写
java·spring boot·后端
2401_876907521 小时前
IEC 61156-5:2020 标准技术解析与应用综述
经验分享·面试·职场和发展·跳槽·iec
取个好名称1 小时前
适合初学者的 Blender 第二部分
java·前端·blender