客户端 - 服务器架构中的连接处理策略
在客户端 - 服务器架构中,处理多个客户端连接是一个重要的问题。本文将介绍几种常见的处理策略,包括多路复用、分叉(forking)和预分叉(preforking),并给出相应的代码示例。
1. 测试客户端编译与运行
测试客户端可以使用以下命令进行编译:
$>gcc -o client client.c
运行客户端并创建五个子进程,每个子进程连接到服务器:
$>./client 5
2. 多路复用(Multiplexing)
多路复用是一种在单个服务器进程中处理多个客户端连接的方法。服务器将客户端连接添加到一个监视列表(watch list)中,操作系统会通知服务器哪些客户端需要服务或是否有新的客户端连接。
可以将其类比为一家只有一个服务员的餐厅。服务员负责同时照顾所有桌子,顾客进来就座后,服务员将他们添加到脑海中的桌子列表中。当某张桌子需要注意时,服务员就去服务它。当然,一次只能服务一张桌子,并且有可能一张桌子会占用服务员的所有时间。
2.1 select() 函数
select() 是一个系统函数,允许我们指定一组感兴趣的描述符(如套接字)。该函数会使程序进入睡眠状态,轮询套接字的活动,并在其中一个套接字发生事件时唤醒程序。其函数原型如下:
超级会员免费看
订阅专栏 解锁全文

被折叠的 条评论
为什么被折叠?



