后端开发【干货知识】—Redis,Memcached,Nginx 网络组件
reator 网络编程
epoll 被称为事件管理器,利用管理器去管理多个连接。
关闭读端 read = 0
关闭写端 write = -1 && errno =EPIPE
data:image/s3,"s3://crabby-images/93055/93055ef09af71874abd4b2c8ad74e33a3bef2c8d" alt=""
data:image/s3,"s3://crabby-images/8007b/8007bacada37d72af8f45db6789241bd6a0cbe09" alt=""
data:image/s3,"s3://crabby-images/f028d/f028d26090a91aa5f9376caf7d8d375a9d1e5f8d" alt=""
io 函数像 read 只能检测一个 fd 对应的状态,可以检测具体的状态。
io 多路复用可以检测多个 fd 对应的状态,只能检测可读,可写,错误,断开笼统等信息。
getsockopt 也可以检测错误。
阻塞 IO 和 非阻塞 IO
阻塞在网络线程
连接的 fd 阻塞属性决定了 io 函数是否阻塞
具体差异在:io 函数在数据未到达时是否立刻返回。
data:image/s3,"s3://crabby-images/c73e1/c73e110f0473dd79c7450ecfdede3beae5243f81" alt=""
data:image/s3,"s3://crabby-images/52d5d/52d5dddae7d1397a8235af9853f515c9ceeba7ad" alt=""
data:image/s3,"s3://crabby-images/00935/00935213997f37addb8e3c75339586fd43a5b659" alt=""
timeout == 0 是非阻塞效果,检测一下立即返回。
timeout == -1 是永久阻塞
timeout == 1000
data:image/s3,"s3://crabby-images/0f1dc/0f1dc0c5c1f7b5fb65a4f0d64e2ab8cb3bf1bcee" alt=""
data:image/s3,"s3://crabby-images/0b68a/0b68aff7ccccfec80da42b47bd21645ecb4a3ae0" alt=""
C++开发学习地址:C/C++Linux服务器开发高级架构师/Linux后台架构师
想学习 C++工程化、高性能及分布式、深入浅出。性能调优、TCP,协程,Nginx 源码分析 Nginx,ZeroMQ,MySQL,Redis,MongoDB,ZK,Linux 内核,P2P,K8S,Docker,TCP/IP,协程,DPDK 以下视频学习资料有需要的可以点击:C++架构师学习资料 进去自取
data:image/s3,"s3://crabby-images/ec213/ec2133cebceaae84d41c267d117885e83a856b51" alt=""
epoll_create 会去创建红黑树和就绪队列。
epoll_ctl 会去注册事件,会建立回调关系。当事件被触发,epoll_ctl 会将 fd 从红黑树中放到就绪队列。
data:image/s3,"s3://crabby-images/d0e52/d0e522b84ae15980419876d07695e63fe4182374" alt=""
data:image/s3,"s3://crabby-images/2f3ec/2f3ec470635b47c51e9550a07a430f569f13c715" alt=""
问:代码第 9 行能不能监听写事件?
答:不能,因为刚开始的时候,写缓冲区是空的,会被一直触发可写。
编程细节,返回值以及错误码
data:image/s3,"s3://crabby-images/6b71c/6b71cc0a1e03f9dc82fdb8c27331160fdfce9ec1" alt=""
读端关闭了。
data:image/s3,"s3://crabby-images/c600f/c600fd700a23b4b293b3723a57c1463606014760" alt=""
建议 read()函数使用非阻塞 io,因为出现错误会立刻返回,不会卡在这里影响别人。
data:image/s3,"s3://crabby-images/db30c/db30c3a460078a667fdd236f53aa314bb13e07a5" alt=""
将数据写到缓冲区,协议栈会将数据发送到对端。
redis、nginx、memcached reactor 具体使用
data:image/s3,"s3://crabby-images/4d529/4d52952190850dfdbfd9f1a49b052325133f2472" alt=""
data:image/s3,"s3://crabby-images/30243/30243a2c602cc487091cbb49b2fe4f1e1aa85713" alt=""
data:image/s3,"s3://crabby-images/0d27b/0d27b4a83d76bb32d4fb387112fbbf24e4669871" alt=""
redis-6.0 支持 IO 多线程,封装在 networking.cz 中。
data:image/s3,"s3://crabby-images/070fe/070fe2b029cf89daf2ef2cbe3fcb650b07be64bf" alt=""
参考资料
推荐一个零声学院免费公开课程,个人觉得老师讲得不错,分享给大家:Linux,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK等技术内容,立即学习
评论