Redis基于内存运行并支持持久化
采用key-value(键值对)的存储形式
优点
1、安装依赖环境
yum -y install gcc gcc-c++
2、将软件包上传到/opt目录下
tar zxvf redis-5.0.7.tar.gz -C /opt
3、进入软件目录进行编译
cd redis-5.0.7/
make
make PREFIX=/usr/local/redis install
4、将redis建立软连接让系统所能识别
ln -s /usr/local/redis/bin/* /usr/local/bin
5、配置脚本
cd /opt/redis-5.0.7/utils ## 进入软件目录
./install_server.sh ## 执行配置脚本
配置过程一直回车即可
PS:配置参数含义如下:
Selected config:
Port : 6379
Config file : /etc/redis/6379.conf //配置文件路径
Log file : /var/log/redis_6379.log //日志文件路径
Data dir : /var/lib/redis/6379 //数据文件路径
Executable : /usr/local/bin/redis-server //可执行文件路径
Cli Executable : /usr/local/bin/redis-cli //客户端命令工具
6、查看服务是否开启
[root@localhost utils]# netstat -lnupt | grep redis
tcp 0 0 127.0.0.1:6379 0.0.0.0:* LISTEN 25830/redis-server
7、可以通过执行命令对redis服务进行管理
/etc/init.d/redis_6379 stop //停止
/etc/init.d/redis_6379 start //启动
/etc/init.d/redis_6379 reboot //重启
/etc/init.d/redis_6379 status //状态
1、连接本地数据库
[root@localhost utils]# redis-cli
127.0.0.1:6379>
2、连接远程数据库
[root@localhost utils]# redis-cli -h 192.168.50.134 -p 6379
127.0.0.1:6379>
3、获取命令帮助
例:
127.0.0.1:6379> help @list
BLPOP key [key ...] timeout
summary: Remove and get the first element in a list, or block until one is available
since: 2.0.0
BRPOP key [key ...] timeout
summary: Remove and get the last element in a list, or block until one is available
since: 2.0.0
127.0.0.1:6379> help set
SET key value [expiration EX seconds|PX milliseconds] [NX|XX]
summary: Set the string value of a key
since: 1.0.0
group: string
127.0.0.1:6379> set test abc
OK
127.0.0.1:6379> get test
"abc"
例:
[root@localhost utils]# redis-benchmark -h 127.0.0.1 -p 6379 -c 100 -n 100000
redis-benchmark -h 127.0.0.1 -p 6379 -q -d 100
1、redis支持多数据库,默认支持16个数据库,0-15个命名
2、多数据库相互独立,互不干扰
3、多数据库常用命令
①多数据库间切换
②多数据库间移动数据
③清除数据库内数据
127.0.0.1:6379> hset table name tom age 20 score 99
(integer) 3
127.0.0.1:6379> hset table2 name jerry age 25 score 80
(integer) 3
127.0.0.1:6379> hget table age
"20"
127.0.0.1:6379> hget table name
"tom"
127.0.0.1:6379> hgetall table2
1) "name"
2) "jerry"
3) "age"
4) "25"
5) "score"
6) "80"
将dump。rdb文件拷贝到redis的安装目录的lib目录下,重启redis服务即可
vim /etc/redis/6379.conf
save 900 1
save 300 10
save 60 10000
dbfilename dump.rdb
dir /var/lib/redis/6379
rdbcompression yes
PS:含义
900秒之内至少一次写操作,300秒之内至少发生10次写操作、60秒之内发生至少10000次写操作,只要满足其一都会触发快照操作,注释所有的save项都表示关闭RDB
RDB文件名称
RDB文件路径
是否进行压缩
vim /etc/redis/6379.conf
appendonly yes ## 开启AOF持久化
appendfilename "appendonly.aof" ## AOF文件名称
# appendfsync always
appendfsync everysec
# appendfsync no
aof-load-truncated yes
PS:
appendfsync always ## always:同步持久化,每次发生数据变化会立刻写入磁盘
appendfsync everysec ## 默认推荐,每秒异步记录一次(默认值)
appendfsync no ## 不同步。交给操作系统决定如何同步
3.AOF的重写机制
4.AOF重写的原理
5.AOF的重写配置
vim /etc/redis/6379.conf
# 在日志进行BGREWRITEAOF时,如果设置为yes表示新写操作不进行同步fsync,只是暂存在缓冲区里,避免造成磁盘IO操作冲突,等重写完成后在写入。Redis中默认为no
no-appendfsync-on-rewrite no
# 当前AOF文件大小是上次日志重写时AOF文件大小两倍时,发生BGREWRITEAOF操作
auto-aof-rewrite-percentage 100
# 当前AOF文件执行BGREWRITEAOF命令的最小值,避免刚开始启动Redis时由于文件尺寸较小导致的BGREWRITEAOF
auto-aof-rewrite-min-size 64mb
info memory
①默认情况下回收策略是禁止删除
②redis.com配置文件中修改maxmemory-policy属性值
③volatile-lry:使用LRU算法从已设置过期时间的数据集合中淘汰数据
④volatile-ttl:从已设置过期时间的数据集合中挑选即将过期的数据淘汰
⑤volatite-random:从已设置过期时间的数据集合中随机挑选数据淘汰
⑥allkeys-lru:使用LRU算法从所有数据集合中淘汰数据
⑦allkeys-random:从数据集合中任意选择数据淘汰
与swap空间交换
2. 避免内存交换
3. 针对缓存数据大小选择
4. 尽可能的使用Hash数据结构
5. 设置key的过期时间
①默认情况下回收策略是禁止删除
②redis.com配置文件中修改maxmemory-policy属性值
③volatile-lry:使用LRU算法从已设置过期时间的数据集合中淘汰数据
④volatile-ttl:从已设置过期时间的数据集合中挑选即将过期的数据淘汰
⑤volatite-random:从已设置过期时间的数据集合中随机挑选数据淘汰
⑥allkeys-lru:使用LRU算法从所有数据集合中淘汰数据
⑦allkeys-random:从数据集合中任意选择数据淘汰
⑧no-enviction:禁止淘汰数据