Redis缓存Windows下安装和入门

Windows下安装Redis缓存

  1. Redis缓存下载地址:https://github.com/MSOpenTech/redis/releases
    这里写图片描述
    有32位和64位的
  2. 安装结束后打开CMD命令,进入你的安装目录下输入redis-server.exe redis.windows.conf 这个命令显示如下界面:
    这里写图片描述
    显示这个界面就安装成功了!

Redis概念

  1. Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库
  2. Redis缓存数据库是一个持久化,单线程,单进程的一款数据库
  3. Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用。
  4. Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
  5. Redis支持数据的备份,即master-slave模式的数据备份。

Redis缓存数据库Java操作

  1. Maven导包
      <dependency>
          <groupId>redis.clients</groupId>
          <artifactId>jedis</artifactId>
          <version>2.9.0</version>
      </dependency>
  1. 代码实现(基本类型操作)
import redis.clients.jedis.Jedis;

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

public class TestRedis {
    private static Jedis jedis;//非切片额客户端连接
    static {
        //Redis缓存服务器
        jedis = new Jedis("127.0.0.1",6379);
        //权限认证
        //jedis.auth();
    }

    /**
     * 字符串操作
     */
    public void RedisString(){
        jedis.set("name","张三");
        System.out.println(jedis.get("name"));
        //追加操作
        jedis.append("name1","李四");
        System.out.println(jedis.get("name"));
        //删除键
        Long del = jedis.del("name0");
        //返回long类型,1表示成功,0失败
        System.out.println(del);
        //设置多个键值对
        jedis.mset("age","25","addr","江苏");
        System.out.println( jedis.mget("name","age","addr"));
        System.out.println("---------------这是Redis缓存字符串(String)操作-----------------");

    }
    //哈希操作Hash
    public void RedisHash() {
        Map<String,String> map = new HashMap<>();
        map.put("name", "宋伟");
        map.put("age", "25");
        //存储数据
        jedis.hmset("user", map);
        //读取数据  返回一个列表类型 [宋伟, 25]
        System.out.println( jedis.hmget("user", "name","age") );
        //HKEYS key 获取所有哈希表中的字段    返回一个列表[name, age]
        System.out.println( jedis.hkeys("user") );
        //HVALS key 获取哈希表中所有值
        System.out.println( jedis.hvals("user") );
        //HLEN key 获取哈希表中字段的数量
        System.out.println( jedis.hlen("user") );
        //获取所有的键  迭代操作
        Iterator<String> iter = jedis.hkeys("user").iterator();
        while(iter.hasNext()) {
            String key = iter.next();
            System.out.println( key+"--"+jedis.hmget("user", key) );
        }
        System.out.println("---------------这是Redis缓存哈希(Hash)操作-----------------");
    }

    //List操作
    public void RedisList() {
        //开始前,先移除所有的内容
        jedis.del("Programming language");

        //LPUSH key value1 [value2] 将一个或多个值插入到列表头部
        jedis.lpush("Programming language", "Java");
        jedis.lpush("Programming language", "Python");
        jedis.lpush("Programming language", "C++");
        //获取数据  返回一个list [Python, Java]
        //第一个是key,第二个是起始位置,第三个是结束位置
        //其中 0 表示列表的第一个元素, 1 表示列表的第二个元素,以此类推。
        //你也可以使用负数下标,以 -1 表示列表的最后一个元素, -2 表示列表的倒数第二个元素,以此类推。
        System.out.println( jedis.lrange("Programming language",  0, -1) );
        //LPUSHX key value 将一个值插入到已存在的列表头部
        jedis.lpushx("Programming language", "php");
        System.out.println( jedis.lrange("Programming language",  0, -1) );
        //RPUSH key value1 [value2] 在列表中添加一个或多个值
        jedis.rpush("Programming language", "C");
        System.out.println( jedis.lrange("Programming language",  0, -1) );
        //输出情况
//      [C++, Python, Java]
//      [php, C++, Python, Java]
//      [php, C++, Python, Java, C]
        System.out.println("---------------这是Redis缓存List(List)操作-----------------");
    }


    //Set操作
    public void RedisSet() {
        //向集合添加一个或多个成员
        jedis.sadd("webSite", "阿里巴巴","网易");
        jedis.sadd("webSite", "腾讯");
        //SCARD key 获取集合的成员数
        System.out.println( jedis.scard("webSite") );
        //SMEMBERS key 返回集合中的所有成员  返回类型列表[阿里巴巴, 腾讯, 网易]注意顺序不唯一
        System.out.println( jedis.smembers("webSite") );
        //SSCAN key cursor [MATCH pattern] [COUNT count] 迭代集合中的元素
        System.out.println(jedis.sscan("webSite", "0") );
        System.out.println("---------------这是Redis缓存Set(Set)操作-----------------");

    }

    //sorted set有序Set
    public void RedisSortSet() {
//      Redis 有序集合和集合一样也是string类型元素的集合,且不允许重复的成员。
//      不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
//      有序集合的成员是唯一的,但分数(score)却可以重复。
        jedis.zadd("city", 0, "北京");
        jedis.zadd("city", 1, "上海");
        jedis.zadd("city", 2, "杭州");

        //ZCARD key 获取有序集合的成员数
        System.out.println( jedis.zcard("city") );
        //ZREVRANK key member 返回有序集合中指定成员的排名,有序集成员按分数值递减(从大到小)排序  java中的方法是zrevrangeByScore
        System.out.println( jedis.zrevrangeByScore("city", 5, 0) );
        System.out.println("---------------这是Redis缓存有序Set(Set)操作-----------------");

    }

    public static void main(String[] args) {
        TestRedis testRedis = new TestRedis();
        testRedis.RedisString();
        testRedis.RedisHash();
        testRedis.RedisList();
        testRedis.RedisSet();
        testRedis.RedisSortSet();
    }
}

运行结果如下:
这里写图片描述
Redis缓存基本操作和概念就讲到这里。

猜你喜欢

转载自blog.csdn.net/qq_20197983/article/details/81098910