服务器性能提高建议

来源:互联网 发布:签名设计软件 编辑:程序博客网 时间:2024/06/08 13:40

这些天在看游双的高性能服务器编程这本书,总结下如何提高服务器性能:

 1、服务器的本身的硬件资源,比如cpu的个数、速度、内存大小等,这是硬件资源方面

软件资源方面:

1、使用线程池和进程池,传统的处理流程是监听线程监听有没有新的用户连接服务器, 每当有一个新的 用户进入, 服务器就开启一个新的线程用户处理这 个用户的数据包。这个线程只服务于这个用户 , 当 用户与服务器端关闭连接以后, 服务器端销毁这个线程。然而频繁地开辟与销毁线程极大地占用了系统的资源。而且在大量用户的情况下, 系统为了开辟和销毁线程将浪费大量的时间和资源。线程池提供了一个解决外部大量用户与服务器有限资源的矛盾, 线程池和传统的一个用户对应一 个线程的处理方法不同, 它的基本思想就是在程序 开始时就在内存中开辟一些线程, 线程的数目是 固定的,他们独自形成一个类, 屏蔽了对外的操作, 而服务器只需要将数据包交给线程池就可以了。

2、使用连接池。网络编程中链接的概念很重要,客户端与服务器连接的过程中花费的时间比较长,主要是三次握手过程花费较长时间。当并发数量大的时候,如果来一个客户建立一条连接来一个客户建立一条连接,必然会导致一定的延时,如果对那些实时性要求比较的的应用,显然容易遇到瓶颈,这个时候可以使用连接池,事先建立起n个连接,当客户端需要时,直接从连接池分配,能大大提高效率。

3、减少不必要的数据复制。尤其是复制发生在内核与用户代码之间时。

4、考虑上下文切换的问题。进程间或者线程间的切换会导致系统开销,过多的会占用大量的CPU时间,导致CPU利用率低。

5、慎重使用锁。对于共享资源我们需要加锁保护,但是锁也是导致服务器降低的一个原因,锁只是锁住一些资源,但是不处理业务逻辑,而且还需要访问内核的资源,所以能不用锁尽量不用。


0 0
原创粉丝点击