【无标题】

群晖中搭建mosquitto并配合樱花穿透Sakura_Frp使用wss协议在前端以及其他地方使用

这是一个比较简短的记录,只记录的核心步骤(请一行一行的仔细阅读)

前情提要:经过测试,樱花穿透貌似不能穿透ws协议的mqtt(ws://),但是使用mqtt本身的协议是可以使用的(mqtt://),而我的使用场景涉及到前端,所以我需要ws,但是在经过测试之后,只能穿透wss协议(wss://),所以在此之前,我们需要一个域名的证书;我的使用方法比较花哨,使用的是阿里云域名,记录类型选择CNAME然后映射到樱花自己的域名,证书使用的就是我阿里云的域名证书;当然,理论上来说,只要能拉到对应域名的证书,那直接用用樱花的也可以;不过群里的小伙伴描述说直接对tcp穿透应该也能用,但是我比较惯性思维,还是先穿透ws协议再说吧。

准备工作(缺一不可,认真重视):

  1. 一份阿里云域名或者樱花域名的证书文件(.crt和.key文件),并放在NAS的一个全英文的路径下(不确定中文行不行,尽量使用英文吧)

  2. 基本linux指令操作能力(包括但不限于cd、ls、vi等)

  3. 能够在群晖中熟练使用有樱花穿透服务,以及樱花穿透服务的基本使用

  4. 一个能够冷静分析问题和能够举一反三的脑子(现在ai那么发达,让deepseek当外置大脑也可以)

基本步骤:

  1. 在群晖中新增套件来源为矿神spk,位置url为 https://spk7.imnks.com

  2. 在社群中搜索Mosquitto,可以看到一个类似于wifi图标的套件,安装它

  3. 安装完成之后手动将其关闭,进入ssh进行设置

  4. 找到Mosquitto套件的安装位置(例:/var/packages/mosquitto/var),使用cd指令进入

  5. 在此路径下有一个mosquitto.conf文件,使用vi指令进行查看和编辑(vi mosquitto.conf)

  6. 找到listener那一行,默认的应该是 listener 1883 172.0.0.1 ,指的是当前的mqtt服务只能在本机使用,此处我们将上面的那一行改为 listener 1883 0.0.0.0 ,这样指的就是,在局域网内所有设备都可以访问,当然也只是局域网

    到这一步的时候可以先将这个文件先保存一下,然后在自己局域网内的windows电脑中,安装一个MQTTX进行最基础的mqtt协议连接测试(mqtt://),不出意外的话是可以成功连接的,注意:此时是没有账号密码的,这部分可以先不用管。

  7. 在这一行的下面写一行 listener 9002 0.0.0.0 ,这一行是wss协议的端口号;然后按下回车,紧跟着一行写 protocol websockets 表示使用ws协议;再紧跟着一行写 certfile [你的路径]/[证书名称].crt ;然后在回车一行写 keyfile [你的路径]/[证书名称].key ,这两个一个是证书一个是密钥,在修改完成之后,这部分的文件应该和下面的类似

    powershell 复制代码
    listener 1883 0.0.0.0
    
    listener 9002 0.0.0.0
    protocol websockets
    certfile [你的路径]/[证书名称].crt
    keyfile  [你的路径]/[证书名称].key

    其实在当前文件的其他地方是有专门写这个STL证书的位置的,但是算了,规范化的代价就是费时间,你可以在vi编辑器中使用:/指令进行文本查找来定位进行编写

  8. 权限设置,这一步比较关键,如果你把证书文件放在了其他文件夹内,而不是放在mosquitto套件文件夹内的话,就需要设置一下权限,假如将证书文件放在了一个名为 Sync 的共享文件夹内的话,就需要将 Sync 这个共享文件夹的权限向 sc-mosquitto 开放读取权限,这一步很关键,否则套件将无法启动

  9. 樱花穿透设置对9002端口穿透,群晖如何使用樱花穿透请自行搜索使用,如果需要使用mqtt协议的话,也可顺便对1883端口开放

  10. 在前端NodeJS中使用wss协议进行验证,不知道为什么MQTTX的wss协议进行测试时始终无法连接,但是在前端的NodeJS环境中就可以连接,这部分很奇怪,但是终究还是解决问题了,所以暂时不管了

相关推荐
柱子jason15 小时前
使用IOT-Tree消息流MQTT模块节点实现监测数据推送功能
物联网·mqtt·边缘计算·iot-tree·数据推送
时空潮汐1 天前
无公网 IP 访问群晖 NAS:神卓 N600 的安全解决方案(附其他方法风险对比)
群晖·nas·公网访问nas·nas伴侣·神卓n600
时空潮汐1 天前
个人用户无公网 IP 访问群晖 NAS:神卓 N600 的安全便捷方案(附踩坑经验)
网络协议·安全·群晖·nas·威联通·绿联·极空间
余衫马12 天前
开发指南:使用 MQTTNet 库构建 .Net 物联网 MQTT 应用程序
物联网·mqtt·.net
灞波儿奔波儿灞15 天前
Lucky STUN穿透结合群晖NAS实现docker下transmission监听端口动态更新
docker·群晖·stun·lucky
LaoZhangGong12322 天前
MQTT报文的数据结构
c语言·网络·数据结构·mqtt·w5500
创思通信1 个月前
4G模块 EC200通过MQTT协议连接到阿里云
数据库·物联网·mqtt·阿里云·at·ec200a
墨鸦_Cormorant1 个月前
Spring Boot 集成 Eclipse Mosquitto
spring boot·后端·mqtt·eclipse·mq
墨鸦_Cormorant1 个月前
MQTT(轻量级消息中间件)基本使用指南
mqtt·中间件·消息中间件