服务器中提高并发处理能力的方法:1.多进程,提高CPU并发度;2.减少使用不必要的锁,减少并发请求对于共享资源的竞争;3.减少进程切换,减少上下文切换次数;4.考虑减少内存分配和释放,减少中间临时变量的内存分配;
具体分析如下:
1.多进程
进程的操作可以对CPU时间进行轮流使用,对CPU的计算和IO操作重叠利用。多进程通过系统调用,使得CPU向网卡或者磁盘等I/O设备发出指令,然后进程被挂起,释放出CPU资源,等待I/O设备完成工作后通过中断来通知进程重新就绪。多进程不仅能提高CPU的并发度,其优越性还体现在独立的内存地址空间和生命周期所带来的稳定性和健壮性,其中一个进程崩溃不会影响到另一个进程。
2.减少使用不必要的锁
服务器处理大量并发请求时,多个请求处理任务时存在一些资源抢占竞争,这时一般采用“锁”机制来控制资源的占用。当一个任务占用资源时,我们锁住资源,这时其它任务都在等待锁的释放,这个现象称为锁竞争。通过锁竞争的本质,我们要意识到尽量减少并发请求对于共享资源的竞争。在允许情况下关闭服务器访问日志,这可以大大减少在锁等待时的延迟时间。要最大程度减少无辜的等待时间。
3.减少进程切换
当硬件上下文频繁装入和移出时,为了尽量减少上下文切换次数,最简单的做法就是减少进程数,尽量使用线程并配合其它I/O模型来设计并发策略。还可以考虑使用进程绑定CPU技术,增加CPU缓存的命中率。
4.考虑减少内存分配和释放
服务器的工作过程中,需要大量的内存,使得内存的分配和释放工作尤为重要。可以通过改善数据结构和算法复制度来适当减少中间临时变量的内存分配及数据复制时间,而服务器本身也使用了各自的策略来提高效率。
网友留言: