【fly-iot飞凡物联】(12):EMQX 5.1使用docker 本地部署,接入到Actorcloud的数据库中,成功连接创建的设备,可以控制设备访问状态

目录

  • 前言
    • 1,关于
    • [2,使用docker 进行部署](#2,使用docker 进行部署)
    • [3,配置API key 可以使用接口访问的](#3,配置API key 可以使用接口访问的)
    • [4,设置客户端认证,连接PostgreSQL 数据连接](#4,设置客户端认证,连接PostgreSQL 数据连接)
    • 5,使用客户端进行连接
    • [6,EMQX的API 接口地址](#6,EMQX的API 接口地址)
    • 7,总结

前言


本文的原文连接是:
https://blog.csdn.net/freewebsys/article/details/108971807

fly-iot飞凡物联专栏:
https://blog.csdn.net/freewebsys/category_12219758.html

未经博主允许不得转载。

博主CSDN地址是:https://blog.csdn.net/freewebsys

博主掘金地址是:https://juejin.cn/user/585379920479288

博主知乎地址是:https://www.zhihu.com/people/freewebsystem

1,关于


EMQX 是一款开源 (opens new window)的大规模分布式 MQTT 消息服务器,功能丰富,专为物联网和实时通信应用而设计。EMQX 5.0 单集群支持 MQTT 并发连接数高达 1 亿条,单服务器的传输与处理吞吐量可达每秒百万级 MQTT 消息,并保证延迟在亚毫秒级。

EMQX 支持多种协议,包括 MQTT (3.1、3.1.1 和 5.0)、HTTP、QUIC 和 WebSocket 等,保证各种网络环境和硬件设备的可访问性。EMQX 还提供了全面的 SSL/TLS 功能支持,比如双向认证以及多种身份验证机制,为物联网设备和应用程序提供可靠和高效的通信基础设施。

https://www.emqx.io/docs/zh/v5.1/

https://www.emqx.io/docs/zh/v5.1/deploy/install-docker.html

2,使用docker 进行部署


配置帐号:admin

密码:public

使用最新版本即可

bash 复制代码
docker run -d --name emqx -p 1883:1883 -p 8083:8083 -p 8084:8084 -p 8883:8883 -p 18083:18083 emqx/emqx:latest
端口 说明
18083 web管理端admin端口
1883 tcp端口常用
8883 ssl的tcp端口
8083 websocket端口常用
8084 ssl的websocket端口


可以忽略下,然后就进入了管理端。

3,配置API key 可以使用接口访问的


这个时候可以再创建一个 访问API key:

http://127.0.0.1:18083/#/APIKey

然后把这个配置放到 arctorcloud 上:

然后创建一个设备:

密码是:11111111

4,设置客户端认证,连接PostgreSQL 数据连接


设置客户端认证:

这个最重要!!

要有 as password 和双引号才可以,是PostgerSQL 特殊的写法:

bash 复制代码
SELECT "token" as password FROM devices where 
"deviceUsername"  = ${username} LIMIT 1 

配置成功:

还可以进行 客户端认证

也可以配置 客户端授 权或者关闭授权:

bash 复制代码
SELECT 'allow' as action, 'all' as permission, 'all' as topic 
 FROM devices where "deviceUsername" = ${username} 

5,使用客户端进行连接


web页面中自带一个客户端,直接连接就可以。

这个设备就是在 Actorcloud 中创建的设备

6,EMQX的API 接口地址


EMQX 还有本地 swagger 接口地址:

http://localhost:18083/api-docs/index.html#

在管理端中设置了API 的 username 和 password 就可以登陆了。

然后就可以直接访问了:

接口非常的丰富,授权之后就可以直接访问了,可以方便和其他系统进行对接。

进行二次开发了。

7,总结


终于弄明白了,EMQX的使用,同时也支持 MQTT5 了,可以正常连接到数据库中创建的设备了。

同时支持很多的扩展接口。可以非常的方便进行管理端的开发和连调了。

但是回调接口目前不知道通过什么job 方式去获得在线状态。

同时在 actorcloud 上还有允许访问状态,可以修改成:

sql 复制代码
-- 客户端认证
SELECT "token" as password FROM devices where 
"deviceUsername"  = ${username} AND "blocked" = 0
 LIMIT 1 
 
-- 客户端授权
SELECT 'allow' as action, 'all' as permission, 'all' as topic 
 FROM devices where "deviceUsername" = ${username} AND "blocked" = 0 
 

都是非常不错的开源项目,持续研究中,把两个项目融合起来跑,

actorcloud项目和Emqx 项目一起部署起来。

本文的原文连接是:
https://blog.csdn.net/freewebsys/article/details/108971807

相关推荐
韩zj1 分钟前
服务器定时备份数据库脚本
服务器·数据库·adb
笨蛋少年派12 分钟前
Maxwell数据变更捕获工具简介
数据库·mysql
专业开发者14 分钟前
Quuppa 如何引领蓝牙 ® 定位服务的全新发展方向
物联网
谷新龙00119 分钟前
pg_clickhouse插件,在postgresql中借助clickhouse借用OLAP能力
数据库·clickhouse·postgresql
Hello.Reader21 分钟前
Flink SQL 的 SET 语句会话参数配置与快速自检(SQL CLI 实战)
数据库·sql·flink
老华带你飞28 分钟前
工会管理|基于springboot 工会管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·spring
自在极意功。28 分钟前
MyBatis配置文件详解:environments、transactionManager与dataSource全面解析
java·数据库·tomcat·mybatis
紫金桥软件29 分钟前
紫金桥软件 | 赋能工业数字化转型
数据库·国产化
Navicat中国32 分钟前
Navicat x 达梦技术指引 | 模型转换
数据库·达梦·navicat·概念模型·物理模型·逻辑模型·模型转换
邂逅星河浪漫33 分钟前
【MySQL 事务】详细介绍+实例
数据库·mysql·事务