创建flink的MqttSource (scala版本)

本文介绍了使用Scala编写的MqttClient类,该类用于连接Mqtt服务器,并订阅主题。同时展示了MqttSource的实现,作为Flink数据源接收消息。然而,目前存在一个问题:当发送汉字字符串时,接收端收到的是一段数字。这可能是编码或者解码问题,需要进一步排查和解决。

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

一.编写 MqttClient类

class MqttClient {

  var url:String="tcp://192.168.174.206:1883"
  var flag:Boolean=true
  private val topicArr: Array[Topic] = List(new Topic("topic_test",QoS.AT_LEAST_ONCE),new Topic("topic_test",QoS.AT_MOST_ONCE),new Topic("topic_test",QoS.EXACTLY_ONCE)).toArray

  //开始连接
  def  start():FutureConnection={
     val mqtt = new MQTT()

    mqtt.setHost(url) //设置连接地址
    mqtt.setCleanSession(true)//是否清空会话信息
    mqtt.setReconnectAttemptsMax(10) //设置最大的重新连接次数
    mqtt.setReconnectDelay(10) //设置重新连接的时长
    mqtt.setKeepAlive(30) //设置心跳时间
    mqtt.setSendBufferSize(64) //设置缓冲区的大小
    mqtt.setClientId("clientid_0001")

    val connection: FutureConnection = mqtt.futureConnection()
    connection.connect()
    connection.subscribe(topicArr)

    return connection

  }

}

 2.编辑MqttSource

object MqttSource extends RichSourceFunction[String] {

   var flag:Boolean=true
  override def run(sourceContext: SourceFunction.SourceContext[String]): Unit = {
    val client = new MqttClient()
    val connection: FutureConnection = client.start()

    var msg:String=""

    while (true){
      val futureMessage: Future[Message] = connection.receive()
      val message: Message = futureMessage.await()
      msg = String.valueOf(message.getPayloadBuffer()).substring(6)
      sourceContext.collect(msg)
    }
  }
  override def cancel(): Unit = {
    flag=false
  }
}

 三,编辑flink主类 flinkMQtt

object flinkMQtt {
  def main(args: Array[String]): Unit = {
  //创建执行的环境
   val env: StreamExecutionEnvironment = StreamExecutionEnvironment.getExecutionEnvironment
  //设置并行度
   env.setParallelism(1)
   val mqttDS: DataStreamSource[String] = env.addSource(MqttSource)
   mqttDS.print()
    
//执行job
env.execute()
  }
}

 存在一个问题:如果发送汉字字符串接,接收端收到一段数字?还没解决!!!知道的留下解决方式......

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值