Redis介绍及使用

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;

    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值