什么是Redis
(1)redis开源 高性能nosql数据库,数据可以存储在内存或磁盘上面
(2)Redis 主要key-value结构形式存储,redis底层支持各种类型的数据存储结构包括
list set map string等
优势
1)数据存储:存放在内存,还支持持久化.-存取速度快,并发能力强,数据安全性高
2)支持value类型
3)支持多个语言客户端
4)还支持集群(支持高并发,海量数据)
Mysql、Memcached和Redis的比较
相同点:都是key-valueNosql,数据存储在内容中,读写效率高,都支持存储过期
不同点:
1)redis支持持久化
2)redis支持存储类型更多
Redis的命令
对字符串操作
对value为string类型的常用操作
set key value//将字符串值value关联到key
get key //返回key关联的字符串值
mset //同时设置一个或多个 key-value 对
mget //返回所有(一个或多个)给定 key 的值
incr key //将 key 中储存的数字值增1(key不存在,则初始化为0,再加1)
decr key //将 key 中储存的数字值减1(key不存在,则初始化为0,再减1)
incrBy key //自增多少
decrBy key //自减多少
对key的常用操作
keys * //获取所有key列表
del key //删除key
expire key xx //设置key的过期时间(xx秒后过期)
ttl key //查看key的过期时间
flushall //清空整个redis服务器数据,所有的数据库全部清空
flushdb //清除当前库,redis中默认有16个数据库,名称分别为0,1,2.。。15
select index --select 0 //用来换数据库
对list集合的常用操作
lpush key value //将一个或多个值 value 插入到列表 key 的表头(最左边)
rpush key value //将一个或多个值 value 插入到列表 key 的表尾(最右边)
lpop key //移除并返回列表 key 的头(最左边)元素。
rpop key //移除并返回列表 key 的尾(最右边)元素。
lrange key start stop //返回列表 key 中指定区间内的元素,查询所有的stop为-1即可
lindex key index //返回列表 key 中,下标为 index 的元素
ltrim key start stop //对一个列表进行修剪
lrem key count value //根据count值移除列表key中与参数 value
相等的元素count > 0 : 从表头开始向表尾搜索,移除与 value 相等的元素,
数量为 count 。count < 0 : 从表尾开始向表头搜索,移除与 value 相等的元素,
数量为 count 的绝对值。count = 0 : 移除表中所有与 value 相等的值。
对set集合的常用操作
sadd key member //将一个或多个 member 元素加入到集合 key 当中,已经存在于集合的 member 元素将被忽略
srem key member //移除集合 key 中的一个或多个 member 元素,不存在的 member 元素会被忽略
smembers key //返回集合 key 中的所有成员。
对hash类型的常用操作
hash类型类似于java的map
hset key name value//添加一个name=>value键值对到key这个hash类型
hget key name //获取hash类型的name键对应的值
hmset key name1 key1 name2 key2 //批量添加name=>value键值对到key这个hash类型
hmget key name1 name2//批量获取hash类型的键对应的值
hkeys //返回哈希表 key 中的所有键
hvals //返回哈希表 key 中的所有值
我们将user:1(name:zhangsan,age:18,sex:nv)的信息保存在hash表
事务
multi //标记一个事务块的开始。
exec //执行所有事务块内的命令。
弱事务 : 日志
强事务 :同时成功 同时失败-- 金融数据
discard //取消事务,放弃执行事务块内的所有命令。
Redis的事务在执行exec指令时,才批量执行操作,没有回滚操作
导包
Jedis数据结构操作
Key操作
System.out.println(jedis.keys("*"));
String操作(Crud)
System.out.println(jedis.set("name","zhangsan"));//新增
System.out.println(jedis.get("name"));//获取
System.out.println(jedis.set("name","zhangsan1"));//修改
System.out.println(jedis.get("name"));//获取
System.out.println(jedis.del("name"));//删除
System.out.println(jedis.keys("*"));//查看所有的key
List操作
jedis.lpush("students1","1","2","3","5","6");
System.out.println(jedis.lrange("students1", 0, 3));
Set操作
//set操作
jedis.sadd("students2","a1","b1","c1","b1");
System.out.println(jedis.smembers("students2"));
Hash操作
jedis.hset("students3","student","zhangsan");
System.out.println(jedis.hget("students3", "student"));
Jedis排序
jedis.flushDB();
jedis.lpush("nums","1","2","3","4","8","5","3","1");
System.out.println(jedis.sort("nums"));
SortingParams sortingParams1 = new SortingParams();
sortingParams1.desc();
System.out.println(jedis.sort("nums", sortingParams1));
//对字母排序
jedis.lpush("langues","java","php","c++","test","ui");
SortingParams sortingParams = new SortingParams();
sortingParams.alpha();
sortingParams.desc();
System.out.println(jedis.sort("langues",sortingParams));
Redis持久化配置
Redis 提供了两种不同级别的持久化方式:RDB和AOF,可以通过修改redis.conf来进行配置.
RDB模式
RDB 持久化可以在指定的时间间隔内生成数据集的时间点快照,默认开启该模式.
如何关闭 rdb 模式:
save “”
save 900 1 //至少在900秒的时间段内至少有一次改变存储同步一
save xxx
save 60 10000
AOF追加模式
AOF 持久化记录服务器执行的所有写操作命令,并在服务器启动时,通过重新执行这些命令来还原数据集,默认关闭该模式。
如何开启aof模式:
appendonly yes //yes 开启,no 关闭
appendfsync always //每次有新命令时就执行一次fsync
这里我们启用 everysec
appendfsync everysec //每秒 fsync 一次
appendfsync no //从不fsync(交给操作系统来处理,可能很久才执行一次fsync)