40.Redis安装及利用Redis未授权访问漏洞的攻击与预防
redis是一个开源的,给予内存也可以持久化的日志型,key-value数据库。redis在默认情况下,会绑定0.0.0.0:6379,如果没有开启认证服务,会导致任意用户可以访问目标服务器,可以成功的在redis服务器上写入公钥,从而使用相应的私钥直接登录目标服务器。
一、redis安装过程
在官网上下载redis的安装包,下载完成后解压,进入redis的安装目录
1.make
data:image/s3,"s3://crabby-images/0c0f6/0c0f64878b9536999fe8d08b5973bfc033e4b564" alt=""
报错一:gcc未找到
data:image/s3,"s3://crabby-images/ff3ba/ff3baf74ee93641f678a9a5736d4ee2d4f9618dd" alt=""
解决方法:安装gcc
data:image/s3,"s3://crabby-images/35546/355467f8f2007fdc168efad16772c2f29fa813c1" alt=""
2.再次 make
报错二:zmalloc.h:50:31: 错误:jemalloc/jemalloc.h:没有那个文件或目录
data:image/s3,"s3://crabby-images/95f79/95f793d10ed18448c3508e54d32ce251ae595567" alt=""
解决方法:添加malloc=libc的参数
data:image/s3,"s3://crabby-images/88c28/88c28e496e90b03858dda4551d3ab864d158f104" alt=""
3.make成功后,进入src目录
make install 成功
data:image/s3,"s3://crabby-images/f79d8/f79d8532d42dd62e1af0fac6468b1968bab30f35" alt=""
4.make test
报错三:You need tcl 8.5 or newer in order to run the Redis test
解决方法:下载tcl源码包并安装
wget http://downloads.sourceforge.net/tcl/tcl8.6.1-src.tar.gz
sudo tar xzvf tcl8.6.1-src.tar.gz -C /usr/local/
cd /usr/local/tcl8.6.1/unix/
sudo ./configure
sudo make
sudo make install
5.为了方便管理,建立一个目录,将redis的配置文件和常用命令放进去
data:image/s3,"s3://crabby-images/8b939/8b939a93c8e25546045c72b43ab6ab9efcfa0ee8" alt=""
ps:redis安装步骤
二、模仿攻击
1.两台centos机器都已安装redis。
目标机器:192.168.252.130
攻击机器:192.168.252.128
1.1.查看目标机器上redis服务是否开启,若没有,则使用redis-server命令开启
data:image/s3,"s3://crabby-images/11673/116735337dcab5e89958027678802643a8d47bdc" alt=""
data:image/s3,"s3://crabby-images/a7c30/a7c3028b5d4c6582b336b511a4f0e40b265f4db0" alt=""
开启后发现redis服务默认前台执行,再开一个终端,查看端口情况,显示redis服务确已开启
data:image/s3,"s3://crabby-images/04261/042614474331d208c186162a6c862243c1492760" alt=""
1.2.将redis服务放在后台执行,有三种办法
a.可以通过在命令后加一个&
b.命令执行和ctrl+z
data:image/s3,"s3://crabby-images/95099/95099623c07dd3851e596455635a3a7703c56ec6" alt=""
data:image/s3,"s3://crabby-images/9e2e9/9e2e97e8a2027d5519faefba35ab28613f7b2e35" alt=""
1.3.修改配置文件
vim /usr/local/redis/redis.conf //将daemonize no改为yes
data:image/s3,"s3://crabby-images/82c45/82c45fee3b32e45e095204e1f7cd684c0a28a9fc" alt=""
data:image/s3,"s3://crabby-images/ed00a/ed00a8dd21d4b7e0074868d99a5e5501fc6c57a1" alt=""
再此开启redis服务,就直接在后台执行了。
data:image/s3,"s3://crabby-images/22331/22331395cf84c93a5697c05eabcdce7f640b4d4c" alt=""
2.在攻击机器上配置
2.1使用ssh-keygen -t rsa会在/root/.ssh/目录下创建本地的ssh公私钥文件,id_rsa为私钥,id_rsa.pub为公钥文件
因为我这台虚拟机已经装过了,所以这边不覆盖(没有装过的,一直回车默认安装)
data:image/s3,"s3://crabby-images/7bcf3/7bcf3e3bdae295be0c3be4fb7d9c008304aa0319" alt=""
2.2进入/root/.ssh目录,将公钥写入foo.txt
data:image/s3,"s3://crabby-images/4ff8e/4ff8ec03daf6ee6414f5e0172c8da88b74241d7f" alt=""
2.3做好文件之后,尝试连接redis服务器,将foo.txt文件写入服务器中(将自己的公钥放在服务器)
data:image/s3,"s3://crabby-images/fec1e/fec1e4dc567860ecc4f81aa49a7d6d0580b8b17e" alt=""
报错一:连接不上
解决方法:在redis服务器上,修改配置文件/usr/local/redis/redis.conf,将bind 127.0.0.1注释
data:image/s3,"s3://crabby-images/19132/19132483927e5fdd7816a75cabc702d8ed8f6e16" alt=""
data:image/s3,"s3://crabby-images/ce173/ce1733914f87967ca735cf6de06564e6ca4ce217" alt=""
再次尝试连接redis服务器。
报错二:保护模式
data:image/s3,"s3://crabby-images/79671/796713df2684222bc4d75096d07f1489bfda2b89" alt=""
解决方法:在redis服务器上,修改配置文件/usr/local/redis/redis.conf,将protected-mode yes改为no.
data:image/s3,"s3://crabby-images/7a4ee/7a4ee5f3861b7b7728da6e11e518c525b587f5c5" alt=""
再次尝试,成功。
data:image/s3,"s3://crabby-images/2e991/2e991faa9c82f0326e3e27ee48598a5588762017" alt=""
2.4连接redis服务器,并进入其/root/.ssh目录,将传入的foo.txt文件重新定义为authorized_keys。
data:image/s3,"s3://crabby-images/d7360/d73607111007dab1a589077515c2cf3f7cf7c3f7" alt=""
2.5在redis服务器端,查看刚刚收到的authorized_keys(即客户机的公钥)
data:image/s3,"s3://crabby-images/ffb64/ffb645482b6dc3215936388a4abd46c070cbd61f" alt=""
data:image/s3,"s3://crabby-images/2900b/2900bd8441fa607d2886ad6ae06f2dbca79c3adb" alt=""
2.6以上步骤将自己的公钥写入到了该服务器上,就可以利用自己的私钥登录到该服务器上.
在192.168.252.128上使用ssh -i id_rsa root@192.168.252.130 命令来连接服务器
如上,已将成功连接到redis服务器上,并且具有root权限。
data:image/s3,"s3://crabby-images/fe76a/fe76a24af8be70948c234f87ebc727ca15fc5097" alt=""
三、预防攻击
1.预防方案1:修改配置文件,为其设置密码。
data:image/s3,"s3://crabby-images/722f8/722f8857c77d84501cdb4d8f8ce1e62e31f53ca0" alt=""
客户机在连接redis服务器时需要输入刚刚设置的密码,否则不予理财。
data:image/s3,"s3://crabby-images/5e0b4/5e0b45a7e4d26fab99a3542ee5f78012117328c9" alt=""
2.预防方案二:修改配置文件,取消bind 127.0.0.1的注释
data:image/s3,"s3://crabby-images/35e56/35e56fb0f2d903518aab5d5ca09e89286ec3a5f4" alt=""
客户机在连接redis服务器的时候会直接被拒绝。
data:image/s3,"s3://crabby-images/ced78/ced788c0b1c18590b91837f93149df379ae683cd" alt=""
根据实验吧实验编写:redis未授权访问漏洞利用与修复