socket通信---并发服务器图解
来源:互联网 发布:mock.js 文档 编辑:程序博客网 时间:2024/06/06 01:19
当服务器处理一个客户请求可能需要相当长一段时间的时候,使用迭代服务器模式(即整个服务器可能被耽搁客户长期占用)是会影响系统性能的。而处理并发连接的服务器可以称为并发服务器。
并发服务器的一个简单操作是fork一个子进程来服务多个客户。当一个连接建立时,用于阻塞进程的aceept返回,服务器接着调用fork来创建一个子进程,该子进程通过已连接套接口connfd服务客户;而父进程就可以通过监听套接口来等待另外一个连接,同时该关闭已连接套接口。
如下是具体连接过程:
(1)服务器阻塞于accept调用且来自客户的连接请求到达时的客户端与服务器的状态。
(2)从accept返回后,连接已经在内核中注册,并且新的套接口connfd被创建。这是一个已建起连接的套接口,可以进行数据的读写。
(3)并发服务器在调用fork之后,listenfd和connfd这两个描述字在父进程以及子进程之间共享(实际为其中一份为copy),各自的引用计数为变成2.
(4)接下来是由父进程关闭已连接套接口(connfd),由子进程关闭监听套接口(listenfd)。进行这个操作之后,那么就可以让子进程来处理与客户的连接,而父进程可以在监听套接口上再次调用accept来处理下一个客户的连接。
- socket通信---并发服务器图解
- socket通信---并发服务器图解
- socket通信---并发服务器图解和阻塞通信图解
- socket通信---并发服务器图解和阻塞通信图解
- Linux socket通信——并发服务器(fork)
- socket服务器并发处理
- Android socket服务器通信
- socket单向通信 服务器
- socket并发服务器(frok)
- socket 并发服务器 多线程模式
- SOCKET 服务器和客户端通信
- socket服务器客户端通信乱码
- Lua 服务器Socket通信实例
- Android与服务器Socket通信
- PHP Socket客户端服务器通信
- Internet通信3-Socket服务器
- Socket客户端,服务器通信demo
- socket多线程服务器网络通信
- ffmpeg+cygwin顺利编译
- c++builder数据导出到excel中的问题
- Gstreamer 工具使用(二)
- JS锁屏
- GTK+ study (2) Cairo和GTK+用户自定义控件
- socket通信---并发服务器图解
- Big-endian 与 Little-endian
- Bellman-Ford算法详讲
- 本地证书申请失败分析--手工证书请求失败
- 代码阅读
- Oracle产生随机数
- DataSet (1)
- rtems bsp编译cortex-m3指令时遇到的问题
- 单据模板数值型字段千分位分割