专栏首页实用工具入门教程如何部署 MQTT 服务器
原创

如何部署 MQTT 服务器

MQTT是一种机器到机器的消息传递协议,旨在为“物联网”设备提供轻量级的发布/订阅通信。Mosquitto是一种流行的MQTT服务器(或MQTT中的代理),具有出色的社区支持,易于安装和配置。

在本篇教程中,我们将安装和配置Mosquitto,并使用Let的加密SSL证书来保护我们的MQTT流量。如果您还没有腾讯云的服务器,可以先点击这里进行免费套餐的试用。免费套餐包含企业版和个人版,超过11款热门产品和42款长期免费的云产品可以供您选择。如果您有长期搭建服务器的需求的话,可以点击这里进行服务器的购买,现在的促销力度很大哦。

安装软件

首先,我们将安装一个自定义软件存储库以获取最新版本的Certbot,即Let的加密客户端:

sudo add-apt-repository ppa:certbot/certbot

ENTER了接受,然后安装Mosquitto和Certbot的软件包:

sudo apt install certbot mosquitto mosquitto-clients

接下来我们将获取SSL证书。

下载SSL证书

打开防火墙中的端口80

sudo ufw allow 80

然后运行Certbot以获取证书。请务必在此处替换您服务器的域名:

sudo certbot certonly --standalone --preferred-challenges http -d mqtt.example.com

系统将提示您输入电子邮件地址并同意服务条款。执行此操作后,您应该会看到一条消息,告诉您进程是否成功以及您的证书存储在何处。

我们接下来将Mosquitto配置为使用这些证书。

配置Mosquitto

首先,我们将创建一个Mosquitto将用于验证连接的密码文件。使用mosquitto_passwd来创建这个文件,请确保使用你喜欢的用户名替换它:

sudo mosquitto_passwd -c /etc/mosquitto/passwd your-username

系统将提示您输入两次密码。

现在为Mosquitto打开一个新的配置文件:

sudo nano /etc/mosquitto/conf.d/default.conf

这将打开一个空文件。粘贴如下:

allow_anonymous false
password_file /etc/mosquitto/passwd
​
listener 1883 localhost
​
listener 8883
certfile /etc/letsencrypt/live/mqtt.example.com/cert.pem
cafile /etc/letsencrypt/live/mqtt.example.com/chain.pem
keyfile /etc/letsencrypt/live/mqtt.example.com/privkey.pem
​
listener 8083
protocol websockets
certfile /etc/letsencrypt/live/mqtt.example.com/cert.pem
cafile /etc/letsencrypt/live/mqtt.example.com/chain.pem
keyfile /etc/letsencrypt/live/mqtt.example.com/privkey.pem

请务必替换您在步骤2中使用的域名为mqtt.example.com。完成后保存并关闭文件。

该文件执行以下操作:

  • 禁用匿名登录
  • 使用我们的密码文件启用密码验证
  • 仅在端口1883上为localhost设置不安全的侦听器
  • 在端口8883上设置安全侦听器
  • 在端口8083上设置基于websocket的安全侦听器

重启Mosquitto以获取配置更改:

sudo systemctl restart mosquitto

检查以确保服务再次运行:

sudo systemctl status mosquitto
● mosquitto.service - LSB: mosquitto MQTT v3.1 message broker
   Loaded: loaded (/etc/init.d/mosquitto; generated)
   Active: active (running) since Mon 2018-07-16 15:03:42 UTC; 2min 39s ago
     Docs: man:systemd-sysv-generator(8)
  Process: 6683 ExecStop=/etc/init.d/mosquitto stop (code=exited, status=0/SUCCESS)
  Process: 6699 ExecStart=/etc/init.d/mosquitto start (code=exited, status=0/SUCCESS)
    Tasks: 1 (limit: 1152)
   CGroup: /system.slice/mosquitto.service
           └─6705 /usr/sbin/mosquitto -c /etc/mosquitto/mosquitto.conf

状态应该是active (running)。如果不是,请检查配置文件并重新启动。Mosquitto的日志文件中可能会提供更多信息:

sudo tail /var/log/mosquitto/mosquitto.log

如果一切顺利,请使用ufw允许两个新端口通过防火墙:

sudo ufw allow 8883
sudo ufw allow 8083

现在已经建立了Mosquitto,我们将在续订证书后配置Certbot以重启Mosquitto。

配置Certbot续订

Certbot会在它们到期之前自动续订我们的SSL证书,但需要告知它在重新启动之后重启Mosquitto服务。

打开域名的Certbot续订配置文件:

sudo nano /etc/letsencrypt/renewal/mqtt.example.com.conf

在最后一行添加以下renew_hook选项:

renew_hook = systemctl restart mosquitto

保存并关闭该文件,然后运行Certbot dry run以确保语法正常:

sudo certbot renew --dry-run

如果您没有看到任何错误,那么您已经完成了设置。让我们接下来测试我们的MQTT服务器。

测试Mosquitto

我们在步骤1中安装了一些命令行MQTT客户端。我们可以在localhost监听器上订阅主题测试,如下所示:

mosquitto_sub -h localhost -t test -u "your-user" -P "your-password"

我们可以用mosquitto_pub发布:

mosquitto_pub -h localhost -t test -m "hello world" -u "your-user" -P "your-password"

要使用端口8883上的安全侦听器进行订阅,请执行以下操作:

mosquitto_sub -h mqtt.example.com -t test -p 8883 --capath /etc/ssl/certs/ -u "your-username" -P "your-password"

这就是您向安全监听器发布的方式:

mosquitto_pub -h mqtt.example.com -t test -m "hello world" -p 8883 --capath /etc/ssl/certs/ -u "your-username" -P "your-password"

请注意,我们使用的是完整的主机名而不是localhost。因为我们为mqtt.example.com发布了SSL证书,如果我们尝试安全连接到localhost,我们会收到一条错误消息,指出主机名与证书主机名不匹配。

要测试websocket功能,我们将使用基于浏览器的公共MQTT客户端。在浏览器中打开Eclipse Paho javascript客户端实用程序并填写连接信息,如下所示:

  • 主机是您的Mosquitto服务器的域,mqtt.example.com
  • 端口8083
  • ClientId可以保留为默认的随机值
  • 路径可以保留为/ ws的默认值
  • 用户名是步骤3中的Mosquitto用户名
  • 密码是您在步骤3中选择的密码

其余字段可以保留其默认值。

Connect后,客户端将连接到您的服务器。您可以使用连接窗格下的订阅发布消息窗格进行发布和订阅。

结论

我们现在已经设置并测试了一个安全的,受密码保护和SSL加密的MQTT服务器。这可以作为物联网,家庭自动化或其他项目的强大而安全的消息传递平台。腾讯云 SSL证书(SSL Certificates)提供了安全套接层(SSL)证书的一站式服务,包括证书申请、管理及部署功能,与顶级的数字证书授权(CA)机构和代理商合作,为您的网站、移动应用提供 HTTPS 解决方案。

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 算法:大O符号解释

    O(n),O(1),O(log n)等大O符号被用来表示算法的效率。在这篇文章中,你会找到每个大O符号的例子和解释。

    大数据弄潮儿
  • 如何部署 TensorFlow 服务器

    TensorFlow是一款由Google构建的用于训练神经网络的开源机器学习软件。TensorFlow的神经网络以有状态数据流图的形式表示。图中的每个节点表示神...

    大数据弄潮儿
  • 使用Go构建一个Data Thrashing CLI工具

    以下所撰就是这个快速上手的项目。最后,我将在容器中搭建服务,并将其放入Kubernetes(k8s)集群中,不过下面操作都是在CLI环境下进行的。

    大数据弄潮儿
  • [快速入门]如何在Ubuntu 18.04上安装和保护Mosquitto MQTT消息传递代理

    MQTT是一种机器到机器的消息传递协议,旨在为“物联网”设备提供轻量级的发布/订阅通信。Mosquitto是一种流行的MQTT服务器(或MQTT中的代理),具有...

    信姜缘
  • 一文看懂用Python读取Excel数据

    导读:现有的Excel分为两种格式:xls(Excel 97-2003)和xlsx(Excel 2007及以上)。

    华章科技
  • Java基础12 类型转换与多态

    我们之前使用类创造新的类型(type),并使用继承来便利我们创建类的过程。我将在这一讲中深入类型,并介绍多态(polymorphism)的概念。

    Java团长
  • 拜托,别再问我什么是B+树 了

    每当我们执行某个 SQL 发现很慢时,都会下意识地反应是否加了索引,那么大家是否有想过加了索引为啥会使数据查找更快呢,索引的底层一般又是用什么结构存储的呢,相信...

    kunge
  • Array - 295. Find Median from Data Stream

    Median is the middle value in an ordered integer list. If the size of the list i...

    用户5705150
  • Mysql | innodb

    二叉查找树存在不平衡问题,因此学者提出通过树节点的自动旋转和调整,让二叉树始终保持基本平衡的状态,就能保持二叉查找树的最佳查找性能了。基于这种思路的自调整平衡状...

    heidsoft
  • 京东提前批研发面经

    【每日一语】真实人生中,我们往往在大势底定无可更改时才迟迟进场,却又在胜败未分的浑沌中提早离席。——翁贝托·埃科《开头与结尾》

    牛客网

扫码关注云+社区

领取腾讯云代金券