技术文档:

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低

 

 

有操作步骤。