Redis(序)应用场景
前言
在阅读了《大型网站技术架构:核心原理与案例分析》书后,稍微了解了Redis在大型网站架构中的应用场景和目的。
大型网站都是从小用户量,小流量的网站演变过来的,在小型网站的架构之初,Linux+Apache+PHP+Mysql即可实现。但是随着用户量持续增长,在LAPM架构中一个非常关键的点限制了网站性能:Mysql数据库。
- 在大用户量、大并发的场景中,Mysql数据库的磁盘I/O,多线程并发过程中表锁行锁都都极大程度上限制了网站的响应、吞吐量;
- 对一些热点数据反复的查询造成不必要的磁盘I/O;
这些都降低了网站性能,增加了网站响应延迟、降低吞吐量。
因为这些问题的存在,内存读写/缓存势在必行。数据在内存,减少/避免磁盘IO。从而出现分布式缓存解决以上问题。
应用场景
Redis的应用场景诸多,这里也是总结工作中的应用和收集网友分享的内容。
分布式缓存:Redis采用client-server的模式,所以对于分布式/集群环境中作为独立的cache server是个不错的选择;
NoSql数据库:在很多特殊场景中,关系型数据库并不非常适合表达业务模型时,Redis也是不错的选择;
以上两点是Redis的大方向上的应用!但是由于Redis提供的特性,它还支持其他的非常多的应用场景:
作为全局队列:Redis提供了List列表的数据类型,先进先出。比如任务调度;
应用在生产消费者模式或者发布订阅模式:Redis提供了List列表的数据类型,阻塞式读。Redis同时也提供了Pub/Sub支持;
排行榜/评论排序:Redis提供了Sorted Set有序集合,可以应用在数据排序上;
最新文章/评论:Redis提供了List列表的数据类型,且支持对List进行范围操作;
用户登录状态:Redis有Bitmap可以存储关联一个对象事物的是否状态:0/1。如果用户ID是自增长,可以作为Bitmap的下标,是否登录用0/1表示。
分布式Session:上面说了Redis可以作为分布式缓存,可以存储分布式Session。
分布式锁:因为Redis的client-server模式和单线程特性,对于key的操作可以作为全局的唯一识别;
Redis还有很多应用场景,这里先暂时总结如此,后面发现更多的神级使用方式时,再继续更新。
Redis(序)应用场景的更多相关文章
- redis的使用场景和基本数据类型
一:redis使用的场景 redis是一个高性能的NoSQL数据库,特点是高性能,持久存储,适应高并发的应用场景. 下面看看它的使用场景1.取最新N个数据的操作比如取网站的最新文章,通过下面方式,我们 ...
- redis系列-redis的使用场景
redis越来越受大家欢迎,提升下速度,做下缓存,完成KPI之利器呀.翻译一篇文章<<How to take advantage of Redis just adding it to yo ...
- Redis 数据结构使用场景
转自http://get.ftqq.com/523.get 一.redis 数据结构使用场景 原来看过 redisbook 这本书,对 redis 的基本功能都已经熟悉了,从上周开始看 redis 的 ...
- redis的适应场景
redis应用场景: 1.对数据高并发读写 2.对海量数据的高效存储和访问 3.对数据的高可扩展性和高可用性 做分布式扩展很简单,因为没有固定的表结构 redis介绍: redis是一个key-val ...
- Lua脚本在redis分布式锁场景的运用
目录 锁和分布式锁 锁是什么? 为什么需要锁? Java中的锁 分布式锁 redis 如何实现加锁 锁超时 retry redis 如何释放锁 不该释放的锁 通过Lua脚本实现锁释放 用redis做分 ...
- redis作为缓存场景使用,内存耗尽时,突然出现大量的逐出,在这个逐出的过程中阻塞正常的读写请求,导致 redis 短时间不可用
redis 突然大量逐出导致读写请求block 内容目录: 现象 背景 原因 解决方案 ref 现象 redis作为缓存场景使用,内存耗尽时,突然出现大量的逐出,在这个逐出的过程中阻塞正常的读写请 ...
- redis 发展史 应用场景
引言 在Web应用发展的初期,那时关系型数据库受到了较为广泛的关注和应用, 原因是因为那时候Web站点基本上访问和并发不高.交互也较少. 而在后来,随着访问量的提升,使用关系型数据库的Web站点多多少 ...
- redis的使用场景和优缺点
使用场景和优缺点: 2 Redis用来做什么? 通常局限点来说,Redis也以消息队列的形式存在,作为内嵌的List存在,满足实时的高并发需求.而通常在一个电商类型的数据处理过程之中,有关商品,热销, ...
- Redis数据类型使用场景及有序集合SortedSet底层实现详解
Redis常用数据类型有字符串String.字典dict.列表List.集合Set.有序集合SortedSet,本文将简单介绍各数据类型及其使用场景,并重点剖析有序集合SortedSet的实现. Li ...
- 1.Redis的应用场景
转自:http://www.runoob.com/redis/redis-tutorial.html Redis开创了一种新的数据存储思路,使用Redis,我们不用在面对功能单调的数据库时,把精力放在 ...
随机推荐
- dtd语法
dtd语法 <!ELEMENT 元素名 约束> //简单元素三种:没有子元素的元素 eg: <!ELEMENT name (#PCDATA)> (#PCDATA):约束name ...
- 章节十四、9-Actions类鼠标悬停、滚动条、拖拽页面上的元素
一.鼠标悬停 1.在web网站中,有一些页面元素只需要我们将鼠标指针放在上面就会出现被隐藏的下拉框或者其它元素,在自动化的过程中我们使用Actions类对鼠标进行悬停操作. 2.案例演示 packag ...
- 【vuejs】vue数组操作
问题:两种操作都能给数组添加数据,但是利用下标添加数据不会自动在视图中渲染,这个是和vue自己的规定有关,这里记录一下 网上到原因,这里附转载链接 点我传送 官网相关说明传送门
- python中lambda
lambda_expr ::= "lambda" [parameter_list]: expression python中lambda可以理解为一个匿名函数,它的要求是函数的运算部 ...
- python_机器学习_监督学习模型_决策树
决策树模型练习:https://www.kaggle.com/c/GiveMeSomeCredit/overview 1. 监督学习--分类 机器学习肿分类和预测算法的评估: a. 准确率 b.速度 ...
- Vue、Element-ui项目中如何使用Iconfont(阿里图标库)
我们使用element-ui.vue开发网站的时候,往往图标是起着很重要的作用. 下面是vue.element-ui项目,如何使用阿里iconfont图标库的方法. 准备工作 1. 先注册,再登录.找 ...
- 解决IIS7、IIS7.5 应用程序池回收假死的方法
最近iis网站一直假死状态,都懵了,查看程序有没有关闭数据库,反复捣鼓,还一直测试是否是程序应用池自动回收问题依然没有效果.经过老师提醒,找到了解决办法,在此做个笔记! 原因在于:应用程序池超时配置被 ...
- Windows解决端口占用问题
Windows解决端口占用问题 步骤 1. win + R,输入cmd回车进入dos界面 2. 输入netstat -ano|findstr 8080 查看占用8080端口的进程 3. 输入taskk ...
- Linux SSH建立连接过程分析
https://blog.csdn.net/qwertyupoiuytr/article/details/71213463 SSH建立连接的过程主要分为下面几个阶段: SSH协议版本协商阶段.SSH目 ...
- zz致力于变革未来的智能技术
有 R-CNN SPPNet Fast R-CNN Faster R-CNN ... 的论文翻译 现在已经不能访问了... [私人整理]空间金字塔池化网络SPPNet详解 SPP-Net是出自 ...