概述:
1. redis
1. 概念
2. 下载安装
3. 命令操作
1. 数据结构
4. 持久化操作
5. 使用Java客户端操作redis
1、redis概念
当数据庞大的时候,如果在关系型数据库里检索数据,那么会非常耗时间,检索耗时,加载进内存耗时。
但,如果在内存中开辟一个空间来缓存无关系的数据,那么数据就不需要加载进内存,直接在用就好了(因为在内存里),而且不需要进行关系查询。
2、下载&安装
2. 下载安装
1. 官网:https://redis.io
2. 中文网:http://www.redis.net.cn/
3. 解压直接可以使用:
* redis.windows.conf:配置文件
* redis-cli.exe:redis的客户端
* redis-server.exe:redis服务器端
先打开服务器端,再打开客户端即可。
3、数据结构介绍【敲黑板】
3. 命令操作
1. redis的数据结构:
* redis存储的是:key,value格式的数据,其中key都是字符串,value有5种不同的数据结构
* value的数据结构:
1) 字符串类型 string
2) 哈希类型 hash : map格式
3) 列表类型 list : linkedlist格式。支持重复元素
4) 集合类型 set : 不允许重复元素
5) 有序集合类型 sortedset:不允许重复元素,且元素有顺序
下面的命令操作都是在redis数据库客户端上操作的,不是java客户端(Java客户端需要数据库连接对象)
4、命令操作:string&hash
2. 字符串类型 string
1. 【存储】: set key value
127.0.0.1:6379> set username zhangsan
2. 【获取】: get key
127.0.0.1:6379> get username
3. 【删除】: del key
127.0.0.1:6379> del age
3. 哈希类型 hash
1. 【存储】: hset key field value
127.0.0.1:6379> hset myhash username lisi
127.0.0.1:6379> hset myhash password 123
2. 【获取】:
* hget key field: 获取指定的field对应的值
127.0.0.1:6379> hget myhash username
* hgetall key:获取所有的field和value
127.0.0.1:6379> hgetall myhash
3. 【删除】: hdel key field
127.0.0.1:6379> hdel myhash username
field是哈希的value的字段。(这个字段又是另一个key)
5、命令操作:list
4. 列表类型 list:可以添加一个元素到列表的头部(左边)或者尾部(右边)
1. 【添加】:
1. lpush key value: 将元素加入列表左表
2. rpush key value:将元素加入列表右边
127.0.0.1:6379> lpush myList a
127.0.0.1:6379> lpush myList b
127.0.0.1:6379> rpush myList c
2. 【获取】:
* lrange key start end :范围获取
127.0.0.1:6379> lrange myList 0 -1 【获取全部】
1) "b"
2) "a"
3) "c"
3. 【删除】:
* lpop key: 删除列表最左边的元素,并将元素返回
* rpop key: 删除列表最右边的元素,并将元素返回
流程图:
6、命令操作:set&sortedset
set
5. 集合类型 set : 不允许重复元素,(无序的,无论取出还是存储)
1. 【存储:sadd key value】
127.0.0.1:6379> sadd myset a
(integer) 1
127.0.0.1:6379> sadd myset a
(integer) 0
2. 【获取:smembers key:获取set集合中所有元素】
127.0.0.1:6379> smembers myset
1) "a"
3. 【删除:srem key value:删除set集合中的某个元素】
127.0.0.1:6379> srem myset a
(integer) 1
sortedset
6. 有序集合类型 sortedset:不允许重复元素,且元素有顺序.
1. 【存储:zadd key score value】
127.0.0.1:6379> zadd mysort 60 zhangsan
(integer) 1
127.0.0.1:6379> zadd mysort 50 lisi
(integer) 1
127.0.0.1:6379> zadd mysort 80 wangwu
(integer) 1
2. 【获取:zrange key start end [withscores]】
127.0.0.1:6379> zrange mysort 0 -1
1) "lisi"
2) "zhangsan"
3) "wangwu"
127.0.0.1:6379> zrange mysort 0 -1 withscores
1) "zhangsan"
2) "60"
3) "wangwu"
4) "80"
5) "lisi"
6) "500"
3. 【删除:zrem key value】
127.0.0.1:6379> zrem mysort lisi
(integer) 1
为什么是sortedset
有序的?
因为sortedset添加元素的时候,每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。(设置分数,再对分数进行排序)
sortedset
一般用在搞【排行榜】业务那里。
7、命令操作:通用命令
7. 通用命令
1. keys * : 查询所有的键
2. type key : 获取键对应的value的类型
3. del key:删除指定的key value
持久化
RDB性能会比AOF好点。
因为RDB是按时间的间隔,并判断key是否变化指定次数才把数据存进硬盘里,而AOF是是操作一下就保存一下,就行MySQL一样
但是,使用RDB只能保证大部分数据不丢失,为了解决这种不安全性,redis和关系型的数据库进行配合。
8、持久化:RDB
2. AOF:日志记录的方式,可以记录每一条命令的操作。可以每一次命令操作后,持久化数据
1. 编辑redis.windwos.conf文件
appendonly no(关闭aof) --> appendonly yes (开启aof)
# appendfsync always : 每一次操作都进行持久化
appendfsync everysec : 每隔一秒进行一次持久化(默认)
# appendfsync no : 不进行持久化
4. 持久化
1. redis是一个内存数据库,当redis服务器重启,或者电脑重启,数据会丢失,我们可以将redis内存中的数据持久化保存到硬盘的文件中。
2. redis持久化机制:
1. RDB:默认方式,不需要进行配置,默认就使用这种机制
* 在一定的间隔时间中,检测key的变化情况,然后持久化数据
1. 【编辑redis.windwos.conf文件】
# after 900 sec (15 min) if at least 1 key changed
save 900 1
# after 300 sec (5 min) if at least 10 keys changed
save