官网地址(英文):Redis
官网地址(中文):CRUG网站 or redis中文文档
Redis源码地址:GitHub - redis/redis: Redis is an in-memory database that persists on disk. The data model is key-value, but many different kind of values are supported: Strings, Lists, Sets, Sorted Sets, Hashes, Streams, HyperLogLogs, Bitmaps.
Redis在线测试:Try Redis
Redis命令参考:Redis 命令参考 — Redis 命令参考
1、环境需要
判断我们的centos 7是多少位的,使用64位切记,命令查看:
getconf LONG_BIT 返回是多少就是几位
必须先具备gcc编译环境
gcc -v 查看版本
yum -y install gcc-c++ 安装c++库环境
2、下载
放入我们的Linux目录/opt
下载命令:wget https://download.redis.io/releases/redis-7.0.0.tar.gz
或者官网下载压缩包解压
3、解压
/opt目录下解压redis
tar -zxvf redis-7.0.0.tar.gz
4、make Redis
5、查看默认安装目录:usr/local/bin
redis-benchmark:性能测试工具,服务启动后运行该命令,看看自己本子性能如何
redis-check-aof:修复有问题的AOF文件,rdb和aof后面进
redis-check-dump:修复有问题的dump.rdb文件
redis-cli:客户端,操作入口
redis-sentinel:redis集群使用
redis-server:Redis服务器启动命令
6、将默认的redis.conf拷贝到自己定义好的一个路径下,比如/myredis
7、修改/myredis目录下redis.conf配置文件做初始化设置
redis.conf配置文件,改完后确保生效,记得重启,记得重启
1 默认daemonize no 改为 daemonize yes (是否采用守护进程方式)
2 默认protected-mode yes 改为 protected-mode no (是否开启保护模式)
3 默认bind 127.0.0.1 改为 直接注释掉(默认bind 127.0.0.1只能本机访问)或改成本机IP地址,否则影响远程IP连接
4 添加redis密码 改为 requirepass 你自己设置的密码
8、启动服务
usr/local/bin目录下运行redis-server,启用/myredis目录下的redis..conf文件
redis-server /myredis/redis7.conf
9、连接服务
redis-cli -a 设置的密码 -p 6379
10、关闭服务
单实例关闭:redis-cli -a 111111 shutdown
多实例关闭,指定端口关闭:redis-cli -p 6379 shutdown
11、 卸载步骤
a、停止redis-server服务
b、删除/usr/local/Iib目录下与redis相关的文件
ls -l /usr/local/bin/redis-*
rm -rf /usr/local/bin/redis-*
Tip登录redis有一个warning警告:
如果你不配置Requirepass就不用密码这一步麻烦
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
我看着不爽,怎么办?
warning 这串输出并不是普通输出,
shell的标准输出包含两种:
1(标准输出)
2(标准错误)我们的命令,即包含1也包含2,2即是我们想要去除的提示。
解决办法将标准错误去除即可,追加2>/dev/null,将标准错误丢弃即可,就没有烦人的警告了。
若使用RedisDesktopManager无法连接Redis服务器
问题1:redis的配置文件问题
使用vim编辑器修改bin目录中的redis.conf文件,修改如下三项
第一项:# bind 127.0.0.1 ::1
第二项:protected-mode no
第三项:daemonize yes
问题2:防火墙没有打开6379的端口
查看VM虚拟机的IP
查看命令是ip addr或是ifconfig
测试端口是否畅通
返回Windows,开启cmd,通过telnet命令,测试端口是否畅通(这一步连接不能就ping一下也可以)
开启6379端口(大部分原因是没开放端口)
如果连接失败,表示CentOS的6379端口没有开启 ping也不行的话
首先输入firewall-cmd --query-port=6379/tcp,
如果返回结果为no,那么证明6379端口确实没有开启。
接着输入
firewall-cmd --add-port=6379/tcp,将6379端口开启,返回success。
最后然后再执行firewall-cmd --query-port=6379/tcp,返回yes,证明端口已经成功开启
开启端口成功之后再用cmd命令重复上述telnet命令一遍,出现小黑框闪烁一下说明连接没有问题。(这里面如果telnet命令不通 ping通也是可以的)