nginx与apache的比较

nginx

  • 轻量级,同样起web 服务,比apache 占用更少的内存及资源
  • 抗并发,nginx 处理请求是异步非阻塞的,而apache 则是阻塞型的,在高并发下nginx 能保持低资源、低消耗、高性能
  • 高度模块化的设计,编写模块相对简单

apache

  • rewrite(重写)功能比nginx 的rewrite 强大
  • 模块超多,基本想到的都可以找到
  • 少bug ,nginx 的bug 相对较多
  • 比nginx更稳定

同步、异步、阻塞和非阻塞

  • 同步:所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。
  • 异步:异步的概念和同步相对。当一个异步过程调用发出后,调用者不能立刻得到结果。实际处理这个调用的部件在完成后,通过状态、通知和回调来通知调用者。
  • 阻塞:阻塞调用是指调用结果返回之前,当前线程会被挂起。函数只有在得到结果之后才会返回。有人也许会把阻塞调用和同步调用等同起来,实际上它们是不同的。对于同步调用来说,很多时候当前线程还是激活的,只是从逻辑上当前函数没有返回而已。
  • 非阻塞:非阻塞和阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。

高并发

  • 高并发(High Concurrency)是互联网分布式系统架构设计中必须考虑的因素之一。它通常是指:通过设计保证系统能够同时并行处理很多请求。
  • 高并发常用指标:
    • 响应时间:系统对请求做出响应的时间。例如系统处理一个HTTP请求需要200ms,这个200ms就是系统的响应时间。
    • 吞吐量:单位时间内处理的请求数量。
    • QPS:每秒响应请求数。在互联网领域,这个指标和吞吐量区分的没有这么明显。
    • 并发用户数:同时承载正常使用系统功能的用户数量。例如一个即时通讯系统,同时在线量一定程度上代表了系统的并发用户数。

总结

  • 如果追求性能就选择nginx,如果想要更高的稳定性则可以考虑apache
  • Apache在处理动态有优势,Nginx并发性比较好,CPU内存占用低,如果rewrite频繁,则选择Apache
  • Nginx 配置简洁, Apache 复杂
  • Nginx 静态处理性能比 Apache 高 3倍以上
  • Apache 对 PHP 支持比较简单,Nginx 需要配合其他后端用
  • Apache 的组件比 Nginx 多
  • 最核心的区别在于apache是同步多进程模型,一个连接对应一个进程;nginx是异步的,多个连接(万级别)可以对应一个进程
  • nginx的负载能力强,静态处理性能高,可以用作前端负责进行抗并发、负载均衡、做静态文件缓存,apache相对稳定,可用作后端处理动态请求

参考链接:https://blog.csdn.net/wzqzhq/article/details/53302976.

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值