emq-redis认证小坑总结

2023-10-23 23:32
文章标签 总结 认证 redis 小坑 emq

本文主要是介绍emq-redis认证小坑总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

了解了 Mysql 插件认证及访问控制后,现在我们再来了解下 Redis 插件认证以及访问控制,默认关闭了匿名认证及鉴权行为


一、创建用户表和控制表

根据官方文档

  • 创建用户表的命令为:hset mqtt_user: password

    hset mqtt_user: password

    127.0.0.1:6379> hset mqtt_user:admin password 123456
    
    • 1
  • 创建控制表的命令为:hset mqtt_acl:

    hset mqtt_acl:

    hset mqtt_acl:admin MQTT 1
    
    • 1

二、配置redis认证

在 etc/plugins 目录下修改 emq_auth_redis.conf 配置文件

  • cd /usr/local/emqtt/emqttd/etc/plugins

  • vim emq_auth_redis.conf

  • 添加 redis 连接配置,保存并退出

    ## Redis server address.
    ##
    ## Value: Port | IP:Port
    ##
    ## Examples: 6379, 127.0.0.1:6379, localhost:6379
    auth.redis.server = 127.0.0.1:6379
    

Redis pool size.

Value: Number

auth.redis.pool = 8

Redis database no.

Value: Number

auth.redis.database = 0

Redis password.

Value: String

auth.redis.password = 123456

  • 开启 redis 认证插件

    • 第一种方式:emqttd_ctl plugins load emq_auth_redis

    • 第二种方式:在 web 管理控制台中开启该插件

  • 重启服务,使插件生效


  • 三、测试

    emqtt 的 redis 插件默认明文不加密,其他加密方式如下图
    在这里插入图片描述

    • 此时我在 redis 中配置了

      • username:admin

      • password:123456

      • topic:MQTT

      • access:1 (行为类型: 1=订阅2=发布3=订阅+发布)

    • 在项目中配置了

      • username:admin

      • password:123456

      • clientid: mqtt-client

      • topic: MQTT

    • 此时我们再启动项目时,只有正确地配置了用户名、密码、topic 和 access 之后,才可以连接成功,否则会报异常
      在这里插入图片描述


    四、启动超级用户

    emqtt 的 redis 插件可以配置超级用户,超级用户可以跳过所有的访问控制,直接连接到 emqtt 服务

    根据官方文档

    • 创建超级用户的命令为:hset mqtt_user: is_superuser <is_superuser>

      hset mqtt_user:admin is_superuser 1
      
      • 1
    • 此时我在 redis 中配置了

      • username:admin

      • password:123456

      • topic:MQTT

      • access:1 (行为类型: 1=订阅2=发布3=订阅+发布)

      • is_superuser:1 (是否为超级用户: 0=否1=是)

    • 在项目中配置了

      • username:admin

      • password:123456

      • clientid: mqtt-client

      • topic: MQTT

    • 此时我们再启动项目时,只要正确地配置了用户名和密码之后,就可以连接成功

      例如:访问控制设置只能订阅 (access = 1),而本地服务器调用了发布 (access = 2) 的方法,因此理论上是发布不了的,而 admin 用户已经被设为了超级用户,所以就可以发布消息

    java后台设置redis方式:

    如果是这种方式设置,redis中存储的结构是这样:

    在这里插入图片描述
    filed中的value多了双引号,当设备连接时会匹配错误导致认证失败。
    正确的方式应该这样:
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述
    现在redis中存的结构如下:
    在这里插入图片描述
    再连接:
    在这里插入图片描述
    提示成功:
    在这里插入图片描述

这篇关于emq-redis认证小坑总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/271188

相关文章

Java反转字符串的五种方法总结

《Java反转字符串的五种方法总结》:本文主要介绍五种在Java中反转字符串的方法,包括使用StringBuilder的reverse()方法、字符数组、自定义StringBuilder方法、直接... 目录前言方法一:使用StringBuilder的reverse()方法方法二:使用字符数组方法三:使用自

一文详解kafka开启kerberos认证的完整步骤

《一文详解kafka开启kerberos认证的完整步骤》这篇文章主要为大家详细介绍了kafka开启kerberos认证的完整步骤,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、kerberos安装部署二、准备机器三、Kerberos Server 安装1、配置krb5.con

Redis客户端工具之RedisInsight的下载方式

《Redis客户端工具之RedisInsight的下载方式》RedisInsight是Redis官方提供的图形化客户端工具,下载步骤包括访问Redis官网、选择RedisInsight、下载链接、注册... 目录Redis客户端工具RedisInsight的下载一、点击进入Redis官网二、点击RedisI

Redis实现RBAC权限管理

《Redis实现RBAC权限管理》本文主要介绍了Redis实现RBAC权限管理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1. 什么是 RBAC?2. 为什么使用 Redis 实现 RBAC?3. 设计 RBAC 数据结构

Python依赖库的几种离线安装方法总结

《Python依赖库的几种离线安装方法总结》:本文主要介绍如何在Python中使用pip工具进行依赖库的安装和管理,包括如何导出和导入依赖包列表、如何下载和安装单个或多个库包及其依赖,以及如何指定... 目录前言一、如何copy一个python环境二、如何下载一个包及其依赖并安装三、如何导出requirem

Redis 内存淘汰策略深度解析(最新推荐)

《Redis内存淘汰策略深度解析(最新推荐)》本文详细探讨了Redis的内存淘汰策略、实现原理、适用场景及最佳实践,介绍了八种内存淘汰策略,包括noeviction、LRU、LFU、TTL、Rand... 目录一、 内存淘汰策略概述二、内存淘汰策略详解2.1 ​noeviction(不淘汰)​2.2 ​LR

Rust格式化输出方式总结

《Rust格式化输出方式总结》Rust提供了强大的格式化输出功能,通过std::fmt模块和相关的宏来实现,主要的输出宏包括println!和format!,它们支持多种格式化占位符,如{}、{:?}... 目录Rust格式化输出方式基本的格式化输出格式化占位符Format 特性总结Rust格式化输出方式

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

Redis的数据过期策略和数据淘汰策略

《Redis的数据过期策略和数据淘汰策略》本文主要介绍了Redis的数据过期策略和数据淘汰策略,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录一、数据过期策略1、惰性删除2、定期删除二、数据淘汰策略1、数据淘汰策略概念2、8种数据淘汰策略

java如何通过Kerberos认证方式连接hive

《java如何通过Kerberos认证方式连接hive》该文主要介绍了如何在数据源管理功能中适配不同数据源(如MySQL、PostgreSQL和Hive),特别是如何在SpringBoot3框架下通过... 目录Java实现Kerberos认证主要方法依赖示例续期连接hive遇到的问题分析解决方式扩展思考总