go语言实现mqtt协议的实践
本篇文章向大家介绍《go语言实现mqtt协议的实践》,主要包括gomqtt协议,具有一定的参考价值,需要的朋友可以参考一下。
一、什么是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
即可进入服务器的控制台
三、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) } /** * @Description: 发布订阅 * @param clientID * @param addr * @param topic * @param payload */ 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: 至少一次, " + 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) } } }
学习资料:
今天带大家了解了gomqtt协议的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

- 上一篇
- 小学生也能看懂的Golang异常处理recover panic

- 下一篇
- Go语言使用defer+recover解决panic导致程序崩溃的问题
-
- 拉长的铅笔
- 写的不错,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢老哥分享博文!
- 2023-05-04 14:20:26
-
- 高大的冰棍
- 这篇文章内容出现的刚刚好,太细致了,受益颇多,已加入收藏夹了,关注大佬了!希望大佬能多写Golang相关的文章。
- 2023-03-13 00:06:07
-
- 正直的冬天
- 细节满满,码住,感谢博主的这篇技术文章,我会继续支持!
- 2023-03-07 19:59:45
-
- 心灵美的方盒
- 这篇博文真是及时雨啊,太全面了,太给力了,码住,关注楼主了!希望楼主能多写Golang相关的文章。
- 2023-01-28 08:38:48
-
- 孝顺的红牛
- 细节满满,已加入收藏夹了,感谢师傅的这篇文章,我会继续支持!
- 2023-01-13 18:52:54
-
- 甜美的老师
- 受益颇多,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢作者分享博文!
- 2023-01-13 12:19:34
-
- Golang · Go教程 | 50秒前 |
- Golang环境搭建与数据库配置教程
- 165浏览 收藏
-
- Golang · Go教程 | 21分钟前 |
- GeanyGo语言编辑技巧分享
- 263浏览 收藏
-
- Golang · Go教程 | 22分钟前 |
- Golang反射缺陷及替代方案解析
- 299浏览 收藏
-
- Golang · Go教程 | 25分钟前 |
- GolangServerless冷启动优化技巧
- 238浏览 收藏
-
- Golang · Go教程 | 31分钟前 |
- GolangTCP粘包处理与自定义协议详解
- 420浏览 收藏
-
- Golang · Go教程 | 33分钟前 | golang net/http 标准库 CRUD RESTfulAPI
- Golang标准库搭建RESTfulAPI教程
- 346浏览 收藏
-
- Golang · Go教程 | 35分钟前 |
- 优化GolangHTTPKeep-Alive设置提升性能
- 377浏览 收藏
-
- Golang · Go教程 | 38分钟前 |
- Golangcontext如何影响Web开发?
- 385浏览 收藏
-
- Golang · Go教程 | 39分钟前 |
- Golang跨语言绑定:cgo与SWIG使用教程
- 418浏览 收藏
-
- Golang · Go教程 | 44分钟前 |
- Golangio库流式操作:Reader与Writer详解
- 141浏览 收藏
-
- Golang · Go教程 | 50分钟前 |
- Golang降低GC停顿技巧:手动内存管理方法
- 162浏览 收藏
-
- Golang · Go教程 | 56分钟前 |
- Golang构建BFF服务,定制客户端后端方案
- 170浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 96次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 89次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 107次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 98次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 99次使用
-
- Golangmap实践及实现原理解析
- 2022-12-28 505浏览
-
- 试了下Golang实现try catch的方法
- 2022-12-27 502浏览
-
- Go语言中Slice常见陷阱与避免方法详解
- 2023-02-25 501浏览
-
- Golang中for循环遍历避坑指南
- 2023-05-12 501浏览
-
- Go语言中的RPC框架原理与应用
- 2023-06-01 501浏览