【手把手教你搭建MQTT服务器 + 域名备案 + 申请与部署SSL证书】

这篇具有很好参考价值的文章主要介绍了【手把手教你搭建MQTT服务器 + 域名备案 + 申请与部署SSL证书】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。



购买云服务器实现远程登录

  • 购买云服务器

    可以按照自己情况买,新用户有优惠的,然后有些平台完成学生认证也是有优惠的

    本人选购的是轻量应用服务器2核2G4M的,装的Ubuntu 20.04LTS,Linux系统

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 重置终端密码,配置防火墙,开启SSH远程登录

    腾讯云默认用户名为Ubuntu,首次购买后需要重置密码才可通过用户密码登录终端

    腾讯云的ssh端口是自动开启的,阿里云端口配置记得是叫安全组

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 远程连接服务器,设置root密码

    ssh ubuntu@公网119.91.237.127 #ubuntu是用户名,后面接自己云服务器的公网IP  
    sudo passwd root	#设置root用户密码
    #输入密码
    #再次输入
    su	#root登录
    

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 修改ssh配置文件,开启root远程登录

    腾讯云默认root账户不能远程登录,需要修改ssh配置文件

    sudo vim /etc/ssh/sshd_config 	#配置ssh的配置文件
    /Per				#输入斜杠查找指定字符串
    将PermitRootLogin那行取消注释,并将后面改为yes
    按下ESC,输入wq保存并退出
    systemctl restart sshd	#重启ssh服务器就可以用root登录了
    

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 测试root远程登录

    ssh @root"公网IP"
    

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习




搭建emqx服务器

  • emqx开源版 下载安装

    这里根据自己云服务器配置来安装吧

    我选择的是版本是 4.2.14 系统是 Ubuntu 20.04

    点Download就跳转到下面的界面了,复制三行代码在云端运行就下载好了

    wget https://www.emqx.com/en/downloads/broker/4.2.14/emqx-ubuntu20.04-4.2.14-x86_64.deb		#下载
    ls	#查看是否把压缩包下载下来
    sudo apt install ./emqx-ubuntu20.04-4.2.14-x86_64.deb  #安装
    ls /etc/emqx #看看emqx目录下都有啥,如果没有报错就说明已经安装好了
    sudo systemctl start emqx	#启动emqx服务器
    

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习
    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习
    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 配置云服务器防火墙(阿里云的叫安全组),将emqx的端口都打开

    端口 说明
    1883 MQTT/TCP 协议端口,一般用于客户端端口
    11883 MQTT/TCP 协议内部端口,仅用于本机客户端连接
    8883 MQTT/SSL 协议端口
    8083 MQTT/WX 协议端口
    8084 MQTT/WSS 协议端口
    18083 EMQX后台管理端口

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 重启emqx服务器

    emqx restart
    
  • 登录emqx后台管理界面

    浏览器输入:云服务器公网IP:18083 #后面的18083即为端口号,emqx服务器与mqtt协议具体的端口号与对应功能请看云防火墙配置时候的端口功能说明表格
    
    默认用户:admin
    默认密码:public
    登录后可自行设置风格
    

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

    到这里emqx服务器就搭建好了!

    同时我们就可以实现硬件与服务器的数据交互了。

    可以在WebSocKet处测试连接,以及模仿订阅、发布等

    如果想修改默认的登录密码可执行以下命令

    cd /bin

    emqx_ctl admins passwd admin 新密码

    具体实现硬件与服务器的数据交互可以参考项目复盘系列之硬件篇—学会白嫖 #待发布

    有兴趣的话,可以用mqtt.fx来模拟客服端连接,来接收和发布消息

    mqtt.fx.rar 提取码:pfcu

    具体操作如下(不需测试的可直接跳过去看域名备案和服务器的证书部署啦)

模拟数据交互测试

  • 配置mqtt.fx的客户端基本信息

    如下图;而后点击Connect连接,在Dashboard客户端查看是否连接成功

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习
    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习


  • 测试发布

    MQTT协议是通过订阅发布来进行数据交互的。具体规则请自行查阅

    mqtt.fx端发布主题名为:Topic

    WebSocket订阅主题名为:Topic

    测试数据:aaa

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 测试订阅

    mqtt.fx端订阅主题名为:Topic/1

    WebSocket订阅主题名为:Topic/1

    数据:{ “msg”: “Hello, World!” }

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习



购买、解析域名

  • 购买域名可以到腾讯、阿里、华为云等搜域名注册根据指示一步步做即可

    域名注册现在需要先实名认证,大概审核需要十几分钟

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 进入域名控制台域名解析

    解析就是将本域名指向指定的IP地址,是一种映射关系

    记录值就是填写我们云服务器的公网IP

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

    解析记录添加成功后,就可以用域名来访问emqx啦!如下

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

域名备案

虽然刚刚部署完时候我们可以正常通过域名访问我们的emqx服务器,但是再过些时间就访问不了了,如出现如下画面

备案也麻烦,还要工信部审核,快的话几天,最长不超过20天 查看各个省份备案时间。

备案虽麻烦,但是也是为了大家的共同的网络使用环境着想,多一分体谅就多一分幸福。

腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 域名备案步骤大致如下
    • 到腾讯云控制台搜索备案,并申请备案,按照实际信息填写备案信息
    • 等待腾讯工作人员致电审核
    • 等待工信部发送短信核验
    • 等待工信部将审核通过同步至网络
    • 各个省份备案时间
  • 填写备案信息注意事项
    • 视频验身:视频验身要以白色为背景,其次最后拍摄不能为闭眼的状态。
    • 联系地址:要详细到门牌号,如果在学校要填到寝室号
    • 域名证书:请到购买域名的平台的控制台处找到域名证书下载按钮(具体看下方图片)以阿里云为例:点击域名列表 --> 点击管理 --> 在左侧点击域名证书下载
    • 域名实名认证截图:到购买域名的平台控制处寻找。以阿里云为例: 点击域名列表 -->点击管理 -->点击域名持有者实名认证 --> 截图(QQ截图快捷键为Ctrl + Alt + A)
    • 最后注意接电话与看短信!

备案提交后腾讯云工作人员会打电话审核真实身份。
腾讯云审核后工信部过几分钟就会发送短信核验,请根据短信提示进行核验。(湖南是这样的)

但是短信核验后好像并不会马上通过,因为在4天前有一个已经核验完了现在还没通过,具体时间请参考

所以请耐心等待

腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习



​​

申请SSL证书


为什么要申请证书?

因为有些平台通信是必须要HTTPS协议的,比如微信小程序。

  • 进入腾讯云证书控制台申请免费SSL证书

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 回到购买域名的平台添加一条解析记录,注意解析类型

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

    添加解析记录后等待十几分钟证书就会下发了。

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 下载证书

    我这里下载Nginx(为后续程序上线做准备)以及其它(部署emq需要)

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • ssl证书说明

    后缀 说明
    域名_bundle.crt CA证书文件
    域名.csr csr文件时证书签名请求文件,在创建证书时使用,因此配置SSL服务时不需要关心此文件
    域名.key 我们证书的私钥文件,以base64和格式分隔符加密
    .pem 证书的base64加密文件,即就是证书


emqx配置SSL证书


  • 远程连接云服务器

    具体配置实现在第一节,购买云服务器实现远程登录

    ssh root@云服务器公网IP
    

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 然后咱进入emqx文件下的certs目录下创建ssl目录(这一步可省略)

    cd /etc/emqx/certs		#路径不一定一样,具体看自己的emqx在哪
    mkdir ssl				#创建目录ssl
    

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 打开本地终端WIN+R 输入cmd,进入下载证书的目录

    cd 路径
    dir   #查看当前目录下的文件
    

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 使用scp命令,将证书与密匙文件传到云服务器的ssl目录下

    scp ddup.fun.key root@119.91.237.127:/etc/emqx/certs/ssl
    scp 文件名 服务器用户名@服务器公网IP:指定存储目录
    #注意不要忘掉冒号了
    

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

    上传后我们可以查看已经成功了

    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

  • 配置emqx.conf文件

    需要修改ssl的三个地方

    • listener.ssl.external.keyfile           秘钥文件 即.key文件
    • listener.ssl.external.certfile           base64加密的证书文件 即.pem文件
    • listener.ssl.external.cacertfile       CA证书文件 即.crt文件



    如果也想修改wss就再修改三个地方

    • listener.wss.external.keyfile
    • listener.wss.external.certfile
    • listener.wss.external.cacertfile

用到的vim编辑文件操作

斜杠搜索指定字符串

i 插入

wq保存退出

ESC键 退出当前的操作

cd /etc/emqx	#进入emqx目录,路径不一定一样的喔
ls				#查看当前目录下的文件
vim emqx.conf	#编辑emqx.conf
/listener.ssl.external.keyfile #搜索该字符串位置
#在后面更改为自己的对应ssl证书存储路径(可以到证书目录下输入pwd打印当前的绝对路径)
#剩下两个文件同上
#然后同样步骤再修改wss的三个文件路径
#修改完成后按下ESC,输入:wq保存并退出
emqx restart #最后重启emqx服务器即可

#注:需要用域名来访问才支持ssl与wss,因为证书是绑定到域名的,所以到备案成功后才能支持ssl和wss连接。

成功案例

腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习



斜杠搜索

腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习



修改ssl

腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习



修改wss

腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习文章来源地址https://www.toymoban.com/news/detail-798127.html


结语

  • 在学习之余也要锻炼身体呀~
  • 开心最重要了!
    腾讯云mqtt服务器搭建,mqtt,emqx,云服务器,服务器,ssl,腾讯云,交互,学习

到了这里,关于【手把手教你搭建MQTT服务器 + 域名备案 + 申请与部署SSL证书】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • hMailServer 使用教程 —— 手把手教你搭建自己的邮箱服务器

    前言 假设你已经拥有了一台具有 公网ip 的服务器,以及 域名 hMailServer 介绍 hMailServer 适用于 Windows 操作系统,它除了提供邮箱系统需要的所有基础功能之外,还内置了一些常用功能,比如:反垃圾邮件、反病毒邮件,而其他未内置的功能,则可以根据用户需要,自行去社区

    2024年02月04日
    浏览(68)
  • 在 Ubuntu 上实现网络穿透:手把手教你搭建FRPS服务器

    希望能写一些简单的教程和案例分享给需要的人 先确认是否安装 curl ,如果没安装,请执行下面命令进行安装 更新包列表: 安装 curl : 如果Ubuntu系统尚未安装Docker,按照以下步骤进行安装: 更新包列表: 安装Docker的依赖包: 通过执行命令 docker --version,可以验证安装是否

    2024年04月13日
    浏览(60)
  • 小码农UU手把手教你云服务器搭建linux环境,还用什么虚拟机啊

    直接安装在物理机上 . 但是由于 Linux 桌面使用起来非常不友好, 不推荐. 使用 虚拟机软件 , 将 Linux 搭建在虚拟机上. 但是由于当前的虚拟机软件(如 VMWare 之类的)存在一些 bug , 会导致环境上出现各种莫名其妙的问题, 比较折腾. 使用 云服务器 , 可以直接在 腾讯云, 阿里云或华为

    2024年02月06日
    浏览(48)
  • 手把手教你搭建个人地图服务器(高德离线部署解决方案):获取地图瓦片数据、高德JS API、私有化部署和调用。。。

    众所周知,目前常见的地图(高德、百度、腾讯等)只提供在线API服务,对于一些内网应用而言,如果需要使用地图展示,则由于不能访问互联网而无法使用类似的第三方地图服务。 本文,通过将高德地图瓦片数据 和 在线JS API做了本地部署,并修改API,将其所有的网络请求

    2024年02月04日
    浏览(63)
  • 手把手教你将项目部署到服务器!

    一、导入centos7虚拟机: 打开VMWare,点击“打开虚拟机”,选择centos7.ova之后,选择存储路径: 点击导入: 选择“不再显示此消息”,点击“重试”按钮: 点击“编辑虚拟机设置”,修改处理器、内存、硬盘等信息后,启动 按Ctrl+Alt键可以切换到windows下。 启动成功后,输入

    2023年04月20日
    浏览(56)
  • 【Linux】手把手教你实现udp服务器

    网络套接字~ 文章目录 前言 一、udp服务器的实现 总结 上一篇文章中我们讲到了很多的网络名词以及相关知识,下面我们就直接进入udp服务器的实现。 一、udp服务器的实现 首先我们需要创建五个文件(文件名可以自己命名也可以和我一样),分别是makefile,udpclient.cc,udpclient.hpp

    2024年02月13日
    浏览(48)
  • 手把手教你,本地RabbitMQ服务搭建(windows)

    前面已经对RabbitMQ介绍了很多内容,今天主要是和大家搭建一个可用的RabbitMQ服务端,方便后续进一步实操与细节分析 跟我们跑java项目,要装jdk类似。rabbitMQ是基于Erlang开发的,因此安装rabbitMQ服务器之前,需要先安装Erlang环境。 【PS: 我已经上传了对应资源,windows可直接下载

    2024年02月14日
    浏览(51)
  • ❤️手把手教你配置服务器板载raid❤️

    当我们买的服务器没有raid卡该怎么办? 但是我们还想给服务器系统做个冗余盘该怎么办? 接下来请去机房带上显示器键盘,开始操作吧!!! 现在以浪潮服务器NF5270M5、NF5270M6、NF5280M5、NF5280M6为例 配置板载raid1 第一步 服务器开机后在INSPUR log位置按delete键,随后进入系统

    2024年02月16日
    浏览(54)
  • 手把手教你给服务器搭建一套资源监控系统

    本文主要是介绍如何给一台服务器,搭建一个优雅的资源监控系统 如果对你有帮助,欢迎三连 收藏 点赞 关注 !!! ---- Nick.Peng 分别下载以下安装包,下载地址: https://prometheus.io/download/ grafana-enterprise-9.3.6.linux-amd64 node_exporter-1.5.0.linux-amd64 prometheus-2.42.0.linux-amd64 安装Promet

    2024年02月06日
    浏览(110)
  • 手把手教你租用服务器以及使用Pycharm远程连接服务器训练模型

    由于模型优化过后训练时间太长,所以想使用显卡或者租服务器进行训练,but显卡太贵(只有A卡),那就租服务器好了,开始了解怎么租,去哪租一系列问题,果然只要开始思考,就是一个接一个的困难,直接被击碎。终于找到了AutoDL,美美的开始租服务器,结果又绊在了选

    2024年02月10日
    浏览(62)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包