技术文档:
http://www.runoob.com/redis/redis-tutorial.html
Jedis介绍
Jedis是Redis 官方首选的java客户端开发包
http://github.com/xetorthio/jedis
Jedis-jar url
下载地址: https://mvnrepository.com/artifact/redis.clients/jedis
#Redis 的数据结构
· 1
· 2
五种数据类型:
字符串(String) , 哈希(hash) ,字符串列表(list) , 字符串集合(set),有序字符串集合(sorted set)
常用的是字符串和哈希
Key的定义注意点:
不要过长
不要过短
统一的命名规范
存储String
常用命令:
赋值: set company imooc ,取值就可以通过 get company 获得 imooc
getset命令: getset company baidu 结果:imooc 然后 get company 结果: baidu .getset key value 就是先获得key后更改value
删除
扩展命令
取值
数值增减
递增
同理
incrby num 5 就是通过 num+5的结果。一般num默认是0,现在应该就是5
同理decrby num2 5 结果就是-5
存储Hash
String key和value的map容器
每一个Hash可以存储4294967295个键值对
hset key field value 命令:
例子:
赋值
hset myhash username jack
hset myhash age 18
其中
hset myhash2 username jack age 18
删除:
如果在接着去删除 hdel myhash2 username 结果 0
删除没有的字段就返回0
存储list:
ArrayList使用数组方式
LinkedList使用双向链接方式
双向链表中增加数据
双向链表中删除数据
存储list常用命令:
两端添加 查看列表 两端弹出 获取列表元素个数 扩展命令
命令: lpush key value[value]
lpush mylist3 a b c 1 2 3
命令: lrange key start stop
取出: lrange mylist3 0 5 结果就是 3 2 1 c b a 这和java 中list集合有一点区别
当然也可以这样取值
命令:
lpop key 移出并获取列表的第一个元素
llen key 获取列表长度
rpop key 移出并获取列表的最后一个元素
lpush key value 插入到已存在列表头部,
rpush key value 插入到已存在列表尾部
lpushx key value 同理也是插入到列表头部
rpushx key value 同理也是插入到列表尾部
lpushx mylist3 x ,通过查看 lrange mylist 0 -1 得 x 3 2 1 a b c
存储set
和list类型不同的是,set集合中不允许出现重复的元素
set可包含的最大元素数量是4294967295
存储set常用命令
添加/删除元素 获得集合中的元素 扩展命令
集合中的差集运算 集合中的交集运算 集合中并集运算
元素添加:
sadd myset a b c 结果为 3
sadd myset a 结果为0
sadd myset 1 2 3
删除元素 :
srem myset 1 2 结果就是: a b 3 c
判断元素是否存在
sismember myset a 存在返回 1 不存在就返回0
差集运算: sdiff key[key]
交集运算
显示集合中所有的元素
显示集合中成员数量
返回集合中的一个或多个成员
存储Set使用场景
跟踪一些唯一性数据
用于维护数据对象之间的关联关系
Redis的Keys的通过操作
keys * 查看所有的key
del my1 my2 my3 删除某些key
exists my1 查看key是否存在 返回0是存在,1不存在
rename company newcompany 重命名为newcompany
expire key 1000 为key设置过期时间
TTL key
以秒为单位,返回给定
Redis特性
相关特性
多数据库
redis事务
多数据:
默认是0号数据库
select 0 ,当然也可以移动数据库 move myset 1 就是将0中的myset移动到myset
MULTI
标记一个事务块的开始。
EXEC
执行所有事务块内的命令。
DISCARD
取消事务,放弃执行事务块内的所有命令。
1、五大数据类型
String 字符串
list 字符串列表
set 字符串集合
hash 哈希
sorted set 有序字符串集合
2、Redis 事物
与关系型数据库不同,一个事物执行失败,他后边的事物继续执行,不会被打断!
3、Redis多数据库
4、Redis持久化
Redis所有的数据都存在内存中,从内存当中同步到硬盘上,这个过程叫做持久化过程。
方式:
RDB持久化:
指定时间间隔,然后写入硬盘中
AOF:
以日志形式,记录服务器每一个操作;Redis服务器启动时读取该文件来重新构建数据库,保证数据完整性。
配置可以禁用 持久化功能;
也可以同时使用两种方式。
5、RDB持久化
优势:
只有一个文件,时间间隔的数据,可以归档为一个文件,方便压缩转移(就一个文件)
劣势:
如果宕机(数据还没向硬盘中写,数据就会丢失),数据损失比较大,因为它是没一个时间段进行持久化操作的。也就是积攒的数据比较多,一旦懵逼,就彻底懵逼了
6、AOF持久化
优势:
1. 带来更高的数据安全性。有三种同步策略。每秒同步、每修改同步、不同步。
2.AOF 文件是一个只进行追加操作的日志文件,因此在写入过程中即使出现宕机现象也不影响之前已经存在的内容。
3.如果日志过大,redis可以启动重写机制。在重写过程中产生的对数据库操作记录会保存在一个新文件中,等到重写完成后再追加到现有的文件中。
4.AOF 文件有序地保存了对数据库执行的所有写入操作
劣势:
1. 对于相同数量的数据集而言,文件比rdb方式要大。
2.效率比RDB低
有操作步骤。