TCP并发服务器

在之前我们写过单循环服务器:同一时刻只能处理一个客户端任务

并发服务器则是在同一时刻,能够处理多个客户端的任务

一、实现方法

1、多进程

安全性好。

2、多线程

并发量更高、高效。

3、IO多路复用

二、IO模型

1、阻塞IO

阻塞函数:fgets、scanf、read、recv、getchar等。

特点:

(1)实现多个IO同步的效果;(有先后顺序)

(2)CPU占有率低。

2、非阻塞IO

特点:

(1)使用轮询的方式实现,可监测多路复用。

(2)CPU占有率高。

实现:

(1)获得原文件描述符的属性;

(2)增加非阻塞属性;fcntl

int fcntl(int fd , int cmd , ...)

参数:cmd为F_GETFL(获得) 、F_SETFL(设置) 、F_SETOWN(关联)等。

(3)设置新属性。

例如;非阻塞的读管道。

3、信号驱动IO

特点:

(1)实现异步IO操作,节省CPU开销。

(2)只能监测少量IO。

实现:

(1)增加异步属性;

(2)关联当前进程;

(3)注册信号处理函数。

例如:信号驱动的读管道。

相关推荐
7***n7516 分钟前
API网关设计模式
linux·服务器·设计模式
国服第二切图仔1 小时前
检测隧道HTTP代理的可用性的几种方法
网络·网络协议·http
托尼吴1 小时前
REST RPC dubbo,HSF 协议总结
网络协议·rpc·dubbo
JH30731 小时前
引依赖包和对这个包发起rpc调用有什么区别
网络·网络协议·rpc
zzzsde2 小时前
【Linux】基础开发工具(1):软件包管理器&&vim编辑器
linux·运维·服务器
tan180°2 小时前
Linux网络TCP(上)(11)
linux·网络·c++·后端·tcp/ip
程序员小单2 小时前
WebSocket 与 Spring Boot 整合实践
spring boot·websocket·网络协议
橘子真甜~2 小时前
C/C++ Linux网络编程6 - poll解决客户端并发连接问题
服务器·c语言·开发语言·网络·c++·poll
zwm_yy3 小时前
服务器检查内存爆满
运维·服务器
摩尔元数3 小时前
2025,服务器通信MES厂商谁主沉浮?
运维·服务器