![](https://img-blog.csdnimg.cn/20201014180756919.png?x-oss-process=image/resize,m_fixed,h_64,w_64)
网络编程
多栖码农
喜欢研究底层源码,不定期创作和分享,喜欢的点点关注。
路很长,长到没时间回头;路很短,短到需要反复的走。
历史的标签无法标注多样的人生,清醒的人生无需被标签界定。
展开
-
Websocket理解
一、websocket与http WebSocket是HTML5出的东西(协议),也就是说HTTP协议没有变化,或者说没关系,但HTTP是不支持持久连接的(长连接,循环连接的不算) 首先HTTP有 1.1 和 1.0 之说,也就是所谓的 keep-alive ,把多个HTTP请求合并为一个,但是 Websocket 其实是一个新协议,跟HTTP协议基本没有关系,只是为了兼容现有浏览器的转载 2017-01-08 11:54:49 · 285 阅读 · 0 评论 -
epoll的本质(1)
要让读者清晰明白EPOLL为什么性能好。 本文会从网卡接收数据的流程讲起,串联起CPU中断、操作系统进程调度等知识;再一步步分析阻塞接收数据、select到epoll的进化过程;最后探究epoll的实现细节。目录: 一、从网卡接收数据说起 二、如何知道接收了数据? 三、进程阻塞为什么不占用cpu资源? 四、内核接收网络数据全过程 五、同时监视多个socket的简单方法 六、epoll的设计思路...转载 2019-05-23 19:37:30 · 180 阅读 · 0 评论 -
epoll的本质 (2)
上篇回顾 一、从网卡接收数据说起 二、如何知道接收了数据? 三、进程阻塞为什么不占用cpu资源? 四、内核接收网络数据全过程 这一步,贯穿网卡、中断、进程调度的知识,叙述阻塞recv下,内核接收数据全过程。 如下图所示,进程在recv阻塞期间,计算机收到了对端传送的数据(步骤①)。数据经由网卡传送到内存(步骤②),然后网卡通过中断信号通知cpu有数据到达,cpu执行中断程序(步骤...转载 2019-05-23 19:39:12 · 130 阅读 · 0 评论 -
epoll的本质 (3)
上篇回顾 四、内核接收网络数据全过程 五、同时监视多个socket的简单方法 六、epoll的设计思路 七、epoll的原理和流程 本节会以示例和图表来讲解epoll的原理和流程。 创建epoll对象 如下图所示,当某个进程调用epoll_create方法时,内核会创建一个eventpoll对象(也就是程序中epfd所代表的对象)。eventpoll对象也是文件系统中的一员,和soc...转载 2019-05-23 19:40:42 · 153 阅读 · 0 评论