安装环境介绍:
系统版本:centos7.9 64 位
redis 版本:6.2.7
下载 redis
进入官网找到下载地址 https://redis.io/download
找到需要的的版本后,复制下载链接,下载到当前目录。
wget https://download.redis.io/releases/redis-6.2.7.tar.gz
或
curl -O https://download.redis.io/releases/redis-6.2.7.tar.gz
解压并安装 redis
在当前目录下解压 redis,并移动到 /usr/local/ 下进行安装
# 安装二进制编译环境
yum install gcc-c++ -y
tar -zvxf redis-6.2.7.tar.gz
mv redis-6.2.7 /usr/local/redis
cd /usr/local/redis
make && make PREFIX=/usr/local/redis install
这里多了一个关键字 PREFIX=
这个关键字的作用是编译的时候用于指定程序存放的路径。比如我们现在就是指定了 redis 必须存放在 /usr/local/redis 目录。假设不添加该关键字 Linux 会将可执行文件存放在 /usr/local/bin 目录,
库文件会存放在 /usr/local/lib 目录。配置文件会存放在 /usr/local/etc 目录。其他的资源文件会存放在 usr/local/share 目录。这里指定号目录也方便后续的卸载,后续直接 rm -rf /usr/local/redis 即可删除 redis。
编译安装结果:
修改 redis.conf 主配置文件
# 允许 redis 后台启动
sed -i "s/daemonize no/daemonize yes/g" /usr/local/redis/redis.conf
#允许 redis 远程登录
sed -i "s/bind 127.0.0.1 -::1/#bind 127.0.0.1 -::1/g" /usr/local/redis/redis.conf
sed -i "s/protected-mode yes/protected-mode no/g" /usr/local/redis/redis.conf
#修改 redis 登录密码
sed -i "s/# requirepass foobared/requirepass'redis 登录密码 '/g" /usr/local/redis/redis.conf
#启动 redis
/usr/local/redis/bin/redis-server /usr/local/redis/redis.conf
redis.conf 配置文件
在目录 /usr/local/redis 下有一个 redis.conf 的配置文件。我们上面启动方式就是执行了该配置文件的配置运行的。我么可以通过 cat、vim、less 等 Linux 内置的读取命令读取该文件。
也可以通过 redis-cli 命令进入 redis 控制台后通过 CONFIG GET * 的方式读取所有配置项。如下:
/usr/local/redis/bin/redis-cli
not connected> CONFIG GET *
回车确认后会将所有配置项读取出来,如下图
这里列举下比较重要的配置项:
配置项名称 | 配置项值范围 | 说明 |
daemonize | yes、no | yes 表示启用守护进程,默认是 no 即不以守护进程方式运行。其中 Windows 系统下不支持启用守护进程方式运行 |
port | 指定 Redis 监听端口,默认端口为 6379 | |
bind | 绑定的主机地址, 如果需要设置远程访问则直接将这个属性备注下或者改为 bind * 即可, 这个属性和下面的 protected-mode 控制了是否可以远程访问。 | |
protected-mode | yes、no | 保护模式,该模式控制外部网是否可以连接 redis 服务,默认是 yes, 所以默认我们外网是无法访问的,如需外网连接 rendis 服务则需要将此属性改为 no。 |
timeout | 300 | 当客户端闲置多长时间后关闭连接,如果指定为 0,表示关闭该功能 |
loglevel | debug、verbose、notice、warning | 日志级别,默认为 notice |
databases | 16 | 设置数据库的数量,默认的数据库是 0。整个通过客户端工具可以看得到 |
rdbcompression | yes、no | 指定存储至本地数据库时是否压缩数据,默认为 yes,Redis 采用 LZF 压缩,如果为了节省 CPU 时间,可以关闭该选项,但会导致数据库文件变的巨大。 |
dbfilename | dump.rdb | 指定本地数据库文件名,默认值为 dump.rdb |
dir | 指定本地数据库存放目录 | |
requirepass | 设置 Redis 连接密码,如果配置了连接密码,客户端在连接 Redis 时需要通过 AUTH <password> 命令提供密码,默认关闭 | |
maxclients | 0 | 设置同一时间最大客户端连接数,默认无限制,Redis 可以同时打开的客户端连接数为 Redis 进程可以打开的最大文件描述符数,如果设置 maxclients 0,表示不作限制。当客户端连接数到达限制时,Redis 会关闭新的连接并向客户端返回 max number of clients reached 错误信息。 |
maxmemory | XXX <bytes> | 指定 Redis 最大内存限制,Redis 在启动时会把数据加载到内存中,达到最大内存后,Redis 会先尝试清除已到期或即将到期的 Key,当此方法处理 后,仍然到达最大内存设置,将无法再进行写入操作,但仍然可以进行读取操作。Redis 新的 vm 机制,会把 Key 存放内存,Value 会存放在 swap 区。配置项值范围列里 XXX 为数值。 |
微信扫描下方的二维码阅读本文