安装
官网下载
下载地址:redis-3.2.8.tar.gz
依赖包
1 | yum install gcc |
编译安装
1 | wget http://download.redis.io/releases/redis-3.2.8.tar.gz # 获取包 |
移动文件夹
移动文件,便于管理:(所有源代码安装的软件都安装在/usr/local下)
创建两个文件夹,bin用于存放命令,etc拥有存放配置文件。
1 | mkdir -p /usr/local/redis/etc |
-p是递归创建。
接下来,将redis-3.2.8文件夹下的redis.conf复制到/usr/local/redis/etc/
并将src目录下的6个命令文件(绿色的),移动到/usr/local/redis/bin/
1 | [root@localhost src]# mkdir -p /usr/local/redis/etc |
启动redis服务
1 | [toor@localhost redis]$ cd bin |
显示结果:
但是,这样做的话,我们并没有使用etc的下的配置文件进行启动(图中红线部分)。
如果希望通过指定的配置文件启动,需要在启动时指定配置文件:
使用ctrl+C终止服务(显示错误,可以重试几次),然后查看redis服务是否终止干净了,之后通过设置配置文件来启动服务
运行:pstree -p | grep redis
发现redis服务已经被终止干净
现在我们带上配置文件 /usr/local/etc/redis.conf 运行redis
1 | [toor@localhost bin]$ ./redis-server /usr/local/redis/etc/redis.conf |
启动结果:
这样启动redis仍然在前台运行;
redis后台运行需要将daemonize由no改为yes
首先在超级权限下打开redis.conf。
1 | [root@localhost bin]# vim /usr/local/redis/etc/redis.conf |
保存退出,然后再次使用配置文件启动redis-server
1 | [root@localhost bin]# ./redis-server /usr/local/redis/etc/redis.conf |
详细参数说明:
daemonize 如果需要在后台运行,把该项改为yes
pidfile 配置多个pid的地址 默认在/var/run/redis.pid
bind 绑定ip,设置后只接受来自该ip的请求
port 监听端口,默认是6379
loglevel 分为4个等级:debug verbose notice warning
logfile 用于配置log文件地址
databases 设置数据库个数,默认使用的数据库为0
save 设置redis进行数据库镜像的频率。
rdbcompression 在进行镜像备份时,是否进行压缩
dbfilename 镜像备份文件的文件名
Dir 数据库镜像备份的文件放置路径
Slaveof 设置数据库为其他数据库的从数据库
Masterauth 主数据库连接需要的密码验证
Requriepass 设置 登陆时需要使用密码
Maxclients 限制同时使用的客户数量
Maxmemory 设置redis能够使用的最大内存
Appendonly 开启append only模式
Appendfsync 设置对appendonly.aof文件同步的频率(对数据进行备份的第二种方式)
vm-enabled 是否开启虚拟内存支持 (vm开头的参数都是配置虚拟内存的)
vm-swap-file 设置虚拟内存的交换文件路径
vm-max-memory 设置redis使用的最大物理内存大小
vm-page-size 设置虚拟内存的页大小
vm-pages 设置交换文件的总的page数量
vm-max-threads 设置VM IO同时使用的线程数量
Glueoutputbuf 把小的输出缓存存放在一起
hash-max-zipmap-entries 设置hash的临界值
Activ 大专栏 centos7安装Redis-3.2.8erehashing 重新hash
Redis服务端默认连接端口是6379.
mysql 服务端默认连接端口是3306
Mogodb 服务端默认连接端口是27017,还有28017。
在平时,我们往往需要查看6379端口是否被占用。可以用以下命令:
1 | [toor@localhost bin]$ netstat -tunpl | grep 6379 |
注意,redis服务需要su权限才能查看,不然只能检查到6379被某个进程占用,但是看不到进程名称。
至此,redis服务已经按照配置文件启动成功!!
客户端登陆
进入 /usr/local/redis/bin/
1 | [root@localhost bin]# redis-cli |
关闭Redis服务
1 | [root@localhost bin]# pkill redis-server |
也可以使用/usr/local/redis/bin/redis-cli shutdown,这种方法使用客户端命令redis-cli
1 | [root@localhost bin]# ./redis-server /usr/local/redis/etc/redis.conf |
开启远程访问端口
> 开启端口:
1 | firewall-cmd --zone=public --add-port=6379/tcp --permanent |
命令含义:
1 | --zone #作用域 |
配置密码认证
找到/usr/local/redis/etc/redis.conf文件中
1 | #requirepass foobared |
去掉注释,并且设置密码
重启redis
1 | [root@localhost bin]# ./redis-server /usr/local/redis/etc/redis.conf |
1 | [root@localhost bin]# ./redis-server /usr/local/redis/etc/redis.conf |
master配置了密码,slave如何配置
若master配置了密码则slave也要配置相应的密码参数否则无法进行正常复制的。
slave中配置文件内找到如下行,移除注释,修改密码即可
1 | #masterauth mstpassword |
参考: