Redis-1 入门

官网: https://redis.io/
参考: http://redisdoc.com/

Redis 介绍

Redis是一个开源项目(BSD许可证), 内存数据库, 用作数据库、缓存和消息代理.
它支持的数据结构包括:

字符串、散列、列表、集合、带有范围查询的排序集、位图、日志, 带有半径查询的地理空间索引.

Redis具有内置的复制、Lua脚本、LRU回收、事务和不同级别的磁盘持久化,并通过Redis Sentinel和Redis Cluster自动分区来提供高可用性.

key:
任何二进制序列都可以作为key, 像name简单的字符串, 一个jpeg文件都可以, 空串也是可以的, 但是不要太长, 消耗内存效率低, 也不要太短, 可读性差.

value:
字符串, 列表, 散列, 集合, 有序集合, HyperLogLog字符串是基本的值类型, 图片也行, 序列化后的对象也行, 但是最多能存512M字节内容.

Redis命令

https://redis.io/commands

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)后即可.

你可能感兴趣的:(Redis-1 入门)