论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
ToB企服应用市场:ToB评测及商务社交产业平台
»
论坛
›
数据库
›
Oracle
›
一文解说Redis为什么读写性能高以及I/O复用干系知识点 ...
一文解说Redis为什么读写性能高以及I/O复用干系知识点 ...
曹旭辉
金牌会员
|
6 天前
|
显示全部楼层
|
阅读模式
楼主
主题
829
|
帖子
829
|
积分
2487
Redis为什么读写性能高呢?
Redis 的速度⾮常快,单机的 Redis 就可以⽀撑每秒十几万的并发,性能是 MySQL 的⼏⼗倍。缘故原由主要有⼏点:
①、
基于内存的数据存储
,Redis 将数据存储在内存当中,使得数据的读写操作避开了磁盘 I/O。而内存的访问速度远超硬盘,这是 Redis 读写速度快的根本缘故原由。
②、
单线程模型
,Redis 使用单线程模型来处理客户端的请求,这意味着在任何时刻只有一个命令在执行。这样就制止了线程切换和锁竞争带来的斲丧。
③、
IO 多路复⽤
,基于 Linux 的 select/epoll 机制。该机制允许内核中同时存在多个监听套接字和已连接套接字,内核会一直监听这些套接字上的连接请求大概数据请求,一旦有请求到达,就会交给 Redis 处理,就实现了所谓的 Redis 单个线程处理多个 IO 读写的请求。
三分恶面渣逆袭:Redis使用IO多路复用和自身事件模型
④、
高效的数据结构
,Redis 提供了多种高效的数据结构,如字符串(String)、列表(List)、集合(Set)、有序集合(Sorted Set)等,这些数据结构颠末了高度优化,能够支持快速的数据操作。
顺带再补充下I/O多路复用的知识
IO 多路复用是一种高效管理多个 IO 事件的技术,通过单线程监控多个文件形貌符(fd),实现高并发的 IO 操作。
常见的 I/O 多路复用机制包括 select、poll 和 epoll 等。
特性selectpollepoll文件形貌符限定受 FD_SETSIZE 限定无限定无限定时间复杂度O(n)O(n)O(1)数据复制需要需要不需要工作方式线性扫描线性扫描事件通知内核支持全部 UNIX 体系全部 UNIX 体系Linux 2.6 及以上版本实用场景少量连接中等连接大量并发连接 好比说你是一名数学老师,上课时提出了一个问题:“今天谁来证明一下勾股定律?”
同学小王举手,你就让小王答复;小李举手,你就让小李答复;小张举手,你就让小张答复。
这种模式就是 IO 多路复用,你只需要在讲台上等,谁举手谁答复,不需要一个一个去问。
有盐老师:IO 多路复用
Redis 就是使用 epoll 这样的 I/O 多路复用机制,在单线程模型下实现高效的网络 I/O,从而支持高并发的请求处理。
举例子说一下 I/O 多路复用?
假设你是一个老师,让 30 个学生解答一道题目,然后检查学生做的是否正确,你有下面几个选择:
第一种选择:按次序逐个检查,先检查 A,然后是 B,之后是 C、D。。。这中心假如有一个学生卡住,全班都会被耽误。这种模式就好比,你用循环挨个处理 socket,根本不具有并发能力。
第二种选择:你创建 30 个分身,每个分身检查一个学生的答案是否正确。 这种类似于为每一个用户创建一个进程大概线程处理连接。
第三种选择,你站在讲台上等,谁解答完谁举手。这时 C、D 举手,表现他们解答问题完毕,你下去依次检查 C、D 的答案,然后继续回到讲台上等。此时 E、A 又举手,然后行止理 E 和 A。
第一种就是阻塞 IO 模型,第三种就是 I/O 复用模型。
图片来源于网络:多路复用模型
Linux 体系有三种方式实现 IO 多路复用:select、poll 和 epoll。
比方 epoll 方式是将用户 socket 对应的 fd 注册进 epoll,然后 epoll 帮你监听哪些 socket 上有消息到达,这样就制止了大量的无用操作。此时的 socket 应该采用非阻塞模式。
这样,整个过程只在举行 select、poll、epoll 这些调用的时候才会阻塞,收发客户消息是不会阻塞的,整个进程大概线程就被充实利用起来,这就是事件驱动,所谓的 reactor 模式。
select、poll 和 epoll 的实现原理?
select 使用位图管理 fd,每次调用都需要将 fd 集合从用户态复制到内核态。最大支持 1024 个文件形貌符。
poll 使用动态数组管理 fd,突破了 select 的数量限定。
epoll 使用红黑树和链表管理 fd,每次调用只需要将 fd 集合从用户态复制到内核态一次,不需要重复复制。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
曹旭辉
金牌会员
这个人很懒什么都没写!
楼主热帖
网络安全应急响应 - 03 - 日志分析与内 ...
Mysql 的Innodb引擎和Myisam数据结构和 ...
Redis - 介绍与使用场景
【docker系列】docker API管理接口增加 ...
Nmap抓包分析与绕过Windows防火墙 ...
微服务架构演进
一招教你如何高效批量导入与更新数据 ...
聊聊Spring事务控制策略以及@Transacti ...
谈了千百遍的数据一致性
ArcToolBox-ArcGIS分析工具中英文对照 ...
标签云
挺好的
服务器
快速回复
返回顶部
返回列表