如何编写高性能服务端程序

本文转发来自:https://blog.csdn.net/daaikuaichuan/article/details/89481184

一、提高并发能力必须解决的问题

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
https://blog.csdn.net/moyuer91/article/details/51169544

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值