Redis学习总结

本文详细介绍了Redis,一种高性能的键值存储系统。从Redis的特性、常用命令到具体的应用场景,如微博的最新ID存储、排行榜、计数器、过期项目处理等,展示了Redis如何有效提升数据处理效率和性能。文章还探讨了Redis的持久化机制,包括RDB和AOF,以及如何根据需求选择合适的持久化策略。
摘要由CSDN通过智能技术生成

一、Redis简介

1、关于关系型数据库和nosql数据库

       关系型数据库是基于关系表的数据库,最终会将数据持久化到磁盘上,而nosql数据 库是基于特殊的结构,并将数据存储到内存的数据库。从性能上而言,nosql数据库 要优于关系型数据库,从安全性上而言关系型数据库要优于nosql数据库,所以在实 际开发中一个项目中nosql和关系型数据库会一起使用,达到性能和安全性的双保证。

2、 nosql数据库的优势 
(1)易扩展 
这些类型的数据存储不需要固定的模式,无需多余的操作就可以进行横向的扩展。相对于关系型数据库可以减少表和字段特别多的情况。也无型之间在架构的层面上带来了可扩展的能力 
(2)大数据量提高性能 
(3)多样灵活的数据模型 
在nosql中不仅可以存储String,hash,set、Zset等数据类型,还可以保存javaBean以及多种复杂的数据类型。 

3、 NoSql的应用 
(1) 大数据时代淘宝、微信、以及微博等都广泛的使用了redis数据库,将一些固定不变的数据例如学校,区域等固定的信息保存在关系型数据库中。然后对于经常变化的数据例如淘宝每个节日都会有比较热门的搜索显示在搜索框,当节日过去关键字自动删除,为了便于管理,可以将这些数据保存在redis数据库中,并设置过期时间,到达时间就自动删除。 
(2)为了缓解数据库压力,微博首先将发送的微博保存到redis数据库,自己可以立即查看到,然后将内存中的数据同步到关系型数据库。

4、为什么要使用Redis?

      我们先来看单机时代模型 :

       如果每次存储成千上万条数据,这样很会导致MySQL的性能很差,存储以及读取速度很慢,然后就演变成缓存+mysql+垂直拆分的方式。  

      接下来看Cache作为中间缓存:

       将所有的数据先保存到缓存中,然后再存入mysql中,减小数据库压力,提高效率。 
       但是当数据再次增加到又一个量级,上面的方式也不能满足需求,由于数据库的写入压力增加,Memcached只能缓解数据库的读取压力。读写集中在一个数据库上让数据库不堪重负,大部分网站开始使用主从复制技术来达到读写分离,以提高读写性能和读库的可扩展性。Mysql的master-slave模式成为这个时候的网站标配了。 

       接下来我们再看主从分离模式 :

       在redis的高速缓存,MySQL的主从复制,读写分离的基础之上,这时MySQL主库的写压力开始出现瓶颈,而数据量的持续猛增,由于MyISAM使用表锁,在高并发下会出现严重的锁问题,大量的高并发MySQL应用开始使用InnoDB引擎代替MyISAM。 

      最后,分表分库模式:

      将变化小的、业务相关的放在一个数据库,变化多的,不相关的数据放在一个数据库。 

二、Redis的常用命令

redis是一种高级的key-value的存储系统。

其中的key是字符串类型,尽可能满足如下几点:

  • key不要太长,最好不要操作1024个字节,这不仅会消耗内存还会降低查找 效率
  • key不要太短,如果太短会降低key的可读性
  • 在项目中,key最好有一个统一的命名规范(根据企业的需求)

其中value 支持五种数据类型:

  • 字符串型 string
  • 字符串列表 lists
  • 字符串集合 sets
  • 有序字符串集合 sorted sets
  • 哈希类型 hashs

下面将来说一下各种Redis的数据类型的存储操作:

1、存储字符串string

字符串类型是Redis中最为基础的数据存储类型,它在Redis中是二进制安全的,这便意味着该类型可以接受任何格式的数据,如JPEG图像数据或Json对象描述信息等。 在Redis中字符串类型的Value最多可以容纳的数据长度是512M

(1)set key value:设定key持有指定的字符串value,如果该key存在则进行覆盖 操作。总是返回”OK”

(2)get key:获取key的value。如果与该key关联的value不是String类型,redis 将返回错误信息,因为get命令只能用于获取String value;如果该key不存在,返 回null。

(3)getset key value:先获取该key的值,然后在设置该key的值。

(4)incr key:将指定的key的value原子性的递增1.如果该key不存在,其初始值 为0,在incr之后其值为1。如果value的值不能转成整型,如hello,该操作将执 行失败并返回相应的错误信息。

(5)decr key:将指定的key的value原子性的递减1.如果该key不存在,其初始值 为0,在incr之后其值为-1。如果value的值不能转成整型,如hello,该操作将执 行失败并返回相应的错误信息。

(6)incrby key increment:将指定的key的value原子性增加increment,如果该 key不存在,器初始值为0,在incrby之后,该值为increment。如果该值不能转成 整型,如hello则失败并返回错误信息

(7)decrby key decrement:将指定的key的value原子性减少decrement,如果 该key不存在,器初始值为0,在decrby之后,该值为decrement。如果该值不能 转成整型,如hello则失败并返回错误信息

(8)append key value:如果该key存在,则在原有的value后追加该值;如果该 key 不存在,则重新创建一个key/value

使用场景:常规key-value缓存应用。常规计数: 微博数, 粉丝数。

实现方式:String在redis内部存储默认就是一个字符串,被redisObject所引用,当遇到incr,decr等操作时会转成数值型进行计算,此时redisObject的encoding字段为int。 

2、存储lists类型

       在Redis中,List类型是按照插入顺序排序的字符串链表。和数据结构中的普通链表 一样,我们可以在其头部(left)和尾部(right)添加新的元素。在插入时,如果该键并不 存在,Redis将为该键创建一个新的链表。与此相反,如果链表中所有的元素均被移除,那么该键也将会被从数据库中删除。List中可以包含的最大元素数量是 4294967295。

       从元素插入和删除的效率视角来看,如果我们是在链表的两头插入或删除元素,这将会是非常高效的操作,即使链表中已经存储了百万条记录,该操作也可以在常量时间内完成。然而需要说明的是,如果元素插入或删除操作是作用于链表中间,那将会是非常低效的。

(1)lpush key value1 value2...&#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值