文章目录
- 一、Redis介绍:
- 二、安装Redis
- 2.1. 下载 解压 进入文件夹 然后 编译
- 2.2. 启动Redis
- 2.2.1. 指定配置文件启动redis
- 2.2.2. 配置redis后台启动
- 三. 登录验证
一、Redis介绍:
Redis是当前比较热门的NOSQL系统之一,它是一个key-value存储系统
- 1、Redis的数据类型:字符串、列表(lists)、集合(sets)、有序集合(sorts sets)、哈希表(hashs)
- 2、Redis和memcache相比的独特之处:
(1)redis可以用来做存储(storge)、而memcache是来做缓存(cache)。这个特点主要是因为redis具有“持久化”功能
(2)存储的数据有“结构”,对于memcache来说,存储的数据只有一种类型——“字符串”,而redis还可以存储链表、集合、有序集合、哈序结构
- 3、Redis实现数据持久化的两种方式:(Redis将数据存储于内存中,或被配置为使用虚拟内存)
(1)使用截图的方式,将内存中的数据不断写入磁盘(性能高,但可能会引起一定程度的数据丢失)
(2)使用类似mysql的方式,记录每次更新的日志
- 4、Redis的主从同步:对提高读取性能非常有益
二、安装Redis
2.1. 下载 解压 进入文件夹 然后 编译
# wget http://download.redis.io/releases/redis-5.0.0.tar.gz
# tar -zxvf redis-5.0.0.tar.gz
# cd redis-5.0.0.tar.gz
# make上面的命令主要是 下载 解压 进入文件夹 然后 编译
当然你也可以选择其它版本下载安装,下载地址:http://redis.io/download
编译时报错,关于gcc的,需要下载gcc
yum install gcc
2.2. 启动Redis
# cd src
# ./redis-server ../redis.conf
2.2.1. 指定配置文件启动redis
进入redis-5.0.0文件夹下 的 src ,使用指定配置文件启动redis,启动成功效果如下:
2.2.2. 配置redis后台启动
不配置后台启动的话命令窗口是无法输入其它命令的 ,进入redis-5.0.0文件夹编辑redis.conf文件
将 daemonize no 改成 daemonize yes,当然 如果有需要的话 也可以配置一下密码,如下图:
最后重启 redis服务即可
同时你也可以查看redis默认端口6379以确认redis是否开启
# netstat -tunlp|grep 6379
至此,redis安装完毕!
三. 登录验证
1.设置Redis认证密码后,客户端登录时需要使用-a参数输入认证密码,不添加该参数虽然也可以登录成功,但是没有任何操作权限,如下:
$ ./redis-cli -h 127.0.0.1 -p 6379
127.0.0.1:6379> keys *
(error) NOAUTH Authentication required.
使用密码认证登录,并验证操作权限:
[root@cjgx-db01 src]# ./redis-cli -h 127.0.0.1 -p 6379 -a Zldc#EDC
Warning: Using a password with '-a' or '-u' option on the command line interface may not be safe.
127.0.0.1:6379> config get requirepass
1) "requirepass"
2) "Zldc#EDC"
127.0.0.1:6379>
看到类似上面的输出,说明Reids密码认证配置成功。
- 在命令行客户端配置密码(redis重启前有效)
前面介绍了通过redis.conf配置密码,这种配置方式需要重新启动Redis。也可以通命令行客户端配置密码,这种配置方式不用重新启动Redis。配置方式如下:
127.0.0.1:6379> config set requirepass newPassword
OK
127.0.0.1:6379> config get requirepass
1) "requirepass"
2) "newPassword"
注意:使用命令行客户端配置密码,重启Redis后仍然会使用redis.conf配置文件中的密码。
- 在Redis集群中使用认证密码
如果Redis服务器使用了集群。除了在master中配置密码外,也需要在slave中进行相应配置。在slave的配置文件中找到如下行,去掉注释并修改与master相同的密码即可:
# masterauth master-password
redis命令参考:
启动:redis-server(redis-server redis.conf)
登陆:redis-cli(redis-cli -p 6379)
关闭:redis-cli shutdown
Redis-server /usr…/redis.conf 启动redis服务,并指定配置文件
Redis-cli 启动redis 客户端 Pkill redis-server
关闭redis服务
./redis-cli shutdown
关闭redis客户端
netstat -tunpl|grep 6379
查看redis 默认端口号6379占用情况
附加内容参考:
1、Redis设置开机自启动
vim /etc/rc.local
加入
/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis-conf
2、/usr/local/redis/bin目录下文件介绍
redis-benchmark:redis性能测试工具redis-check-aof:检查aof日志的工具redis-check-dump:检查rdb日志的工具redis-cli:连接用的客户端redis-server:redis服务进程
3、Redis的配置
daemonize:如需要在后台运行,把该项的值改为yespdifile:把pid文件放在/var/run/redis.pid,可以配置到其他地址bind:指定redis只接收来自该IP的请求,如果不设置,那么将处理所有请求,在生产环节中最好设置该项port:监听端口,默认为6379timeout:设置客户端连接时的超时时间,单位为秒loglevel:等级分为4级,debug,revbose,notice和warning。生产环境下一般开启noticelogfile:配置log文件地址,默认使用标准输出,即打印在命令行终端的端口上database:设置数据库的个数,默认使用的数据库是0save:设置redis进行数据库镜像的频率rdbcompression:在进行镜像备份时,是否进行压缩dbfilename:镜像备份文件的文件名dir:数据库镜像备份的文件放置的路径slaveof:设置该数据库为其他数据库的从数据库masterauth:当主数据库连接需要密码验证时,在这里设定requirepass:设置客户端连接后进行任何其他指定前需要使用的密码maxclients:限制同时连接的客户端数量maxmemory:设置redis能够使用的最大内存appendonly:开启appendonly模式后,redis会把每一次所接收到的写操作都追加到appendonly.aof文件中,当redis重新启动时,会从该文件恢复出之前的状态appendfsync:设置appendonly.aof文件进行同步的频率vm_enabled:是否开启虚拟内存支持vm_swap_file:设置虚拟内存的交换文件的路径vm_max_momery:设置开启虚拟内存后,redis将使用的最大物理内存的大小,默认为0vm_page_size:设置虚拟内存页的大小vm_pages:设置交换文件的总的page数量vm_max_thrrads:设置vm IO同时使用的线程数量