当前位置: 首页 > news >正文

Redis 哨兵模式下DB库操作审计

Redis Sentinel集群环境

主机版本模式NodeSentinel
redis-sentinel-node-06.2.12哨兵MasterYes
redis-sentinel-node-16.2.12哨兵SlaveYes
redis-sentinel-node-26.2.12哨兵SlaveYes

在这里插入图片描述

架构设计

在这里插入图片描述

命令行&程序验证

1、在redis-sentinel-node-1上使用redis-cli 连接redis-sentinel-node-0上的redis实例进行增删改查
在这里插入图片描述
2、在redis-sentinel-node-0节点上开启monitor 命令监控
在这里插入图片描述
3、由1、2 步截图可以看出在实例上使用monitor命令可以实时监控连接的client端执行命令参数详情
命令执行时间戳 [ db client_ip:port ] command argvs_list
4、使用python 客户端程序连接验证

from redis import Redis,ConnectionPool
config={"host": "192.168.123.241","pwd": "xxxxxx","port": 63675,
}
# 创建一个连接池
pool_list = [ConnectionPool(host=config["host"], password=config["pwd"], port=config["pwd"], db=0), ConnectionPool(host=config["host"], password=config["pwd"], port=config["pwd"], db=1)] 
for pool in pool_list:# 使用连接池来创建一个Redis客户端r = Redis(connection_pool=pool)# 现在你可以使用r对象来执行Redis命令了r.set('foo', 'bar')value = r.get('foo')print(value)r.delete('foo')r.close()

在这里插入图片描述
由上面service 可以看到 redis-sentinel-node-0 映射到 192.168.123.241node上的63675端口
执行测试client脚本
在这里插入图片描述
redis-sentinel-node-0实例上监控输出,可以看到监控到了整个脚本请求redis命令全过程
在这里插入图片描述

测试结论

经过以上命令行和python client模拟redis哨兵的使用测试结果来看,可以使用redis 自带的 monitor 监控命令来观测client 端执行redis 命令的详细情况,通过monitor 命令输出结果中的: 时间点 db号 client_ip 命令+参数 这些信息来辅助排查业务上的redis client模块执行操作。
注意:

1、MONITOR是一个调试命令,它回传 Redis 服务器处理的每个命令。它有助于了解数据库正在发生的情况。
2、当使用 Redis 作为数据库和分布式缓存系统时,查看服务器处理的所有请求的能力对于发现应用程序中的错误很有用
3、使用SIGINT(Ctrl-C)停止MONITOR通过 运行的流redis-cli。
4、手动发出QUIT或RESET命令来停止MONITOR通过运行的流telnet。
5、出于安全考虑,MONITOR的输出不会记录任何管理命令,并且命令中的敏感数据会被删除AUTH。 此外,该命令QUIT也未被记录。
6、MONITOR流会支持所有命令,因此使用流是有代价的,运行单个MONITOR客户端可能会使吞吐量降低 30% ~ 50%以上,同时运行更多MONITOR客户端会使吞吐量进一步降低。
7、不建议在生产环境实例上直接使用,尤其业务高峰期。

开源Redis proxy

Predixy gihub地址:https://github.com/joyieldInc/predixy 1500 star
Camellia gihub地址:https://github.com/netease-im/camellia/blob/master/docs/camellia-redis-proxy/redis-proxy-zh.md 605 star
Redis Enterprise 6.2.18 官方自带审计日志, 社区版暂不支持
在这里插入图片描述

结论

Predixy 经测试没有命令操作审计记录功能
网易开源 camellia 未发现所有操作命令审计记录功能
目前Redis 各个代理组件尚未有完善的审计日志功能

http://www.lryc.cn/news/461782.html

相关文章:

  • latex公式输入-矩阵
  • NSSCTF-WEB-easy_eval
  • 交通目标识别数据集YOLO 模型 ui界面✓图片数量15000,xml和txt标签都有 11类 交通道路车辆行人红黄绿数据集 红绿灯数据集 交通信号数据集
  • 买卖股票的最佳时机 题解
  • 微信小程序路由跳转的区别及其常见的使用场景
  • 麒麟桌面版v10 SP1以docker方式安装达梦数据库
  • KNN的 k 设置的过大会有什么问题
  • Star Tower:智能合约的安全基石与未来引领者
  • 2024-NewStarCTF-WEEK1
  • 大数据面试题整理——Zookeeper
  • 图书库存管理:Spring Boot驱动的进销存系统
  • 用增结算数仓化改造:在/离线调度系统的构建与应用
  • 施磊C++高级进阶课程 | 学习笔记 | 博客汇总
  • 学习threejs,拉伸几何体THREE.TubeGeometry管道
  • day01-Qt5入门
  • AnaTraf | 利用多点关联数据分析和网络关键KPI监控提升IT运维效率
  • 图书库存控制:Spring Boot进销存系统的应用
  • Python 工具库每日推荐 【pyspider 】
  • 【C语言教程】【常用类库】(十五)网络编程 - <sys/socket.h> 和 <netinet/in.h>
  • 正点原子讲解SPI学习,驱动编程NOR FLASH实战
  • 低代码开发助力中小企业数字化转型难度持续降低
  • 【Linux】:线程控制
  • 大数据-174 Elasticsearch Query DSL - 全文检索 full-text query 匹配、短语、多字段 详细操作
  • Spring Boot视频网站:构建可扩展的视频服务平台
  • 护眼台灯横评:书客、柏曼、明基哪款使用体验好,又能护眼?
  • RDMA笔记
  • Collection 单列集合 List Set
  • LabVIEW提高开发效率技巧----跨平台开发
  • 创建uniCloud新项目并且是新服务空间,运行会报Error: Invalid uni-id config file错误
  • 七、IPD 方法论框架(IPD的组织架构)