flink写入redis(redisSink)

  • 1.所需依赖
  <dependency>
      <groupId>org.apache.bahir</groupId>
      <artifactId>flink-connector-redis_2.11</artifactId>
      <version>1.0</version>
    </dependency>
  • 2.redisSink
  /**
     * 生成RedisSink
     */
    private static RedisSink<Tuple2<String, Long>> generateRedisSink() {
        // Redis配置
        FlinkJedisPoolConfig config = new FlinkJedisPoolConfig.Builder()
                .setMaxTotal(8) // 最大实例总数
                .setMaxIdle(4) // 实例最多空闲数
                .setMinIdle(2)
                .setHost("192.168.19.10")
                .setPort(6379)
                .build();
        // Mapper
        RedisMapper<Tuple2<String, Long>> redisMapper = new RedisMapper<Tuple2<String, Long>>() {
            @Override
            public RedisCommandDescription getCommandDescription() {
                // 定义保存数据到Redis的命令
                return new RedisCommandDescription(
                        RedisCommand.HSET, // 使用hset命令
                        "my_hash" // 表名
                );
            }

            @Override
            public String getKeyFromData(Tuple2<String, Long> tuple2) {
                return tuple2.f0;
            }

            @Override
            public String getValueFromData(Tuple2<String, Long> tuple2) {
                return tuple2.f1.toString();
            }
        };

        return new RedisSink<>(config, redisMapper);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值