一、redis概述
1、redis
redis:一款高性能的NOSQL系列的非关系型数据库redis
2、NoSQL
NoSQL:泛指非关系型的数据库
NOSQL分类:
- 键值(Key-Value)存储数据库:内容缓存,主要用于处理大量数据的高访问负载
- 列存储数据库:分布式的文件系统
- 文档型数据库:Web应用
- 图形(Graph)数据库:社交网络
3、下载安装
- 官网:https://redis.io
- 中文网:http://www.redis.net.cn
- 解压直接可以使用
- redis.windows.conf:配置文件
- redis-cli.exe:redis的客户端
- redis-server.exe:redis服务器端
二、redis数据结构
key:字符串
value:
- 字符串类型 string
- 哈希类型 hash:map格式
- 列表类型 list :linkedlist格式,支持重复元素
- 集合类型 set :不允许重复元素
- 有序集合类型 sortedset:不允许重复元素,且元素有序
三、redis命令
类型 | 存储 | 获取 | 删除 |
---|---|---|---|
string | set key value | get key | del key |
hash | hset key field value | hget key field hgetall key lrange start end | hdel key field |
list | lpush key value rpush key value | lrange key start end | lpop key rpop key |
set | sadd key value | smembers key | srem key value |
sortedset | zadd key score value | zrange key start end [withscores] | zrem key value |
keys *
:查询所有的键type key
:获取键对应的value的类型del key
:删除指定的key value
四、redis持久化
1、redis持久化概述
redis是一个内存数据库,当redis服务器重启,获取电脑重启,数据会丢失,我们可以将redis内存中的数据持久化保存到硬盘的文件中。
2、RDB
-
默认方式,不需要进行配置,默认就使用这种机制
-
在一定的间隔时间中,检测key的变化情况,然后持久化数据
-
修改配置
-
编辑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 300 10 ## after 60 sec if at least 10000 keys changed save 60 10000
-
重新启动redis服务器,并指定配置文件名称
>redis-server.exe redis.windows.conf
-
3、AOF
-
日志记录的方式,可以记录每一条命令的操作。可以每一次命令操作后,持久化数据
-
配置
-
编辑redis.windwos.conf文件
ppendonly no(关闭aof) --> appendonly yes (开启aof)## appendfsync always : 每一次操作都进行持久化 appendfsync everysec : 每隔一秒进行一次持久化 ## appendfsync no : 不进行持久化
-
重新启动redis服务器,并指定配置文件名称
>redis-server.exe redis.windows.conf
-
五、Jadis
1、Jadis概述
Jadis:java操作redis数据库的工具
2、下载使用
下载并导入jedis的jar包
//1. 获取连接
Jedis jedis = new Jedis("localhost",6379);
//2. 操作
jedis.set("username","zhangsan");
//3. 关闭连接
jedis.close();
3、操作redis
1)string
//1. 获取连接
Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379端口
//2. 操作
//存储
jedis.set("username","zhangsan");
//获取
String username = jedis.get("username");
System.out.println(username);//可以使用setex()方法存储可以指定过期时间的 key value
jedis.setex("activecode",20,"hehe");
//将activecode:hehe键值对存入redis,并且20秒后自动删除该键值对//3. 关闭连接
jedis.close();
2)hash
//1. 获取连接
Jedis jedis = new Jedis();//2. 操作
//2.1 存储hash
jedis.hset("user","name","lisi");
jedis.hset("user","age","23");
jedis.hset("user","gender","female");
//2.2 获取hash
String name = jedis.hget("user", "name");
System.out.println(name);
//2.3 获取hash的所有map中的数据
Map<String, String> user = jedis.hgetAll("user");//3. 关闭连接
jedis.close();
3)list
//1. 获取连接
Jedis jedis = new Jedis();//2. 操作
//2.1 list 存储
jedis.lpush("mylist","a","b","c");//从左边存
jedis.rpush("mylist","a","b","c");//从右边存
//2.2 list 范围获取
List<String> mylist = jedis.lrange("mylist", 0, -1);
//2.3 list 弹出
String element1 = jedis.lpop("mylist");//c
String element2 = jedis.rpop("mylist");//c
//2.4 list 范围获取
List<String> mylist2 = jedis.lrange("mylist", 0, -1);//3. 关闭连接
jedis.close();
4)set
//1. 获取连接
Jedis jedis = new Jedis();//2. 操作
//2.1 set 存储
jedis.sadd("myset","java","php","c++");
//2.2 set 获取
Set<String> myset = jedis.smembers("myset");//3. 关闭连接
jedis.close();
5)sortedset
//1. 获取连接
Jedis jedis = new Jedis();//2. 操作
//2.1 sortedset 存储
jedis.zadd("mysortedset",3,"亚瑟");
jedis.zadd("mysortedset",30,"后裔");
jedis.zadd("mysortedset",55,"孙悟空");
//2.2 sortedset 获取
Set<String> mysortedset = jedis.zrange("mysortedset", 0, -1);//3. 关闭连接
jedis.close();
4、jedis连接池
jedis连接池:JedisPool
//0.创建一个配置对象
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(50);
config.setMaxIdle(10);//1.创建Jedis连接池对象
JedisPool jedisPool = new JedisPool(config,"localhost",6379);//2.获取连接
Jedis jedis = jedisPool.getResource();//3. 使用
jedis.set("hehe","heihei");//4. 关闭 归还到连接池中
jedis.close();
5、连接池工具类
public class JedisPoolUtils {private static JedisPool jedisPool;static{//读取配置文件InputStream is = JedisPoolUtils.class.getClassLoader().getResourceAsStream("jedis.properties");//创建Properties对象Properties pro = new Properties();//关联文件try {pro.load(is);} catch (IOException e) {e.printStackTrace();}//获取数据,设置到JedisPoolConfig中JedisPoolConfig config = new JedisPoolConfig();config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));config.setMaxIdle(Integer.parseInt(pro.getProperty("maxIdle")));//初始化JedisPooljedisPool = new JedisPool(config,pro.getProperty("host"),Integer.parseInt(pro.getProperty("port")));}/*** 获取连接方法*/public static Jedis getJedis(){return jedisPool.getResource();}
}