官网: https://redis.io/
参考: http://redisdoc.com/
Redis 介绍
Redis是一个开源项目(BSD许可证), 内存数据库, 用作数据库、缓存和消息代理.
它支持的数据结构包括:
字符串、散列、列表、集合、带有范围查询的排序集、位图、日志, 带有半径查询的地理空间索引.
Redis具有内置的复制、Lua脚本、LRU回收、事务和不同级别的磁盘持久化,并通过Redis Sentinel和Redis Cluster自动分区来提供高可用性.
key:
任何二进制序列都可以作为key, 像name简单的字符串, 一个jpeg文件都可以, 空串也是可以的, 但是不要太长, 消耗内存效率低, 也不要太短, 可读性差.
value:
字符串, 列表, 散列, 集合, 有序集合, HyperLogLog字符串是基本的值类型, 图片也行, 序列化后的对象也行, 但是最多能存512M字节内容.
Redis命令
Redis安装与卸载
#安装
$sudo apt-get update
$sudo apt-get install redis-server
#卸载
apt-get purge --auto-remove redis-server
然后再删除redis文件. rdb, aof, log文件
# 如果卸载的时候会出现unknown user 'redis' in statoverride file
# 解决方法
#1: open /var/lib/dpkg/statoverride
#2: should see root redis
#3: dpkg-statoverride --remove xxx
Redis客户端
一般使用 Redis Desktop Manager
如何使局域网可以访问
1: 修改 etc/redis/redis.conf
2: redis.windows.conf
3: 修改: protected-mode no, 他是为了禁止公网访问redis cache,加强redis安全的, 它启用的条件,有两个:
a: 没有bind IP
b: 没有设置访问密码
4: 增加 requirepass 111111
Redis 常见命令
命令 | 描述 | 例子 |
---|---|---|
redis-server | 启动服务端 | |
redis-cli | 启动客户端 | |
service redis restart | 重启服务端 | |
v | 用服务端查看版本 | redis-server -v |
info | 用客户端查看版本 | redis-cli info |
auth | 输入密码 | auth "yourpassword" |
ss -tanl | 查看端口是否被使用, 这个是linux的命令 | |
help | 查看帮助. | help @string, 关于string的全部会出来 |
flushdb | 清掉所有数据 | flushdb |
keys | 查看键 | keys * 查看所有键 |
get | 获取设置的值 | get {key} |
Redis 持久化
1: 为什么要持久化
持久化是将数据从掉电易失的内存存放到磁盘设备上(默认名:dump.rdb), 因为Redis默认是基于内存的, 不存到磁盘上.
持久化2种方式:
1: RDB Redis DB(保存二进制数据, 省空间, 默认为dump.rdb)
2: AOF AppendOnlyFile(存的是命令), 默认是不开启的
2: 如何持久化
RDB, AOF可以同时执行, 但是RDB很耗时, 所以操作不能太频繁, 否则性能不好. 备份文件一般存放到/var/lib/redis/dump.rdb中, 具体是在redis.conf中配置的.
1: SAVE: Redis服务器将被阻塞, 无法处理客户端发送的命令
2: BGSAVE: 这个是后台(Background)执行的. 不阻塞
3: 满足条件后自动持久化, 默认下面的任何一种成立, 则持久化, 实际使用的是BGSAVE
SAVE 900 1 #距离上次创建RDB文件900秒, 且发生了一次修改.
SAVE 300 10
SAVE 60 10000
说明: SAVE 300 10: 过去300秒, 且所有数据库总共发生了不少于10次的修改.
AOF是写入命令的, 每执行一条修改的, 都会生成一个命令, 比RDB相对安全一些, 在遭遇停机的时候造成数据丢失, 取决于命令被写到硬盘的时间, 他有3中策略(Always, Everysec, No)
appendonly yes
appendfilename "appendonly.aof"
appendfsync always
Always: 每写一个命令, 就调用一次写操作. 因此比较安全, 但是造成性能偏低,速度慢
Everysec: 每秒写一次(默认值)
No: 不主动调用fdatasync.由服务器决定何时写.
在conf中appendonly节点上.
随着时间推移, 备份文件越来越大, 就需要压缩, 如何压缩, 2种方法:
1: 客户端发送BGREWRITEAOF (只保留最后一次的)
2: conf中设置 auto-aof-rewrite-min-size
2: 如何还原备份的文件
对于备份RDB文件和AOF文件都可以采用拷贝的方式还原.
把RDB文件拷贝到conf文件设置的路径, 重启(service service redis restart)后即可.