PHP 多进程和多线程的优缺点

来源:互联网 发布:易语言在线播放器源码 编辑:程序博客网 时间:2024/06/05 18:42

多进程

使用多进程, 子进程结束以后, 内核会负责回收资源

使用多进程, 子进程异常退出不会导致整个进程Thread退出. 父进程还有机会重建流程.

一个常驻主进程, 只负责任务分发, 逻辑更清楚.

多进程方式更加稳定,另外利用进程间通信(IPC)也可以实现数据共享。

共享内存,这种方式和线程间读写变量是一样的,需要加锁,会有同步、死锁问题。

消息队列,可以采用多个子进程抢队列模式,性能很好

多线程

线程是在同一个进程内的,可以共享内存变量实现线程间通信

线程比进程更轻量级,开很大量进程会比线程消耗更多系统资源

多线程也存在一些问题:

线程读写变量存在同步问题,需要加锁

锁的粒度过大存在性能问题,可能会导致只有1个线程在运行,其他线程都在等待锁

同时使用多个锁,逻辑复杂,一旦某个锁没被正确释放,可能会发生线程死锁

某个线程发生致命错误会导致整个进程崩溃

参考 http://blog.csdn.net/lijingshan34/article/details/70244142

原创粉丝点击