文章目录
- 一、提高并发能力必须解决的问题
- 1、如何提高并发连接数?
- 2、那么多的连接数怎么进行业务处理?
- 3、应用服务器的处理水平又该怎么提高?
- (1)代码中的业务逻辑
- (2)数据库的压力
- 二、高性能服务端编程框架
一、提高并发能力必须解决的问题
1、如何提高并发连接数?
能不能接受高并发连接,主要是取决于accept的速度。一个TCP连接的建立,要在客户端和服务端之间,完成三次握手,然后连接会被放到完成队列中,accept从完成队列中取出连接并返回。任何影响accept取连接的因素,都会影响并发度。一般策略是:独立处理accept或者使用epoll处理accept。
2、那么多的连接数怎么进行业务处理?
nginx只是具有反向代理和负载均衡的功能,并不能处理具体的业务逻辑,不能担当应用服务器来使用,但是可以利用nginx将接受到的大量连接通过均衡的方式(轮询,权重,hash)分配到不同的应用服务器(聊天服务器、文件服务器等等)中进行业务处理!
3、应用服务器的处理水平又该怎么提高?
要提高应用服务器的处理水平就要了解自己的应用服务器的瓶颈在哪里,一般有两个:
(1)代码中的业务逻辑
总的来说少创建线程(使用线程池)、少创建对象、少加锁(使用原子操作)、防止死锁、注意内存回收等策略,来提升代码性能。
(2)数据库的压力
使用缓存、建立有效索引、读写分离、双主互备、分库分表等策略,提高数据库处理能力,减少压力!
二、高性能服务端编程框架
参考:http://www.cppblog.com/ecopgm/archive/2008/03/24/45314.aspx
http://www.cppblog.com/humanchao/archive/2014/05/19/207019.html