文章目录
Redis
一、图解
下载安装
https://www.redis.net.cn/
解压即可使用
二、文件详解
redis.windows.conf:配置文件
redis-cli.exe:redis的客户端
redis-server.exe:redis的服务器端
三、使用
1 命令操作
redis的数据结构
redis存储的是:key,value格式的数据,其中key都是字符串,value有5种不同的数据结构
1) 字符串类型 string
2) 哈希类型 hash
3) 列表类型 list
4) 集合类型 set
5) 有序集合类型 sortedset
3.1 字符串类型string
①存储:set key value
②获取:get key
③删除:del key
3.2 哈希类型 hash
①存储:hset key field value
②获取:
hget key field:获取指定的field对应的值
hgetall key:获取所有的field和value
③删除:hdel key field
3.3 列表类型 list:允许重复元素
①存储:
lpush key value :将元素加入列表左边
rpush key value:将元素加入列表右边
②获取:
lrange key start end :范围获取(0 -1)代表所有
③删除:
lpop key :删除列表最左边的元素,并将元素返回
ropo key:删除列表最右边的元素,并将元素返回
3.4 集合类型set:不允许重复元素
①存储:sadd key value
②获取:smembers key:获取set集合种所有元素
③删除:srem key value:删除set集合中的某个元素
3.5 有序集合类型 sortedset:不允许重复元素,且元素有顺序(按照score进行排序)
①存储:zadd key score value
②获取:zrange key start end
③删除:zren key value
3.6 通用命令
①keys * :查询所有的键
②type key :获取键对应的value的类型
③del key:删除指定的key value
四、持久化
1.redis是一个内存数据库,当redis服务器重启,或者电脑重启,数据会丢失,我们可以将redis内存中的数据持久化保存到硬盘的文件中
redis持久化机制
①RDB:默认方式,不需要进行配置,默认就使用这种机制
-----在一定的间隔事件中,检测key的变化情况,然后持久化数据
配置&过程
①配置redis.windows.conf
900秒之后,至少有一个key发生了改变就持久化一次。以此类推
save 900 1
save 300 10
save 60 10000(例如改这行为save 10 5)
②在当前文件中运行cmd
redis-server.exe redis.windows.conf
③点击启动客户端
②AOF:日志记录的方式,可以记录每一条命令的操作。可以每一次命令操作后,持久化数据
配置&过程
①配置redis.window.conf文件
appendfsync no(关闭aof) --->appendonly yes(开启aof)
# appendfsync always:每一次操作都进行持久化
# appendfsync everysec:每隔一秒进行一次持久化
# appendfsync no:不进行持久化
Jedis
一、简介
Jedis:一款Java操作redis数据库的工具
二、使用步骤
1.下载Jedis的jar包
2.使用
//1.获取连接
//空参构造器默认本机,6379
Jedis jedis = new Jedis("localhost",6379);
//2.操作
jedis.set("username","zhangsan");
//3.关闭连接
jedis.close();
1. 操作String
Jedis jedis = new Jedis("localhost",6379);
//2.操作
jedis.set("username","zhangsan");
String username = jedis.get("username");
System.out.println(username);
//可以使用setex()方法存储可以指定过期时间的key value
//将activecode:hehe键值对存入redis,并且20秒后自动删除该键值对
jedis.setex("activecode",20,"hehe");
//3.关闭连接
jedis.close();
2. 操作Hash
Jedis jedis = new Jedis();
jedis.hset("myhash","name","Jerry");
jedis.hset("myhash","age","25");
//获取指定的key中的field值
jedis.hget("myhash","name");
//获取所有的值
Map<String,String> myhash = jedis.hgetAll("myhash");
Set<String> keyset = myhash.keyset();
for(String key : keyset){
System.out.println(key + ":" + myhash.get(key));
}
3. 操作List
Jedis jedis = new Jedis("localhost",6379);
jedis.del("mylist");
//2.操作
//list 存储
jedis.lpush("mylist","a","b","c");
jedis.rpush("mylist","a","b","c");
//list范围获取
List<String> mylist = jedis.lrange("mylist", 0, -1);
System.out.println(mylist);
//list弹出
String lvalue = jedis.lpop("mylist");
System.out.println(lvalue);
String rvalue = jedis.rpop("mylist");
System.out.println(lvalue+"/"+rvalue);
List<String> mylist1 = jedis.lrange("mylist", 0, -1);
System.out.println(mylist1);
//3.关闭连接
jedis.close();
4. 操作Set
Jedis jedis = new Jedis("localhost",6379);
//2.操作
jedis.sadd("myset","java","php","json");
Set<String> myset = jedis.smembers("myset");
System.out.println(myset);
//3.关闭连接
jedis.close();
5. 操作sortedset
Jedis jedis = new Jedis("localhost",6379);
//2.操作
jedis.zadd("mysortedset",100,"压缩2");
jedis.zadd("mysortedset",101,"压缩1");
jedis.zadd("mysortedset",92,"压缩3");
//获取
Set<String> mysortedset = jedis.zrange("mysortedset", 0, -1);
System.out.println(mysortedset);
//3.关闭连接
jedis.close();
三、Jedis数据库连接池
- 记得开启服务端
private static JedisPool jedisPool;
static{
//读取配置文件
InputStream is = JedisPoolUtils.class.getClassLoader().getResourceAsStream("jedis11.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")));
//初始化JedisPool
jedisPool = new JedisPool(config,pro.getProperty("host"),Integer.parseInt(pro.getProperty("port")));
}
/**
* 获取连接方法
*/
public static Jedis getJedis(){
return jedisPool.getResource();
}
}
- 测试方法
@Test
public void testUtils(){
//通过连接池工具类获取
Jedis jedis = JedisPoolUtils.getJedis();
//使用
jedis.set("name","Jerry");
System.out.println(jedis.get("name"));
//关闭
jedis.close();
}
案例
- ajax查询数据库使用redis技术
@Override
public String findAllJson() {
//1.先从redis中查询数据
//1.1先获取redis客户端连接
Jedis jedis = JedisUtils.getJedis();
String province_json = jedis.get("province");
//2判断province_json是否为null
if(province_json == null || province_json.length() == 0){
//2.1从数据库中查询
List<Province> list = dao.FindAll();
//2.2将list序列化为json
ObjectMapper mapper = new ObjectMapper();
try {
province_json = mapper.writeValueAsString(list);
} catch (JsonProcessingException e) {
e.printStackTrace();
}
//2.3将json数据存入redis
jedis.set("province",province_json);
System.out.println("第一次查询redis没有 走了数据库");
jedis.close();
}else {
System.out.println("第二次查询redis有数据,查询缓存");
}
return province_json;
}