写点什么

Redis 小白入门教程

作者:Java高工P7
  • 2021 年 11 月 11 日
  • 本文字数:3090 字

    阅读完需:约 10 分钟

  • redis.windows.conf:配置文件

  • redis-cli.exe:redis 的客户端

  • redis-server.exe:redis 服务器端


命令操作




redis 的数据结构:


redis 存储的是:key,value 格式的数据,其中 key 都是字符串,value 有 5 种不同的数据结构


value 的数据结构:


  1. 字符串类型 string

  2. 哈希类型 hash : map 格式

  3. 列表类型 list : linkedlist 格式。支持重复元素

  4. 集合类型 set : 不允许重复元素

  5. 有序集合类型 sortedset:不允许重复元素,且元素有顺序


1. 字符串类型 string


  1. 存储: set key value


127.0.0.1:6379> set username zhangsan


OK


  1. 获取: get key


127.0.0.1:6379> get username


"zhangsan"


  1. 删除: del key


127.0.0.1:6379> del age


(integer) 1




2. 哈希类型 hash


  1. 存储: hset key field value


127.0.0.1:6379> hset myhash username lisi


(integer) 1


127.0.0.1:6379> hset myhash password 123


(integer) 1


  1. 获取:


hget key field: 获取指定的 field 对应的值


127.0.0.1:6379> hget myhash username


"lisi"


hgetall key:获取所有的 field 和 value


127.0.0.1:6379> hgetall myhash


  1. "username"

  2. "lisi"

  3. "password"

  4. "123"


  1. 删除: hdel key field


127.0.0.1:6379> hdel myhash username


(integer) 1


3. 列表类型 list:可以添加一个元素到列表的头部(左边)或者尾部(右边)


  1. 添加:

  2. lpush key value: 将元素加入列表左表

  3. rpush key value:将元素加入列表右边


127.0.0.1:6379> lpush myList a


(integer) 1


127.0.0.1:6379> lpush myList b


(integer) 2


127.0.0.1:6379> rpush myList c


(integer) 3


  1. 获取:


  • lrange key start end :范围获取


127.0.0.1:6379> lrange myList 0 -1


  1. "b"

  2. "a"

  3. "c"


  1. 删除:


  • lpop key: 删除列表最左边的元素,并将元素返回

  • rpop key: 删除列表最右边的元素,并将元素返回


4. 集合类型 set : 不允许重复元素


存储:sadd key value


127.0.0.1:6379> sadd myset a


(integer) 1


127.0.0.1:6379> sadd myset a


(integer) 0


获取:smembers key:获取 set 集合中所有元素


127.0.0.1:6379> smembers myset


  1. "a"


删除:srem key value:删除 set 集合中的某个元素


127.0.0.1:6379> srem myset a


(integer) 1


5. 有序集合类型 sortedset:不允许重复元素,且元素有顺序.每个元素都会关联一个 double 类型的分数。redis 正是通过分数来为集合中的成员进行从小到大的排序。


  1. 存储:zadd key score value


127.0.0.1:6379> zadd mysort 60 zhangsan


(integer) 1


127.0.0.1:6379> zadd mysort 50 lisi


(integer) 1


127.0.0.1:6379> zadd mysort 80 wangwu


(integer) 1


  1. 获取:zrange key start end [withscores]


127.0.0.1:6379> zrange mysort 0 -1


  1. "lisi"

  2. "zhangsan"

  3. "wangwu"


127.0.0.1:6379> zrange mysort 0 -1 withscore


  1. "zhangsan"

  2. "60"

  3. "wangwu"

  4. "80"

  5. "lisi"

  6. "500"


  1. 删除:zrem key value


127.0.0.1:6379> zrem mysort lisi


(integer) 1


6. 通用命令


  1. keys * : 查询所有的键

  2. type key : 获取键对应的 value 的类型

  3. del key:删除指定的 key value


持久化




  1. redis 是一个内存数据库,当 redis 服务器重启,获取电脑重启,数据会丢失,我们可以将 redis 内存中的数据持久化保存到硬盘的文件中。

  2. redis 持久化机制:


1. RDB:默认方式,不需要进行配置,默认就使用这种机制


* 在一定的间隔时间中,检测 key 的变化情况,然后持久化数据


  1. 编辑 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


  1. 重新启动 redis 服务器,并指定配置文件名称


D:\JavaWeb2018\day23_redis\资料\redis\windows-64\redis-2.8.9>redis-server.exe redis.windows.conf


  1. AOF:日志记录的方式,可以记录每一条命令的操作。可以每一次命令操作后,持久化数据


1. 编辑 redis.windwos.conf 文件


appendonly no(关闭 aof) --> appendonly yes (开启 aof)

appendfsync always : 每一次操作都进行持久化

appendfsync everysec : 每隔一秒进行一次持久化

appendfsync no : 不进行持久化

Java 客户端 Jedis




  • Jedis: 一款 java 操作 redis 数据库的工具.


* 使用步骤:


1. 下载 jedis 的 jar 包


2. 使用


//1. 获取连接


Jedis jedis = new Jedis("localhost",6379);


//2. 操作


jedis.set("username","zhangsan");


//3. 关闭连接


jedis.close();


  • Jedis 操作各种 redis 中的数据结构


  1. 字符串类型 string


set


get


//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();


  • 哈希类型 hash : map 格式


hset


hget


hgetAll


//1. 获取连接


Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379 端口


//2. 操作


// 存储 hash


jedis.hset("user","name","lisi");


jedis.hset("user","age","23");


jedis.hset("user","gender","female");


// 获取 hash


String name = jedis.h


【一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义】
浏览器打开:qq.cn.hn/FTf 免费领取
复制代码


get("user", "name");


System.out.println(name);


// 获取 hash 的所有 map 中的数据


Map<String, String> user = jedis.hgetAll("user");


// keyset


Set<String> keySet = user.keySet();


for (String key : keySet) {


//获取 value


String value = user.get(key);


System.out.println(key + ":" + value);


}


//3. 关闭连接


jedis.close();


  • 列表类型 list : linkedlist 格式。支持重复元素


lpush / rpush


lpop / rpop


lrange start end : 范围获取


//1. 获取连接


Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379 端口


//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 element1 = jedis.lpop("mylist");//c


System.out.println(element1);


String element2 = jedis.rpop("mylist");//c


System.out.println(element2);


// list 范围获取


List<String> mylist2 = jedis.lrange("mylist", 0, -1);


System.out.println(mylist2);


//3. 关闭连接


jedis.close();


  • 集合类型 set : 不允许重复元素


sadd


smembers:获取所有元素


//1. 获取连接


Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379 端口


//2. 操作


// set 存储


jedis.sadd("myset","java","php","c++");


// set 获取


Set<String> myset = jedis.smembers("myset");


System.out.println(myset);


//3. 关闭连接


jedis.close();


  • 有序集合类型 sortedset:不允许重复元素,且元素有顺序


zadd


zrange


//1. 获取连接


Jedis jedis = new Jedis();//如果使用空参构造,默认值 "localhost",6379 端口


//2. 操作


// sortedset 存储


jedis.zadd("mysortedset",3,"亚瑟");


jedis.zadd("mysortedset",30,"后裔");


jedis.zadd("mysortedset",55,"孙悟空");


// sortedset 获取


Set<String> mysortedset = jedis.zrange("mysortedset", 0, -1);


System.out.println(mysortedset);


//3. 关闭连接


jedis.close();


  • jedis 连接池: JedisPool

  • 使用:


1.创建 JedisPool 连接池对象


2.调用方法 getResource()方法获取 Jedis 连接


//0.创建一个配置对象


JedisPoolConfig config = new JedisPoolConfig();


config.setMaxTotal(50);


config.setMaxIdle(10);


//1.创建 Jedis 连接池对象

用户头像

Java高工P7

关注

还未添加个人签名 2021.11.08 加入

还未添加个人简介

评论

发布
暂无评论
Redis小白入门教程