设为首页 收藏本站
查看: 702|回复: 0

[经验分享] Redis缓存数据库安全加固指导(一)

[复制链接]

尚未签到

发表于 2018-11-2 07:47:02 | 显示全部楼层 |阅读模式
背景
  在众多开源缓存技术中,Redis无疑是目前功能最为强大,应用最多的缓存技术之一,参考2018年国外数据库技术权威网站DB-Engines关于key-value数据库流行度排名,Redis暂列第一位,但是原生Redis版本在安全方面非常薄弱,很多地方不满足安全要求,如果暴露在公网上,极易受到恶意×××,导致数据泄露和丢失。
  本文主要是在原生开源软件Redis3.0基础上,系统的在安全特性方面进行的增强,很多增强点涉及了开源代码的修改,后续章节阐述的Redis缓存数据库的安全规范, 理论上适用于所有应用Redis的产品。
  本系列共连载三篇,分九个章节,本文从合法监听接口,未公开接口,访问通道控制三个章节阐述了Redis缓存数据库加固措施
1、合法监听接口
1.1 端口使用非默认端口
  安全问题:Redis Server监听的端口默认为6379,容易被扫描×××。
  解决方案:修改为非默认端口,并在端口矩阵中说明。
1.2 监听地址不允许包括*
  安全问题:Redis支持监听0.0.0.0。
  解决方案:因为如果有多网卡,应该将监听地址设置为只有数据库客户端需要连接的网卡地址。如果只允许本机访问,应该只监听127.0.0.1。
1.3 隐蔽的RedisCluster端口
  安全问题:官方RedisCluster方案缺省会增加一个集群端口,且是在客户端端口偏移10000,这个问题非常隐蔽。
  解决方案:在端口矩阵中对额外的这个集群端口有说明。修改源码,新增一个redis.conf偏移量配置项cluster-port-increment,缺省配置+1,这样可以做到端口范围可控,避免冲突。
2、未公开接口
2.1 账号管理(重要)
  安全问题:Redis只有一个超户,权限过大。
  解决方案:权限最小化原则,增加配置项,角色区分超户,普通用户和只读用户三种。
DSC0000.jpg

  普通用户不能进行的操作有:
DSC0001.jpg

2.2 Redis-cli隐藏密码
  安全问题:通过在redis-cli指定-a参数,密码会被ps出来,属于敏感信息。
  解决方案:修改Redis源码,在main进入后,立即隐藏掉密码,避免被ps出来。(可参考开源Mysql代码)
2.3 Redis-cli工具使用说明
  对于需在现网维护阶段使用的命令/参数、端口等接入方式(包括但不限于产品的生产、调测、维护用途),需通过产品资料等向客户或监管机构公开或受限公开。
2.4 禁止在脚本中通过sudo方式切换用户执行redis-cli
  安全问题: redis-cli访问参数带密码敏感信息,会被ps出来,也容易被系统记录操作日志。
  解决方案:改为通过API方式(Python可以使用redis-py)来安全访问,禁止通过sudo方式切换到dbuser账号使用redis-cli。
  重现条件:可以通过iptables禁掉redis端口来模拟重现。
3、访问通道控制
3.1 预共享秘钥认证(重要)
  安全问题:Redis原生认证存在重放×××:只是简单的交互一次auth xxx
  解决方案:采用预共享秘钥(对称加密算法+随机数的双向认证),同时在方案设计上做到最大限度兼容,让客户端改造成本最小,目前平台配套目前支持客户端有:Java,Python,C,Lua。
  方案设计如下:
  Redis认证协议变更,其中auth命令区分两种功能,通过首字母区分:
DSC0002.jpg

  预共享秘钥认证时序图
DSC0003.jpg

  说明:Redis为文本协议, 安全随机数长度固定为32字节的可显示字符串,连接2个随机数的分隔符为”@”。
  主要认证流程:
  1.客户端向服务端执行命令: authRAND_C
  1)首字母1)验证TokenBA是否合法
  解密出RAND_S@RAND_C,看看RAND_C是否是自己生成的随机数
2)客户端产生TokenAB=AES128(RAND_C@RAND_S@dbname@ossdbuser@pwd)
  3)调用认证接口: auth >TokenAB
  4.服务端认证

  1)      验证TokenAB是否合%E8%A7%A3%E5%AF%86%E5%87%BARAND_C@RAND_S%EF%BC%8C%E7%9C%8B%E7%9C%8BRAND_S%E6%98%AF%E5%90%A6%E6%98%AF%E8%87%AA%E5%B7%B1%E7%94%9F%E6%88%90%E7%9A%84%E9%9A%8F%E6%9C%BA%E6%95%B0

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-629576-1-1.html 上篇帖子: 系统学习redis之一——基础概念 下篇帖子: 运维日常:快速解决Redis问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表