redis简介

2023-11-06

一、概念

1、什么是redis?

      redis是一款高性能的NOSQL(非关系型)数据库。

2、什么是NOSQL?

      (NoSQL,Not Only SQL)是一种不使用传统的关系型表格结构来组织和存储数据的数据库管理系统。与关系型数据库相比,非关系型数据库采用了不同的数据模型和存储机制,旨在解决大规模数据和高并发访问的需求。

3、关系型数据库和非关系型数据库的比较?

(1)非关系型是数据库的优点

  • 数据之间没有关系,耦合性低,易于扩展。
  • 数据存于缓存中,查询速度高于存于硬盘中的关系型数据库
  • 数据以键值对形式存储,可存储基础数据类型、对象或集合等各种格式,而数据库只支持基础类型。

(2)关系型数据库的优点

  • 支持复杂查询,可以用SQL语句方便的在一个表以及多个表之间做非常复杂的数据查询。
  • 支持事务,使得对于安全性能很高的数据访问要求得以实现。

(3) 一般会将数据存储在关系型数据库中,在nosql数据库中备份存储关系型数据库的数据。

二、redis的数据结构

         Redis通过提供多种键值数据类型来适应不同场景下的存储需求,其中key都是字符串,value有5种不同的数据结构。

1、字符串类型

(1)命令

  • 存储:set key value
  • 获取:get key
  • 删除:del key
127.0.0.1:6379> set username tom
OK
127.0.0.1:6379> get username
"tom"
127.0.0.1:6379> del username
(integer) 1

 (2)使用场景

       String 是最基本最常用的·数据类型,key 是唯一标识,value 是具体的值,value其实不仅是字符串, 也可以是数字(整数或浮点数)。

  ①热点数据缓存

      因为Redis是分布式的独立服务,可以在多个应用之间共享。   

  ②计算访问次数、点赞、转发、库存数量

     因为 Redis 处理命令是单线程,所以执行命令的过程是原子的。因此 String 数据类型适合计数场景。

③共享session信息

       利用 Redis 对 Session 信息进行统一的存储和管理,这样无论请求发送到那台服务器,服务器都会去同一个 Redis 获取相关的 Session 信息,解决了分布式系统下 Session 存储的问题。

2、哈希类型(以map格式)

       Hash 是一个键值对(key - value)集合,value由多个{filed,value}组成。

(1)命令

  • 存储:hset key filed value
  • 获取:获取指定filed对应的值:hget key filed
  •           获取所有的filed和value:hgetall key
  • 删除:hdel key filed
127.0.0.1:6379> hset myhash username lisi
(integer) 1
127.0.0.1:6379> hset myhash password 123
(integer) 1
127.0.0.1:6379> hget myhash username
"lisi"
127.0.0.1:6379> hgetall myhash
1) "username"
2) "lisi"
3) "password"
4) "123"
127.0.0.1:6379> hdel myhash username
(integer) 1
127.0.0.1:6379> hgetall myhash
1) "password"
2) "123"

(2)使用场景

  ①存储对象

      Hash 类型的 (key,field, value) 的结构与对象的(对象id, 属性, 值)的结构相似,可用来存储对象。

  ② 购物车

       以用户的id为key,商品的id为filed,商品的数量为value。刚好构成购物车的三要数。

3、列表类型list

       linkedlist格式,存储有序,支持重复元素。

(1)命令

  • 添加:将元素添加到列表左边:lpush  key  value
  •           将元素添加到列表右边:rpush  key  value
  • 获取:范围获取: lrange  key  start  end
  • 删除:删除列表最左边元素,并将元素返回:lpop key
  •           删除列表最右边元素,并将元素返回:rpop key
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
127.0.0.1:6379> lrange mylist 0 -1
1) "b"
2) "a"
3) "c"
127.0.0.1:6379> lpop mylist
"b"
127.0.0.1:6379> rpop mylist
"c"

 (2)使用场景

         ①任务队列。(秒杀、抢购、12306等等)

         ②消息队列

4、集合类型set

     Set 类型是一个无序并唯一的键值集合,不允许重复元素它的存储顺序不会按照插入的先后顺序进行存储。

(1)命令

  • 存储:sadd key value
  • 获取:获取set集合中所有元素:smembers myset
  • 删除:删除集合中某个元素:srem key value
127.0.0.1:6379> sadd myset a
(integer) 1
127.0.0.1:6379> sadd myset a
(integer) 0
127.0.0.1:6379> smembers myset
1) "a"
127.0.0.1:6379> srem myset a
(integer) 1

(2)使用场景

     ①抽奖

        Set 类型是一个无序并唯一的键值集合,可用于抽奖。

    ②点赞,签到,打卡

        set类型可用保证用户只签到、点赞、打卡一次,例如,以文章id为key,用户id为value,保证用户只能点赞一次。

5、有序集合类型sortedset

       不允许重复元素,且元素有序。相比于 Set 类型多了一个double类型的排序属性 score(分值)来进行排序,对于有序集合 sortedset 来说,每个存储元素相当于有两个值组成的,一个是元素值,一个是排序值。

(1)命令

  • 存储:zadd key score value
  • 获取:zrange key start end [withsores]
  • 删除:zrem key 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
127.0.0.1:6379>  zrange mysort 0 -1
1) "lisi"
2) "zhangsan"
3) "wangwu"
127.0.0.1:6379> zrange mysort 0 -1 withscores
1) "lisi"
2) "50"
3) "zhangsan"
4) "60"
5) "wangwu"
6) "80"
127.0.0.1:6379> zrem mysort lisi
(integer) 1
127.0.0.1:6379>  zrange mysort 0 -1
1) "zhangsan"
2) "wangwu"

(2)使用场景

       在面对需要展示最新列表、排行榜等场景时,如果数据更新频繁或者需要分页显示,可以优先考虑使用 Sortedset。

6、通用命令

  • 查询所有的键:key *
  • 获取键对应的value类型:type key
  • 删除指定的键值对:del key

 三、持久化

 1、概念

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

2、持久化机制

(1)RDB(Redis Database)

         RDB 是 Redis 默认的持久化方式。在一定时间间隔内,检测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服务器,并指定配置文件名称

(2)AOF(Append-Only File)

         AOF 持久化以日志的形式记录每个写操作,将操作追加到文件的末尾。当 Redis 重启时,会重新执行 AOF 文件中的写操作来还原数据。

实现方法

    编辑redis.windwos.conf文件

# appendfsync always : 每一次操作都进行持久化
appendfsync everysec : 每隔一秒进行一次持久化
# appendfsync no	 : 不进行持久化

四、Jedis

         一款java操作数据库的工具。

1、使用步骤

(1)下载jedis的jar包

(2)获取连接

(3)操作

(4)关闭连接

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

(1)字符串类型

  • 获取数据方法:get(key)
  • 存储数据方法:set(key,value)
  • 存储指定过期时间数据:setex(key,时间,value)
 //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)哈希类型

  • 获取数据方法:hget(key),hgetAll(key)
  • 存储数据方法:hset(key,filed,value)
	//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.hget("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();

 (3)列表类型 list

  • 存储数据方法:  lpush / rpush()
  •  获取数据方法: lpop / rpop(),lrange(key, 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();

 (4)集合类型 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();

 (5)有序集合类型 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();

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

redis简介 的相关文章

  • redis dump.rdb / 保存小文件

    Context 我正在使用redis 数据库小于 100 MB 但是 我想进行每日备份 我也在 Ubuntu Server 12 04 上运行 当输入 redis cli save 我不知道 dump rdb 保存到哪里 因为 redis
  • 如何将“.csv”数据文件导入Redis数据库

    如何将 csv 数据文件导入 Redis 数据库 csv 文件中包含 id 时间 纬度 经度 列 您能否向我建议导入 CSV 文件并能够执行空间查询的最佳方法 这是一个非常广泛的问题 因为我们不知道您想要什么数据结构 您期望什么查询等等 为
  • Laravel 异常队列最大尝试次数超出

    我创建了一个应用程序来向多个用户发送电子邮件 但在处理大量收件人时遇到问题 该错误出现在failed jobs table Illuminate Queue MaxAttemptsExceededException App Jobs ESe
  • docker-compose:容器之间的 Redis 连接被拒绝

    我正在尝试设置一个 docker compose 文件 该文件旨在替换运行多个进程 RQ 工作线程 RQ 仪表板和 Flask 应用程序 的单个 Docker 容器解决方案导师 http supervisord org 主机系统是 Debi
  • 如何延长 django-redis 中的缓存 ttl(生存时间)?

    我正在使用 django 1 5 4 和 django redis 3 7 1 我想延长缓存的 ttl 生存时间 当我取回它时 这是示例代码 from django core cache import cache foo cache get
  • 没有适用于机器人的 Laravel 会话

    我在大型 Laravel 项目和 Redis 存储方面遇到问题 我们将会话存储在 Redis 中 我们已经有 28GB 的 RAM 然而 它的运行速度仍然相对较快 达到了极限 因为我们有来自搜索引擎机器人的大量点击 每天超过 250 000
  • 集合成员的 TTL

    Redis 是否可以不为特定键而是为集合的成员设置 TTL 生存时间 我正在使用 Redis 文档提出的标签结构 数据是简单的键值对 标签是包含与每个标签对应的键的集合 例如 gt SETEX id id 1 100 Lorem ipsum
  • Redis 是否使用用户名进行身份验证?

    我已经在我的环境中设置了Redis 并且只看到了通过密码授权的部分 有没有办法也设置用户名 还是只能通过密码验证 Redis 6 上有 ACL 这些都有一个用户名 查看https redis io topics acl https redi
  • 在 Rails 应用程序上将 HASH 保存到 Redis

    我刚刚开始使用 Redis 和 Rails 所以这可能是一个愚蠢的问题 我试图将哈希值保存到 Redis 服务器 但是当我检索它时 它只是一个字符串 IE hash field gt value field2 gt value2 redis
  • redis能完全取代mysql吗?

    简单的问题 我是否可以使用 redis 而不是 mysql 来处理各种 Web 应用程序 社交网络 地理位置服务等 IT 领域没有什么是不可能的 但有些事情可能会变得极其复杂 将键值存储用于全文搜索之类的事情可能会非常痛苦 另外 据我所知
  • Redis AOF fsync(始终)与 LSM 树

    我对日志结构化合并树 LSM 树 的理解是 它利用了附加到磁盘非常快 因为它不需要查找 这一事实 只需将更新附加到预写日志并返回到客户端即可 我的理解是 这仍然提供了立即的持久性 同时仍然非常快 我不认为 Redis 使用 LSM 树 它似
  • spring中如何使用jackson代替JdkSerializationRedisSerializer

    我在我的一个 Java 应用程序中使用 Redis 并且正在序列化要存储在 Redis 中的对象列表 但是 我注意到使用 RedisTemplate 会使用 JdkSerializationRedisSerializer 相反 我想使用 J
  • 如何在Redis中存储聚合目录树搜索结果

    我有一个很大的产品目录树 目前包含约 36000 个类别和约 100 万个产品 即叶子 它的结构如下 最大深度为 5 Cat1 Cat11 Cat111 Cat1111 Product1 Cat1112 Product1 Cat1113 P
  • Redis 会话序列化器 3.2 和 4.2 之间不匹配

    我有一个基于 Spring Cloud 的应用程序在多个 spring boot 服务器上运行 所有服务器使用 EnableRedisHttpSession共享相同的Spring Session 我现在想将第三方小部件集成到我的应用程序中
  • 使用 MongoDB 作为我们的主数据库,我应该使用单独的图数据库来实现实体之间的关系吗?

    我们目前正在为一家专业公司内部实施类似 CRM 的解决方案 由于存储信息的性质以及信息的不同值和键 我们决定使用文档存储数据库 因为它完全适合目的 在本例中我们选择 MongoDB 作为此 CRM 解决方案的一部分 我们希望存储实体之间的关
  • 如何让 Redis 在 Heroku 上启动?

    我已经添加了RedistogoHeroku 上的 nano 插件 我已经在控制台中成功测试了它 但是 当我的应用程序尝试连接 Redis 时 出现以下错误 Heroku 日志文件 2011 10 12T08 19 50 00 00 app
  • 将redis数据移至MySQL的更快方法

    我们拥有庞大的购物和产品交易系统 我们在 MySQL 方面遇到了很多问题 因此经过几次研发后 我们计划使用 Redis 并开始将 Redis 集成到我们的系统中 继之前直接访问数据库之后 现在我们已经移动了Redis系统 用户购物车详情 关
  • 有没有办法在jedis中传递redis命令,而不使用函数?

    我们正在尝试构建一个控制台来处理 Redis 查询 但是 在后端我们需要使用Jedis 因此 作为输入给出的命令需要使用 Jedis 进行处理 例如 在redis cli中 我们使用 keys 同样 我们在 Jedis 中使用 jedis
  • 在 Google App Engine Flex 上将 Websockets 与 Django 结合使用

    我目前正在尝试使用 django 框架和 django channels 设置 Google 应用程序引擎 Flex 对于我当前的项目 我需要一个 websocket 所以我尝试重建 Django channels 网站上提供的教程 htt
  • 使用 StackExchange.Redis 处理暂时性网络错误

    寻找有关使用 StackExchange Redis 客户端时处理临时网络问题的指南 澄清一下 我并不是说最初使用 ConnectionMultiplexer Connect 连接到 Redis 服务器 我指的是如何处理在操作过程中由于任何

随机推荐