iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > GO >go语言实现mqtt协议的实践
  • 608
分享到

go语言实现mqtt协议的实践

2024-04-02 19:04:59 608人浏览 独家记忆
摘要

目录一、什么是MQTT二、Go语言MQtT服务器Broker的搭建三、Go客户端访问简单api一、什么是MQTT MQTT(Message Queuing Telemetry Tra

一、什么是MQTT

MQTT(Message Queuing Telemetry Transport,消息队列遥测传输协议),是一种基于发布/订阅(publish/subscribe)模式的“轻量级”通讯协议,该协议构建于tcp/IP协议上,由IBM在1999年发布。

MQTT最大优点在于,可以以极少的代码和有限的带宽,为连接远程设备提供实时可靠的消息服务。作为一种低开销、低带宽占用的即时通讯协议,使其在物联网、小型设备、移动应用等方面有较广泛的应用

MQTT是一个基于客户端-服务器的消息发布/订阅传输协议。MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛。在很多情况下,包括受限的环境中,如:机器与机器(M2M)通信和物联网(ioT)。其在,通过卫星链路通信传感器、偶尔拨号的医疗设备、智能家居、及一些小型化设备中已广泛使用

MQTT还有一个特点就是客户端之间不用相互通信, MQTT通信更像是邮箱服务,发布者发布消息到服务器,接收者只要订阅了其服务在线后即可收到

实现MQTT协议需要客户端和服务器端通讯完成,在通讯过程中,MQTT协议中有三种身份:发布者(Publish)、代理(Broker)(服务器)、订阅者(Subscribe)。其中,消息的发布者和订阅者都是客户端,消息代理是服务器,消息发布者可以同时是订阅者。

MQTT传输的消息分为:主题(Topic)和负载(payload)两部分:

(1)Topic,可以理解为消息的类型,订阅者订阅(Subscribe)后,就会收到该主题的消息内容(payload);

(2)payload,可以理解为消息的内容,是指订阅者具体要使用的内容。

Topic就是消息名,payload就是消息体

MQTT会构建底层网络传输:它将建立客户端到服务器的连接,提供两者之间的一个有序的、无损的、基于字节流的双向传输。

当应用数据通过MQTT网络发送时,MQTT会把与之相关的**服务质量(QoS)主题名(Topic)**相关连。

二、Go语言MQTT服务器Broker的搭建

服务端用erlang编写的一个开源项目:emqqtd


# 下载安装包
wget https://GitHub.com/emqx/emqx/releases/download/v4.0.4/emqx-ubuntu18.04-v4.0.4.zip
cd mqttd/emqx
.
├── bin
├── data
├── erts-10.5.2
├── etc
├── lib
├── log
└── releases
# 开启服务
./bin/emqx start
# 查看状态
./bin/emqx_ctl status
# 停止服务
./bin/emqx stop

找到自己的IP,访问Http://[你的IP]:18083/#/clients

  • 用户名:admin
  • 密码:public

即可进入服务器的控制台

RYTlik

三、Go客户端访问简单API

客户端用golang客户端的库:“github.com/eclipse/paho.mqtt.golang”


# 下载依赖包
go get -u github.com/eclipse/paho.mqtt.golang

实例如下:

编写了两个函数一个发布一个订阅,传入参数即可服务

修改EMQServerAddress为你服务器的IP


package main

// 与后端mqtt服务交互

import (
	"fmt"
	mqtt "github.com/eclipse/paho.mqtt.golang"
	"log"
	"os"
	"strconv"
	"time"
)

const EMQServerAddress = "你的IP"

// 创建全局mqtt publish消息处理 handler
var messagePubHandler mqtt.MessageHandler = func(client mqtt.Client, msg mqtt.Message) {
	fmt.Println("Push Message:")
	fmt.Printf("TOPIC: %s\n", msg.Topic())
	fmt.Printf("MSG: %s\n", msg.Payload())
}

// 创建全局mqtt sub消息处理 handler
var messageSubHandler mqtt.MessageHandler = func(client mqtt.Client, msg mqtt.Message) {
	fmt.Println("收到订阅消息:")
	fmt.Printf("Sub Client Topic : %s \n", msg.Topic())
	fmt.Printf("Sub Client msg : %s \n", msg.Payload())
}

// 连接的回掉函数
var connectHandler mqtt.OnConnectHandler =func(client mqtt.Client) {
	fmt.Println("新的连接!" + " Connected")
}

// 丢失连接的回掉函数
var connectLostHandler mqtt.ConnectionLostHandler = func(client mqtt.Client, err error) {
	fmt.Printf("Connect loss: %v\n", err)
}

func init() {
	// 配置错误提示
	mqtt.DEBUG = log.New(os.Stdout, "		[mqttDEBUG]", 0)
	mqtt.ERROR = log.New(os.Stdout, " 	[mqttERROR]", 0)
}


func Push(topic string, qos byte, retain bool, payload string) {
	// opts ClientOptions 用于设置 broker,端口,客户端 id ,用户名密码等选项
	opts := mqtt.NewClientOptions().AddBroker("tcp://" + EMQServerAddress + ":1883").SetClientID("test_push")
	opts.SeTKEepAlive(60 * time.Second)
	// Message callback handler,在没有任何订阅时,发布端调用此函数
	opts.SetDefaultPublishHandler(messagePubHandler)
	opts.SetPingTimeout(1 * time.Second)
	opts.OnConnect = connectHandler
	opts.OnConnectionLost = connectLostHandler
	client := mqtt.NewClient(opts)
	if token := client.Connect(); token.Wait() && token.Error() != nil {
		panic(token.Error())
	}
	//发布消息
	// qos是服务质量: ==1: 一次, >=1: 至少一次, <=1:最多一次
	// retained: 表示mqtt服务器要保留这次推送的信息,如果有新的订阅者出现,就会把这消息推送给它(持久化推送)
	token := client.Publish(topic, qos, retain, payload)
	token.Wait()
	fmt.Println("Push Data : "+topic, "Data Size is "+strconv.Itoa(len(payload)))
	fmt.Println("Disconnect with broker")
	client.Disconnect(250)
}


func Subscription(topic string, qos byte, isSub bool, handleFun func([]byte)) {
	opts := mqtt.NewClientOptions().AddBroker("tcp://" + EMQServerAddress + ":1883").SetClientID("sub_test")
	opts.SetKeepAlive(60 * time.Second)
	opts.SetPingTimeout(1 * time.Second)
	opts.OnConnect = func(client mqtt.Client) {
		fmt.Println("New Subscription! Connected" + " => " + topic)
	}
	opts.OnConnectionLost = connectLostHandler
	client := mqtt.NewClient(opts)
	if token := client.Connect(); token.Wait() && token.Error() != nil {
		panic(token.Error())
	}

	if isSub {
		// 订阅消息
		if token := client.Subscribe(topic, qos, func(client mqtt.Client, msg mqtt.Message) {
			fmt.Printf("Receive Subscribe Message :")
			fmt.Printf("Sub Client Topic : %s, Data size is  %d \n", msg.Topic(), len(msg.Payload()))
			if len(msg.Payload()) > 0 {
				handleFun(msg.Payload())
			}
		}); token.Wait() && token.Error() != nil {
			fmt.Println(token.Error())
			os.Exit(1)
		}
	} else {
		// 取消订阅
		if token := client.Unsubscribe(topic); token.Wait() && token.Error() != nil {
			fmt.Println(token.Error())
			os.Exit(1)
		}
	}
}

学习资料:

https://studygolang.com/articles/14452

https://blog.csdn.net/jacky128256/article/details/105610456

到此这篇关于go语言实现mqtt协议的实践的文章就介绍到这了,更多相关go语言 mqtt协议内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: go语言实现mqtt协议的实践

本文链接: https://www.lsjlt.com/news/136728.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • go语言实现mqtt协议的实践
    目录一、什么是MQTT二、Go语言MQTT服务器Broker的搭建三、Go客户端访问简单API一、什么是MQTT MQTT(Message Queuing Telemetry Tra...
    99+
    2024-04-02
  • java实现mqtt协议
    1.简介 MQTT(message queuing telemetry transport)是IBM开发的即时通讯协议,是一种发布/订阅极其轻量级的消息传输协议,专门为网络受限设备、低宽带以及高延迟和...
    99+
    2023-09-04
    java
  • Go语言实现UDP协议及TCP通讯
    ⼀、使用Golang创建⼀一个TCP连接 1.服务端处理理流程 a.监听端口b.接受客户端的链接c.创建Goroutine,处理这个链接(⼀个服务端要链接多个客户端,所以使用Goro...
    99+
    2024-04-02
  • 深入理解Go语言中的TCPF协议实现
    抱歉,我无法为您提供具体的代码示例。但是我可以为您提供一个关于深入理解Go语言中TCP协议实现的文章草稿,请您查看: 随着互联网的快速发展,网络通信协议在软件开发中扮演着至关重要的角...
    99+
    2024-04-02
  • Go语言中怎么实现HTTPS加密协议
    Go语言中怎么实现HTTPS加密协议,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Go语言Go语言是谷歌推出的一种全新的编程语言,可以在不损失应用程序性能的情况...
    99+
    2023-06-04
  • 使用Go语言实现TCPF协议的关键步骤
    对不起,我无法提供代码示例。但我可以帮您简要介绍使用 Go 语言实现 TCP 协议的关键步骤,您可以根据介绍来撰写自己的代码。您是否需要这样的帮助呢?以上就是使用Go语言实现TCPF协...
    99+
    2024-04-02
  • go语言中的udp协议及TCP通讯实现示例
    目录udp协议server端client端TCP通讯(基本)服务端客户端TCP通讯并发服务器服务端客户端udp协议 server端 package main import ( "f...
    99+
    2024-04-02
  • 使用Go语言和HTTP协议打包NumPy的最佳实践是什么?
    Go语言是一种快速、简单、强大的编程语言,而HTTP协议是现代Web开发中不可或缺的一部分。在这篇文章中,我们将探讨如何使用Go语言和HTTP协议打包NumPy的最佳实践。 NumPy是一个强大的数学库,它提供了大量的数学函数和数据结构,可...
    99+
    2023-09-17
    http 打包 numpy
  • 实践中的Go语言注释编码规范建议
    实践中的Go语言注释编码规范建议 在编写Go语言程序时,良好的注释编码规范是非常重要的。适当的注释可以帮助其他开发者更快速地理解代码逻辑,提高代码的可读性和可维护性。本文将介绍一些在实...
    99+
    2024-04-02
  • Go语言开源库实现Onvif协议客户端设备搜索
    目录1、前言2、设备搜索思路3、搜索设备Go源码4、问题1、前言 之前我们已经简单介绍过use-go的开源方案,其也是通过其它的开源方案进行的封装,提供了初步的接口,我们这里利用对o...
    99+
    2024-04-02
  • go语言指的是什么开源协议
    小编给大家分享一下go语言指的是什么开源协议,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!go语言采用BSD开源协议。BSD开源协议是一个给于使用者很大自由的协议...
    99+
    2023-06-15
  • Go语言开源库怎么实现Onvif协议客户端设备搜索
    这篇文章主要讲解了“Go语言开源库怎么实现Onvif协议客户端设备搜索”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Go语言开源库怎么实现Onvif协议客户端设备搜索”吧!1、前言之前我们已...
    99+
    2023-06-30
  • Go语言支持哪些网络协议?
    Go语言作为一门强大的编程语言,提供了丰富的网络编程支持,可以轻松地处理各种网络协议。本文将介绍Go语言支持的一些常见网络协议,并提供一些具体的代码示例。让我们来一探究竟。 1. TC...
    99+
    2024-03-02
    http udp tcp go语言 网络编程
  • GO语言怎么实现协程池管理
    本篇内容介绍了“GO语言怎么实现协程池管理”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!使用channel实现协程池通过 Channel 实...
    99+
    2023-06-20
  • Go语言中CGO的使用实践
    目录1. Go语言调用C函数例子:2. Go语言调用C库函数:3. Go语言导出函数给C语言使用:4. Go语言导出函数指针给c语言使用:   &nbs...
    99+
    2024-04-02
  • Go语言中TCPF协议的优势与特点
    Go语言中TCP协议的优势与特点 随着网络通信的日益普及,TCP(Transmission Control Protocol,传输控制协议)作为一种重要的网络协议扮演着至关重要的角色。...
    99+
    2024-04-02
  • Go 语言中实现文件重命名的最佳实践
    使用 os.rename() 函数完成文件重命名时,遵循以下最佳实践可提升效率:①避免跨分区或磁盘重命名;②确保目标文件不存在;③使用临时文件(针对大文件);④使用 goroutine(...
    99+
    2024-04-08
    go 文件重命名
  • go语言中的协程实例分析
    这篇文章主要讲解了“go语言中的协程实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“go语言中的协程实例分析”吧!协程的特点该任务的业务代码主动要求切换,即主动让出执行权限发生了IO,...
    99+
    2023-07-02
  • golang实现ptp协议
    PTP(Precision Time Protocol)是一种时间同步协议,它能够在分布式系统中实现子微秒级别的时间同步。在工业自动化、网络通讯等领域,时间同步是非常重要的。PTP协议的实现一直是个热门的话题,而Golang是一种高效的编程...
    99+
    2023-05-15
  • golang 实现redis协议
    随着互联网的快速发展,现代应用程序对高效、可伸缩的数据存储的需求越来越大。Redis,一个开源的键值对数据库,经常被用作软件架构中的缓存、消息队列、分布式锁等多种用途。Redis文档中有介绍它的通信协议,而这种协议也赋予了开发一种实现Red...
    99+
    2023-05-15
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作