Redis是一个开源,高级的键值存储和一个适用的解决方案,用于构建高性能,可扩展的Web应用程序。php
Redis属于非关系型数据库和Memcached相似,redis也是一个key-value型存储系统。但redis支持的存储value类型相对更多,包括string(字符串)、list(列表)、set(集合)和zset(有序集合)等。这些数据类型都支持push/pop、add/remove及取交集、并集和差集及更丰富的操做,并且这些操做都是原子性的。为了保证效率,redis的数据都是缓存在内存中。区别是redis会周期性的把更新的数据写入磁盘或者把修改操做写入追加的记录文件,而且在基础上实现了master-slave(主从)同步。
Redis官方网网站是:http://www.redis.io/ ,以下:css
redis是一个高性能的key-value数据库。redis的出现、很大程度补偿了memcached这类key/value存储的不足,在部分场合能够对关系数据库起到很好的补充做用。它提供了Python、Ruby、Erlang、PHP客户端,使用方便。html
关于Redis以往版本中存在的问题官方已经作出解释
https://redis.io/topics/problemsmysql
redis特色:redis
- 1)支持内存缓存,这个功能至关于memcached
- 2)支持持久化存储,这个功能至关于memcachedb,ttserver
- 3)数据库类型更丰富。比其余key-value库功能更强
- 4)支持主从集群、分布式
- 5)支持队列等特殊功能
应用:缓存从存取memcached更改存取redis
1.存储方式:
memecache 把数据所有存在内存之中,断电后会挂掉,数据不能超过内存大小, Redis有部份存在硬盘上,这样能保证数据的持久性,支持数据的持久化(笔者注:有RDB快照和AOF日志两种持久化方式,在实际应用的时候,要特别注意配置文件快照参数,要不就颇有可能服务器频繁满载作dump)算法2.数据支持类型:
redis在数据支持上要比memecache多的多。sql3.使用底层模型不一样
新版本的redis直接本身构建了VM 机制,由于通常的系统调用系统函数的话,会浪费必定的时间去移动和请求。docker4.运行环境不一样:
redis目前官方只支持Linux 上去行,从而省去了对于其它系统的支持,这样的话能够更好的把精力用于本系统环境上的优化,虽而后来微软有一个小组为其写了补丁。可是没有放到主干上数据库总结:对于二者的选择仍是要看具体的应用场景,若是须要缓存的数据只是key-value这样简单的结构时,我在项目里仍是采用memcache,它也足够的稳定可靠。若是涉及到存储,排序等一系列复杂的操做时,毫无疑问选择redis。vim
redis最佳使用场景是所有数据in-memory redis更多场景最为memcached的替代品来使用 须要除key/value以外的更多数据类型支持时,使用redis更合适 当存储的数据不能被剔除时,使用redis更合适
目前Redis支持的键值数据类型以下:
String 字符串类型 Hash散列类型 List列表类型 Set集合类型 Zset有序集合类型
[root@luoahong-1 home]# wget –q http://download.redis.io/releases/redis-3.2.8.tar.gz [root@luoahong-1 home]# tar xf redis-3.2.8.tar.gz [root@luoahong-1 home]# cd redis-3.2.8 [root@luoahong-1 redis-3.2.8]# make [root@luoahong-1 redis-3.2.8]# make PREFIX=/usr/local/redis install
成功的标志:
[root@luoahong-1 ~]# tree /usr/local/redis/bin/ /usr/local/redis/bin/ ├── redis-benchmark #redis性能读写测试工具 ├── redis-check-aof #对更新日志appenonly.aof检查,相似于mysql binlog ├── redis-check-rdb #用于本地数据库rdb文件的检查 ├── redis-cli #redis命令行客户端操做工具 ├── redis-sentinel -> redis-server └── redis-server #redis服务器daemon启动程序
3. 配置 redis 为系统服务
# mkdir -pv /usr/local/redis/{conf,db,log} mkdir: created directory ‘/usr/local/redis/conf’ mkdir: created directory ‘/usr/local/redis/db’ mkdir: created directory ‘/usr/local/redis/log’ # cp -a utils/redis_init_script /etc/init.d/redis # cp -a redis.conf /usr/local/redis/conf/6379.conf
编辑redis启动脚本
# vim /etc/init.d/redis #!/bin/sh #chkconfig: 2345 80 90 # 添加该行是为了设置成服务 # # Simple Redis init.d script conceived to work on Linux systems # as it does use of the /proc filesystem. # chkconfig --add redis # systemctl status redis redis.service Loaded: loaded (/etc/rc.d/init.d/redis) Active: inactive (dead) EXEC=/usr/local/bin/redis-server # 修改成:EXEC=/usr/local/redis/bin/redis-server CLIEXEC=/usr/local/bin/redis-cli # 修改成:CLIEXEC=/usr/local/redis/bin/redis-cli CONF="/etc/redis/${REDISPORT}.conf" # 修改成:CONF="/usr/local/redis/conf/${REDISPORT}.conf"
修改 redis 主配置文件
# vim /usr/local/redis/conf/6379.conf daemonize no # 修改成 daemonize yes 设置redis服务后台启动 logfile "" # 修改成 logfile "/usr/local/redis/log/redis.log" 设置redis日志文件 dir ./ # 修改成 dir /usr/local/redis/db/ 设置 rdb 文件存储目录
配置环境变量
[root@luoahong-1 ~]# echo "export PATH=/usr/local/redis/bin:$PATH" >>/etc/profile [root@luoahong-1 ~]# . /etc/profile or source /etc/profile
# systemctl daemon-reload # systemctl start redis # systemctl status redis redis.service Loaded: loaded (/etc/rc.d/init.d/redis) Active: active (running) since Wed 2017-08-30 15:04:09 CST; 9s ago CGroup: /system.slice/redis.service └─5199 /usr/local/redis/bin/redis-server 127.0.0.1:6379 Aug 30 15:04:09 localhost.localdomain systemd[1]: Starting redis.service... Aug 30 15:04:09 localhost.localdomain redis[5197]: Starting Redis server... Aug 30 15:04:09 localhost.localdomain systemd[1]: Started redis.service. Aug 30 15:04:16 localhost.localdomain systemd[1]: Started redis.service.
安装错误:
说明:提示说关于分配器allocator, 若是有MALLOC 这个 环境变量, 会有用这个环境变量的 去创建Redis。
并且libc 并非默认的 分配器, 默认的是 jemalloc, 由于 jemalloc 被证实 有更少的 fragmentation problems 比libc
可是若是你又没有jemalloc 而只有 libc 固然 make 出错。 因此加这么一个参数。
解决办法
make MALLOC=libc
[root@luoahong-1 ~]# redis-server &
注:这个是根据环境变量的配置文件进行启动,redis须要启动在后台
[root@luoahong-1 ~]# redis-server --port 6380 & #这个须要咱们的环境变量下面的conf文件放一个6380的配置文件。只须要修改一下端口就能够启动
[root@luoahong-1 ~]# redis-server /usr/local/redis/conf/6389.conf &
经过启动参数传递同名的配置选项会覆盖文件中相应的参数
[root@luoahong-1 ~]# redis-server /usr/local/redis/conf/6389.conf --loglevel warning &
启动:
[root@luoahong-1 ~]# mkdir /usr/local/redis/conf #建立配置文件目录 [root@luoahong-1 ~]# cp -a redis-3.2.8/redis.conf /usr/local/redis/conf/ #拷贝配置文件 [root@luoahong-1 ~]# redis-server /usr/local/redis/conf/redis.conf & #启动 [1] 4501 [root@luoahong-1 ~]# 4501:M 28 Apr 06:47:05.568 * Increased maximum number of open files to 10032 (it was originally set to 1024). _._ _.-``__ ''-._ _.-`` `. `_. ''-._ Redis 3.2.8 (00000000/0) 64 bit .-`` .-```. ```\/ _.,_ ''-._ ( ' , .-` | `, ) Running in standalone mode |`-._`-...-` __...-.``-._|'` _.-'| Port: 6379 | `-._ `._ / _.-' | PID: 4501 `-._ `-._ `-./ _.-' _.-' |`-._`-._ `-.__.-' _.-'_.-'| | `-._`-._ _.-'_.-' | http://redis.io `-._ `-._`-.__.-'_.-' _.-' |`-._`-._ `-.__.-' _.-'_.-'| | `-._`-._ _.-'_.-' | `-._ `-._`-.__.-'_.-' _.-' `-._ `-.__.-' _.-' `-._ _.-' `-.__.-' 4501:M 28 Apr 06:47:05.570 # WARNING: The TCP backlog setting of 511 cannot be enforced because /proc/sys/net/core/somaxconn is set to the lower value of 128. 4501:M 28 Apr 06:47:05.570 # Server started, Redis version 3.2.8 4501:M 28 Apr 06:47:05.570 # WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effect. 4501:M 28 Apr 06:47:05.570 # WARNING you have Transparent Huge Pages (THP) support enabled in your kernel. This will create latency and memory usage issues with Redis. To fix this issue run the command 'echo never > /sys/kernel/mm/transparent_hugepage/enabled' as root, and add it to your /etc/rc.local in order to retain the setting after a reboot. Redis must be restarted after THP is disabled. 4501:M 28 Apr 06:47:05.571 * The server is now ready to accept connections on port 6379
关闭redis
1
2
3
4
5
6
7
|
咱们可使用自带脚本,或者使用
ps
–ef|
grep
redis 进行
kill
[root@luoahong-1 ~]
# redis-cli shutdown
4867:M 05 Jul 14:33:00.284
# User requested shutdown...
4867:M 05 Jul 14:33:00.284 * Saving the final RDB snapshot before exiting.
4867:M 05 Jul 14:33:00.285 * DB saved on disk
4867:M 05 Jul 14:33:00.286
# Redis is now ready to exit, bye bye...
[1]+ Done redis-server
|
解决启动报warning信息:
可选值:0、一、2
0 内核将检查是否有足够的可用内存供应用进程使用;若是有足够的可用内存,内存申请容许;不然,内存申请失败,并把错误返回给应用进程。 1 内核容许分配全部的物理内存,而无论当前的内存状态如何。 2 内核容许分配超过全部物理内存和交换空间总和的内存
三种设置方法:
1
2
3
|
编辑
/etc/sysctl
.conf ,改vm.overcommit_memory=1,而后sysctl -p 生效
sysctl vm.overcommit_memory=1
echo
1 >
/proc/sys/vm/overcommit_memory
|
############### 一、通用 ############### <br>daemonize yes #是否之后台进程运行 pidfile /var/run/redis/redis-server.pid #pid文件位置 port 6379#监听端口 bind 127.0.0.1 #绑定地址,如外网须要链接,设置0.0.0.0 空格分隔 timeout 300 #链接超时时间,单位秒 loglevel notice #日志级别,分别有: # debug :适用于开发和测试 # verbose :更详细信息 # notice :适用于生产环境 # warning :只记录警告或错误信息 logfile /var/log/redis/redis-server.log #日志文件位置 syslog-enabled no #是否将日志输出到系统日志 databases 16#设置数据库数量,默认数据库为0<br> ############### 二、快照方式 ###############<br> save 900 1 #在900s(15m)以后,至少有1个key发生变化,则快照 save 300 10 #在300s(5m)以后,至少有10个key发生变化,则快照 save 60 10000 #在60s(1m)以后,至少有1000个key发生变化,则快照 rdbcompression yes #dump时是否压缩数据 dir /var/lib/redis #数据库(dump.rdb)文件存放目录<br> ############### 三、主从复制 ###############<br> slaveof <masterip> <masterport> #主从复制使用,用于本机redis做为slave去链接主redis masterauth <master-password> #当master设置密码认证,slave用此选项指定master认证密码 slave-serve-stale-data yes #当slave与master之间的链接断开或slave正在与master进行数据同步时,若是有slave请求,当设置为yes时,slave仍然响应请求,此时可能有问题,若是设置no时,slave会返回"SYNC with master in progress"错误信息。但INFO和SLAVEOF命令除外。 <br>############### 四、安全 ###############<br> requirepass foobared #配置redis链接认证密码<br> ############### 五、 限制 ###############<br> maxclients 128#设置最大链接数,0为不限制 maxmemory <bytes>#内存清理策略,若是达到此值,将采起如下动做: # volatile-lru :默认策略,只对设置过时时间的key进行LRU算法删除 # allkeys-lru :删除不常用的key # volatile-random :随机删除即将过时的key # allkeys-random :随机删除一个key # volatile-ttl :删除即将过时的key # noeviction :不过时,写操做返回报错 maxmemory-policy volatile-lru#若是达到maxmemory值,采用此策略 maxmemory-samples 3 #默认随机选择3个key,从中淘汰最不常常用的<br> ############### 六、附加模式 ###############<br> appendonly no #AOF持久化,是否记录更新操做日志,默认redis是异步(快照)把数据写入本地磁盘 appendfilename appendonly.aof #指定更新日志文件名 # AOF持久化三种同步策略: # appendfsync always #每次有数据发生变化时都会写入appendonly.aof # appendfsync everysec #默认方式,每秒同步一次到appendonly.aof # appendfsync no #不一样步,数据不会持久化 no-appendfsync-on-rewrite no #当AOF日志文件即将增加到指定百分比时,redis经过调用BGREWRITEAOF是否自动重写AOF日志文件。<br> ############### 七、虚拟内存 ###############<br> vm-enabled no #是否启用虚拟内存机制,虚拟内存机将数据分页存放,把不多访问的页放到swap上,内存占用多,最好关闭虚拟内存 vm-swap-file /var/lib/redis/redis.swap #虚拟内存文件位置 vm-max-memory 0 #redis使用的最大内存上限,保护redis不会因过多使用物理内存影响性能 vm-page-size 32 #每一个页面的大小为32字节 vm-pages 134217728 #设置swap文件中页面数量 vm-max-threads 4 #访问swap文件的线程数<br> ############### 八、高级配置 ############### hash-max-zipmap-entries 512 #哈希表中元素(条目)总个数不超过设定数量时,采用线性紧凑格式存储来节省空间 hash-max-zipmap-value 64 #哈希表中每一个value的长度不超过多少字节时,采用线性紧凑格式存储来节省空间 list-max-ziplist-entries 512 #list数据类型多少节点如下会采用去指针的紧凑存储格式 list-max-ziplist-value 64 #list数据类型节点值大小小于多少字节会采用紧凑存储格式 set-max-intset-entries 512 #set数据类型内部数据若是所有是数值型,且包含多少节点如下会采用紧凑格式存储 activerehashing yes #是否激活重置哈希
lua脚本
1
2
3
|
lua脚本的最大运行时间是须要被严格限制的,要注意单位是毫秒:
lua-
time
-limit 5000
若是此值设置为0或负数,则既不会有报错也不会有时间限制。
|
慢日志
1
2
3
4
5
6
7
8
|
redis慢日志是指一个系统进行日志查询超过了指定的时长。这个时长不包括IO操做,好比与客户端的交互、发送响应内容等,而仅包括实际执行查询命令的时间。
针对慢日志,你能够设置两个参数,一个是执行时长,单位是微秒,另外一个是慢日志的长度。当一个新的命令被写入日志时,最老的一条会从命令日志队列中被移除。
单位是微秒,即1000000表示一秒。负数则会禁用慢日志功能,而0则表示强制记录每个命令。
slowlog-log-slower-than 10000
慢日志最大长度,能够随便填写数值,没有上限,但要注意它会消耗内存。你可使用SLOWLOG RESET来重设这个值。
slowlog-max-len 128
|
默认状况,Redis不是在后台运行,咱们须要把redis放在后台运行
1
2
|
vim
/usr/local/redis/etc/redis
.conf
将daemonize的值改成
yes
|
远程链接redis
1
2
3
4
5
6
7
8
9
|
redis-cli –h 127.0.0.1 –p 6379
-h ip地址
-p 端口
链接不一样端口
[root@luoahong-1 ~]
# redis-cli -p 6380
测试客户端与redis链接是否正常
127.0.0.1:6379>
ping
PONG
#redis设置密码修改配置文件,equirepass foobared去掉注释,foobared改成本身的密码。而后重启。
|
在redis中,使用CONFIG命令获取.
获取配置文件内容:
1
2
3
4
|
127.0.0.1:6379> CONFIG GET port
1)
"port"
2)
"6379"
127.0.0.1:6379> CONFIG GET *
#查看redis全部的配置内容
|
验证密码是否正确
1
2
3
|
AUTH password
127.0.0.1:6379> AUTH 123456
OK
|
打印字符串
1
2
3
|
ECHO message
127.0.0.1:6379> ECHO 1
"1"
|
关闭当前链接
1
|
QUIT
|
切换到指定的数据库
1
|
SELECT index
|
命令返回值
1.状态回复
1
2
3
|
redis 发送
set
命令设置某个键的值时,Redis会回复状态OK表示设置成功,另外
ping
命令的回复PONG也是状态回复。状态回复直接显示状态信息
127.0.0.1:6379> PING
PONG
|
2.错误回复
当出现命令不存在或命令格式有错误等状况时Redis会返回错误回复(error reply)错误回复以(error)开头,并在后面跟上错误信息。
1
2
|
127.0.0.1:6379> luoahong
(error) ERR unknown
command
'luoahong'
|
3.整数回复
Redis虽然没有整数类型,可是却提供了一些用于整数操做的命令,如递增键值的INCR命令会以整数形式返回递增后的键值。整数回复(integer reply)以(integer)开头,并在后面跟上整数数据
1
2
|
127.0.0.1:6379> INCR foo
(integer) 1
|
4.字符串回复
字符串回复(bulk reply)是最多见的一种回复类型,当请求一个字符串类型键值或一个其余类型键中的某个元素时就会获得一个字符串回复。字符串回复以双引号包裹:
1
2
|
127.0.0.1:6379> GET foo
"1"
|
特殊状况是当请求的键值不存在时会获得一个空结果,显示为(nil) 127.0.0.1:6379> GET luoahong (nil) 127.0.0.1:6379> GET www.luoahong.com (nil)
5.多行字符串回复
多行字符串回复(multi-bulk reply)一样很常见,如当请求一个非字符串类型键的元素列表时就会收到多行字符串回复。多行字符串回复中的每行字符串都以一个序号开头
1
2
|
127.0.0.1:6379> KEYS *
1) "foo
|
提示:KEYS命令的做用是获取数据库中符合指定规则的键名
原文连接