epoll_socket

背景

通常来说,实现处理tcp请求,为一个连接一个线程,在高并发的场景,这种多线程模型与Epoll相比就显得相形见绌了。epoll是linux2.6内核的一个新的系统调用,epoll在设计之初,就是为了替代select, poll线性复杂度的模型,epoll的时间复杂度为O(1), 也就意味着,epoll在高并发场景,随着文件描述符的增长,有良好的可扩展性。

参考

epoll原理
epoll触发模式
对于触发模式重点,可以总结为下

如果对于一个非阻塞 socket,如果使用 epoll 边缘模式去检测数据是否可读,触发可读事件以后,一定要一次性把 socket 上的数据收取干净才行,也就是说一定要循环调用 recv 函数直到 recv 出错,错误码是EWOULDBLOCK(EAGAIN 一样)(此时表示 socket 上本次数据已经读完);如果使用水平模式,则不用,你可以根据业务一次性收取固定的字节数,或者收完为止

例子

/*************************************************************************> File Name: epollsvr.c> Author: ycj> Mail: 1484541288@qq.com > Created Time: 2024年01月24日 星期三 16时33分07秒************************************************************************/#include<stdio.h>
#include <fcntl.h>
#include <stdlib.h>
#include <stdbool.h>
#include <string.h>
#include <errno.h>
#include <assert.h>
#include <unistd.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <sys/epoll.h>#define NAME_LEN 50
#define MAX_CLIENTS 100int size = 0;int init_server(const char* ip,unsigned short int port){int fd = socket(AF_INET,SOCK_STREAM,0);assert(fd != -1);int oldSocketFlag = fcntl(fd,F_GETFL,0);int newSocketFlag = oldSocketFlag | O_NONBLOCK;assert(fcntl(fd,F_SETFL,newSocketFlag) != -1);struct sockaddr_in addr = {};addr.sin_family = AF_INET;addr.sin_port = htons(port);addr.sin_addr.s_addr = inet_addr(ip);socklen_t addrlen = sizeof(addr);int ret = bind(fd,(const struct sockaddr*)&addr,addrlen);assert(ret != -1);ret = listen(fd,MAX_CLIENTS);assert(ret != -1);return fd;
}void accept_client(int fd,int epfd){struct sockaddr_in addr = {};socklen_t len = sizeof(addr);int cfd = accept(fd,(struct sockaddr*)&addr,&len);assert(cfd != -1);int oldSocketflag = fcntl(cfd,F_GETFL,0);int newSocketFlag = oldSocketflag | O_NONBLOCK;assert(fcntl(fd,F_SETFL,newSocketFlag) != -1);struct epoll_event event ={};event.events = EPOLLIN;event.data.fd = cfd;int ret = epoll_ctl(epfd,EPOLL_CTL_ADD,cfd,&event);assert(ret != -1);
}void select_fd(int fd){int epfd = epoll_create(MAX_CLIENTS);if(epfd == -1){perror("epoll_create");return;}struct epoll_event event = {};event.events = EPOLLIN;//event.events |= EPOLLET;event.data.fd = fd;int ret = epoll_ctl(epfd,EPOLL_CTL_ADD,fd,&event);if(ret == -1){perror("epoll_ctl");return;}while(true){struct epoll_event events[MAX_CLIENTS+1] = {};int i;ret = epoll_wait(epfd,events,MAX_CLIENTS+1,-1);if(ret == -1){perror("epoll_wait");break;}for(i=0;i<ret;i++){if(events[i].events & EPOLLIN){if(events[i].data.fd == fd){accept_client(fd,epfd);}else{char msg[1024] = {};ret = recv(events[i].data.fd,msg,1024,0);if(ret <= 0){ret = epoll_ctl(epfd,EPOLL_CTL_DEL,events[i].data.fd,NULL);assert(ret != -1);}else{printf("msg : %s\n",msg);}}}else if(events[i].events & EPOLLOUT){if(events[i].data.fd != fd)printf("input msg...\n");}else{//....}}}
}int main(int argc,char *argv[]){if(argc < 3){printf("%s ip port\n",argv[0]);return -1;}int fd = init_server(argv[1],atoi(argv[2]));select_fd(fd);close(fd);return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/644269.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue3中的自定义Hooks

为什么要使用Hooks&#xff1f; 组件复用性更强&#xff1a;通过Hooks可以使得组件的一些逻辑可以更好地进行封装和复用 更好的逻辑分离。Hooks有助于组件内的业务逻辑更加清晰明了&#xff0c;从而减少代码耦合度。 更高的代码可读性。使用Hooks使得函数组件的可读性更高&am…

【论文阅读|2024 WACV 多目标跟踪Deep-EloU】

论文阅读|2024 WACV 多目标跟踪Deep-EloU 摘要1 引言&#xff08;Introduction&#xff09;2 相关工作&#xff08;Related Work&#xff09;2.1 基于卡尔曼滤波器的多目标跟踪算法&#xff08;Multi-Object Tracking using Kalman Filter&#xff09;2.2 基于定位的多目标跟踪…

vue2 KeepAlive实操

需求 列表->详情 —缓存列表详情->列表 — 恢复列表缓存其他->列表 —不缓存列表 1. 注册eventbus Vue.prototype.$eventBus new Vue();2. 视图文件 <keep-alive :include"cacheList"><router-view></router-view> </keep-alive&…

一篇博客读懂排序

目录 一、常见的排序 二、冒泡排序 2.1基本思想&#xff1a; 2.2代码&#xff1a; 三、插入排序 3.1基本思想&#xff1a; 3.2思路讲解&#xff1a; 3.3代码&#xff1a; 3.4时间复杂度&#xff1a; 四、希尔排序 4.1基本思路&#xff1a; 4.2思路讲解&#xff1a;…

android 防抖工具类,经纬度检查工具类

一&#xff1a;点击事件防抖工具类&#xff1a; public abstract class ThrottleClickListener implements View.OnClickListener {private long clickLastTimeKey 0;private final long thresholdMillis 500;//millisecondsOverridepublic void onClick(View v) {long curr…

微信小程序如何获取当前日期时间

Hello大家好&#xff01;我是咕噜铁蛋&#xff0c;获取当前日期时间是小程序中经常会用到的一个功能。因此&#xff0c;在本文中&#xff0c;我通过科技手段给大家收集整理了下&#xff0c;今天我将向大家介绍如何在微信小程序中获取当前日期时间的方法&#xff0c;并分享一些实…

nginx 实现动静分离

目录 nginx 实现动静分离 1.配置动静分离 nginx 实现动静分离 为了加快网站的解析速度&#xff0c;可以把动态页面和静态页面由不同的服务器来解析&#xff0c;加快解析速度。降低原来单个服务器的压力。 在动静分离的tomcat的时候比较明显&#xff0c;因为tomcat解析静态很慢…

Overleaf(LaTeX文档在线编写平台)使用学习记录

一、LaTeX简概[1] LaTeX&#xff0c;是一种基于TEX的排版系统&#xff0c;是一种可以处理排版和渲染的标记语言。由美国计算机科学家莱斯利兰伯特在20世纪80年代初期开发&#xff0c;利用这种格式系统的处理&#xff0c;即使用户没有排版和程序设计的知识也可以充分发挥由TEX所…

离零售业智能体时代的真正开启还有多远?

AIGC&#xff08;生成式人工智能&#xff09;当道的2023年&#xff0c;将LLM&#xff08;大语言模型&#xff09;的各类生成式能力发挥到淋漓尽致、精彩纷呈的程度。各行各业一边在观望大语言模型不断扩宽的商业运用可能&#xff0c;一边在继续探寻能够不断拓宽企业往纵深发展的…

Mybatis----缓存

MyBatis是一个流行的Java持久化框架&#xff0c;它提供了一个灵活的缓存机制来提高查询性能。 MyBatis的缓存机制主要分为一级缓存和二级缓存。 一级缓存是指在同一个SqlSession中&#xff0c;查询结果会被缓存起来&#xff0c;当再次执行同样的查询时&#xff0c;直接从缓存中…

基于SSM的企业文档管理系统

末尾获取源码作者介绍&#xff1a;大家好&#xff0c;我是何时&#xff0c;本人4年开发经验&#xff0c;专注定制项目开发 更多项目&#xff1a;CSDN主页YAML 我欲乘风归去 又恐琼楼玉宇 高处不胜寒 -苏轼 一、项目简介 现代经济快节奏发展以及不断完善升级的信息化技术&…

latex图文混排示例

\parbox[t]{0.7\textwidth}{ 本题属于利用信号量实现前驱的经典问题&#xff0c;操作C必须在A和B完成后执行&#xff0c; 操作E必须在C和D完成后执行&#xff0c;其执行顺序如右图所示。 定义同步信号量A、B、C、D&#xff0c;一开始四个操作都未执行&#xff…

深度了解TCP/IP模型

网络通信是现代社会不可或缺的一部分&#xff0c;而TCP/IP模型作为网络通信的基石&#xff0c;扮演着至关重要的角色。本文将深入探讨TCP/IP模型的概念、结构及其在网络通信中的作用&#xff0c;为读者提供全面的了解。 一.TCP/IP模型简介 TCP/IP模型是一个网络通信协议体系&a…

【Java并发编程的艺术学习】第七,八章摘要

原子更新基本类型类 1.原子操作类&#xff1a;多线程下的操作是安全的&#xff0c;不需要自己加锁 2.在原子类中不能用 - * / ,而是采用这些方法 AtomicBoolean&#xff1a;原子更新布尔型 AtomicInteger&#xff1a;原子更新整形 AtomicLong&#xff1a;原子更新长整型 …

怎样设计一个具有良好容灾性的系统架构?

设计一个具有良好容灾性的系统架构 当你的系统出现故障时&#xff0c;容灾性设计可以让你的系统保持高效运转&#xff0c;避免数据丢失和业务中断。那么&#xff0c;怎样设计一个具有良好容灾性的系统架构呢&#xff1f;让我来教你几招&#xff0c;不过在开始之前&#xff0c;…

机器学习 | 掌握Matplotlib的可视化图表操作

Matplotlib是python的一个数据可视化库&#xff0c;用于创建静态、动态和交互式图表。它可以制作多种类型的图表&#xff0c;如折线图、散点图、柱状图、饼图、直方图、3D 图形等。以渐进、交互式方式实现数据可视化。当然博主也不能面面俱到的讲解到所有内容&#xff0c;详情请…

【极数系列】Flink 初相识(01)

# 【极数系列】Flink 初相识&#xff08;01&#xff09; 引言 Flink官网&#xff1a;https://flink.apache.org/ Flink版本&#xff1a;https://flink.apache.org/blog/ Flink文档&#xff1a;https://ci.apache.org/projects/flink/flink-docs-release-1.12/ Flink代码库…

AI存在信任问题,区块链能提供帮助吗?

区块链的商业应用&#xff0c;比如供应链追踪&#xff0c;一直以来都没有取得成功。但有人表示&#xff0c;该技术可能作为一种验证人工智能算法的工具而找到其存在的价值。 确保人工智能算法的安全性、公正性和准确性的困难正使一些公司转向一种曾被吹捧为革命性但在商业领域…

轻松互换文件夹名,高效批量改名!高手工具助您一臂之力!

在日常工作中&#xff0c;我们经常需要处理大量的文件夹&#xff0c;有时候需要将文件夹名称互换或进行批量改名。这时&#xff0c;一款高效、实用的高手工具就能派上用场。它不仅能帮助您轻松实现文件夹名互换&#xff0c;还能快速批量改名&#xff0c;让您的工作更加高效、轻…

Unity - 角色控制

Test_05 角色控制 创建一个3D对象作为角色&#xff0c;添加 “CharacterController” 组件来控制角色移动&#xff0c;绑定脚本"PlayerControl"。 PlayerControl public class PlayerControl : MonoBehaviour {private CharacterController player;void Start(){p…