阿里云部署开源MQTT平台mosquitto的docker操作

MQTT(Message Queuing Telemetry Transport)是一种轻量级的消息传输协议,广泛用于物联网和传感器网络中。Mosquitto是一个流行的开源MQTT代理,可以在Docker中进行配置和部署。本文将详细介绍如何在Docker中配置Mosquitto MQTT代理,以便在容器化环境中运行和管理MQTT通信。

一、安装docker

在开始之前,确保你的系统上已经安装了Docker。Docker提供了一个开放的平台,可以在容器中打包、分发和运行应用程序。你可以从Docker官方网站下载和安装适合你操作系统的Docker版本。

二、拉取Mosquitto Docker镜像

这里我们以阿里云的Ubuntu系统为例。想要在docker中部署MQTT的服务就得先找好一个开源平台,像mosquitto、EMQ X Broker 等都是开源的MQTT服务,这里我们以搭建mosquitto为例。

拉取mosquitto镜像:

复制代码
docker pull eclipse-mosquitto

# 或者拉取1.6.14版本
docker pull eclipse-mosquitto:1.6.14

这里将拉取最新的mosquitto镜像到docker中。

三、创建mosquitto配置文件

在运行容器之前我们需要先创建一个配置文件,定义mosquitto的日志、配置等文件的存储路径,我们在服务器的根目录下创建一个文件夹。

复制代码
# 创建文件夹
mkdir mosquitto

# 进入mosquitto文件夹
cd mosquitto

# 创建配置文件夹、日志文件夹
mkdir config

mkdir data

mkdir log

在config文件夹下编辑配置文件mosquitto.conf,并添加下列配置内容;

复制代码
persistence true
persistence_location /mosquitto/data
log_dest file /mosquitto/log/mosquitto.log

这里的存储地址可以根据自己的需求进行调整

四、创建mosquitto容器运行

在终端或命令行界面中运行以下命令来运行Mosquitto容器:

复制代码
docker run -itd --name mosquitto -p 9042:1883 -p 9001:9001 -v /mosquitto/config:/mosquitto/config -v /mosquitto/data:/mosquitto/data -v /mosquitto/log:/mosquitto/log eclipse-mosquitto:1.6.14

解释一下这个命令:

  • -itd:以交互模式运行容器,启动之后在后台运行,方便查看输出日志和控制台信息。
  • -p 1883:1883:将宿主机的1883端口映射到容器内的1883端口,以便可以通过该端口与MQTT代理进行通信。
  • --name 容器名称
  • -v /mosquitto/config:/mosquitto/config:将本地的mosquitto-config文件夹挂载到容器内的/mosquitto/config路径,用于配置文件的持久化存储。
  • -v /mosquitto/data:/mosquitto/data:将本地的mosquitto-data文件夹挂载到容器内的/mosquitto/data路径,用于数据的持久化存储。
  • -v /mosquitto/log:/mosquitto/log:将本地的mosquitto-log文件夹挂载到容器内的/mosquitto/log路径,用于日志的持久化存储。
  • eclipse-mosquitto:指定要运行的Mosquitto镜像。

根据实际情况,将/mosquitto/config、/mosquitto/data和/mosquitto/log替换为你本地系统上的相应路径。

运行该命令后,Docker将会创建并运行Mosquitto容器,配置文件和数据将被挂载到容器中,使得配置的持久化和数据的保存得以实现。

复制代码
docker ps

有看到mosquitto的容器名称证明启动成功。

五、测试MQTT通讯

我这里用到的是simulate-device.exe这个工具。工具下载地址:https://download.csdn.net/download/qq_45758854/88279562

看到connect变为灰色证明连接成功。我们可以随便订阅一个主题。

发布:

接收的信息:

如果一切正常,你应该能够在订阅者的终端中看到接收到的消息。

至此,你已经成功在Docker中配置和运行了Mosquitto MQTT代理,并进行了简单的MQTT通信测试。

六、总结

在本文中,我们学习了如何在Docker中配置Mosquitto MQTT代理。通过安装Docker、获取Mosquitto Docker镜像、创建配置文件、运行Mosquitto容器,并进行MQTT通信测试,我们成功实现了在容器化环境中运行和管理MQTT代理的目标。

使用Docker进行配置和部署MQTT代理,可以极大地简化安装和管理过程,并提供了更好的可移植性和可扩展性。无论是在本地开发环境还是在生产环境中,使用Docker可以快速搭建MQTT通信基础设施。

相关推荐
二等饼干~za89866810 小时前
从零搭建 Geo 开源项目源码开发环境——以 GeoServer 为例
开源
极客BIM工作室11 小时前
IfcOpenShell:开源BIM的核心引擎技术解析
开源
lularible11 小时前
从沙子到车辙(3.3):数据通路与控制器的“双人舞“
开源·嵌入式·汽车电子
数据法师11 小时前
MotrixNext:接棒经典 Motrix,用 Tauri 2+Rust 重构的下一代开源下载神器
重构·rust·开源
仙柒41512 小时前
Docker存储原理
运维·docker·容器
码途漫谈13 小时前
让 AI 编程不断线:9Router 的本地模型路由与 Token 节流术
人工智能·ai·开源·ai编程
快乐的哈士奇15 小时前
LangFuse 自托管实战:选型理由、Docker 部署与常用配置全解析
运维·人工智能·docker·容器
幽络源小助理15 小时前
全新UI 阅后即焚V2正式版系统源码_全开源_安全加密传输
安全·ui·开源·php源码
lularible16 小时前
从沙子到车辙(3.5):存储层次
开源·嵌入式·汽车电子
lularible16 小时前
从沙子到车辙(3.4):流水线——指令级并行的艺术
开源·嵌入式·汽车电子