跟我一起学Redis之五种基本类型及其应用场景举例(干了6个小时) (2)

文章阅读数或网页浏览数统计:常见博客文章或是公众号都有阅读数统计,或是自己开发的站点需要统计页面访问量,用Redis也可以轻松实现,换其他方式估计得费点心思。

img

img

分布式锁:单体程序,多线程通过线程锁来控制资源抢占,对于分布式系统用线程锁就不行了,借助于setnx(set if not exists的缩写) 来完成,及如果没有值就能新增成功,否则就失败,和资源被占就要等待原理是一样的,当然还得考虑对应值的过期和删除,不然一直占用也不行。

img

字符串的常规操作:比如截取字符串、获取字符串长度等操作。

img

通过以上可知,字符串的功能还是很强大的,这应该就是很多人喜欢用而且只用它的原因吧。

hash

hash的相关命令一般以h开头,着重分享以下命令:

hset key field value : 新增或更新key对应字段的值;

hsetnx key field value:新增一个不存在Key的字段值;

hmset key field value [field value ...]:在指定Key上存储多个字段和值

hget key field:获取指定key中指定字段的值;

hdel key field [field1...]:删除指定Key值的指定字段

hlen key:获取指定key中的字段的数量

hgetall key:获取指定key中所有的字段值

hincrby key field step:指定key中字段值增加step

结合应用场景演练*↓↓↓*

对象缓存:string也能做,为什么还要用hash?,string一般用于简单对象的缓存,比如字段不多,记录也不多的情况,便于序列化解析。

平时项目中有配置信息或下拉数据信息,会用于各个页面,这种变化频率不高,但需频繁的读取的数据,将其进行缓存减少数据库访问是不错的选择:

img

当做数据库:有一个同学,做硬件相关系统,通常关于硬件的相关的参数配置都放在内存中,但由于参数过多时,维护是非常不爽的事,而且稍微一个参数的改动,就会重新发布程序。有些也采用SQLite来存储,对于高效访问和修改,Redis却是相对比较优的选择:

如:多个主机,每个主机中有不同的属性,每个属性有对应的值。

img

做购物车(之前学习记录的):因为大型的网站,用户很多,将每个人的购物车信息都进行关系存储,做以下页面是有点难处的。所以用Redis做比较高效,至于一些明细信息,可以通过商品ID从关系数据库中查找。

img

相对于string来说,对于对象存储,不用来回进行序列化,减少内存和CPU的消耗,但设置过期不能到具体字段,只能针对Key设置。

list

着重分享以下命令:

lpush key value [value1 ...] :在指定key的列表左边插入一个或多个值;

rpush key value [value1 ...] :在指定key的列表右边插入一个或多个值;

lpop key :从指定key的列表左边取出第一个值;

rpop key:从指定key的列表右边取出第一个值;

lrange key start end:从指定key列表中获取指定区间内的数据;

blpop key [key1 ...] timeout:从指定key列表中左边取出第一个值,若列表中没有元素就等待timeout时间,如果timeout为0就一直等待。

brpop key [key1 ...] timeout:从指定key列表中右边取出第一个值,若列表中没有元素就等待timeout时间,如果timeout为0就一直等待。

lset key index value:将指定下标的值更新为value,

img

结合应用场景演****练↓↓↓

用于模拟数据结构:

栈:先进后出,lpush+lpop 或 rpush+rpop;

img

队列:先进先出,lpush+rpop 或 rpush+lpop;

img

阻塞队列:先进先出,如果列表没有元素就等待,lpush+brpop或rpush+blpop;

img

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wpfywj.html