多进程,多线程的编程是高性能服务器编程的重点,
多进程编程:父进程负责监听、并接受客户连接(accept),fork() 创建子进程,子进程处理与客户端通讯。
多进程编程中父子进程共享文件描述符,父进程不需要将接收的链接文件的文件描述符传递个子进程。
父进程要关闭链接的文件描述符,如果父进程不关闭文件描述符,后续创建的子进程会将所有的文件描述符继承下来,后续的链接的文件的文件描述符不断增大,链接客户端的数量就受到一个进程最多打开的文件描述符数目的限制。
多线程编程:主线程负责监听,并接受客户端的链接,函数线程负责和客户端通讯。
主线程接受连接,链接的文件描述符必须通过创建函数线程时值传递给函数线程,主线程不能关闭文件描述符。
多线程的优势:
- 多线程相比于多进程对资源的消耗相对较小。
- 线程之间数据共享会更加容易
- 线程结束释放的资源比较少