nginx和apache的区别,选择哪个好?

nginx和apache的区别,选择哪个好?Apache和Nginx最核心的区别在于apache是同步多进程模型,一个连接对应一个进程;而nginx是异步的,多个连接(万级别)可以对应一个进程。下面本篇文章就来给大家介绍一下Apache和Nginx的区别有那些,选择哪个好?希望对你们有所帮助。一、Nginx特点  1、轻量级,采用C进行编写,同样的web服务,会占用更少的内存及资源。  2、抗并发,nginx以epollandkqueue作为开发模型,处理请求是异步非阻塞的,负载能力比apache高很多,而apache则.

大家好,又见面了,我是你们的朋友全栈君。

Apache和Nginx最核心的区别在于 apache 是同步多进程模型,一个连接对应一个进程;而 nginx 是异步的,多个连接(万级别)可以对应一个进程。下面本篇文章就来给大家介绍一下Apache和Nginx的区别有那些,选择哪个好?希望对你们有所帮助。 

一、Nginx特点

  1、轻量级,采用C进行编写,同样的web服务,会占用更少的内存及资源。

  2、抗并发,nginx以epollandkqueue作为开发模型,处理请求是异步非阻塞的,负载能力比apache高很多,而apache则是阻塞型的。在高并发下nginx能保持低资源低消耗高性能,而apache在php处理慢或者前端压力很大的情况下,很容易出现进程数飙升,从而拒绝服务的现象。 

  3、nginx在开启时,会生成一个master进程,然后,master进程会fork多个worker子进程,最后每个用户的请求由worker的子线程处理。 

  4、可以配置nginx的upstream实现nginx的反向代理。 

  5、nginx作为负载均衡服务器,支持7层负载均衡。 

  6、nginx处理静态文件好,静态处理性能比apache高三倍以上。

  7、支持高并发连接,每秒最多的并发连接请求理论可以达到50000个。 

  8、nginx配置简洁,正则配置让很多事情变得简单,而且改完配置能使用-t测试配置有没有问题,apache配置复杂,重启的时候发现配置出错了,会很崩溃。 

  9、用线程处理用户请求,而线程是共享内存的,只需要开启少量进程,多个线程就可以共享进程的内存,占用内存小。 

  10、一个进程死掉时,会影响到多个用户的使用,稳定性差。

  11、nginx的设计高度模块化,编写模块相对简单。

  12、nginx本身就是一个反向代理服务器,而且可以作为非常优秀的邮件代理服务器。

  13、启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动,还能够不间断服务的情况下进行软件版本的升级。

  14、社区活跃,各种高性能模块出品迅速。

 

 

二、Apache特点 

  1、select同步阻塞。

  2、一个连接对应一个进程。

  3、用进程处理用户请求,用MPM(多处理模块)来绑定到网络端口上,接受请求,调度子进程处理请求。

  4、当用户请求过多时,开启的进程较多,占用内存大,每秒最多的并发连接请求最多不超过3000个。

  5、一个进程死掉时,不会影响其他的用户

  6、apache的rewrite比nginx强大,在rewrite频繁的情况下,用apache。 

  7、apache发展到现在,模块超多,基本想到的都可以找到。 

  8、apache更为成熟,少bug,nginx的bug相对较多。 

  9、apache超稳定。 

  10、apache对php支持比较简单,nginx需要配合其他后端用。 

  11、apache在处理动态请求有优势,一般动态请求要apache去做,nginx适合静态和反向。

  12、apache仍然是目前的主流,拥有丰富的特性,成熟的技术和开发社区。

两者最核心的区别在于apache是同步多进程模型,一个连接对应一个进程,而nginx是异步的,多个连接(万级别)可以对应一个进程。一般来说,需要性能的web服务,用nginx。如果不需要性能只求稳定,更考虑apache,apache的各种功能模块实现比nginx好,例如ssl的模块就比nginx好,可配置项多。epoll(freebsd上是kqueue)网络IO模型是nginx处理性能高的根本理由,但并不是所有的情况下都是epoll大获全胜的,如果本身提供静态服务的就只有寥寥几个文件,apache的select模型或许比epoll更高性能。当然,这只是根据网络IO模型的原理作的一个假设,真正的应用还是需要实测。更为通用的方案是,前端nginx抗并发,后端apache集群,配合起来会更好。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142034.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月24日 下午4:20
下一篇 2022年5月24日 下午4:20


相关推荐

  • ms17010复现

    ms17010复现关于漏洞的复现干多了就发现,这种菜鸟级别的复现,,真是没有啥实用性,主要就是,自己玩玩,,,唉,,  ms17_010,好像跟什么永恒之蓝,勒索病毒有啥关系。但是,我这种小白可管不着,而且现在做的所有的复现都是基于防火墙关闭,所以,没有啥技术,复现也白复现。。。。 好了,还是讲复现: 搜索:search17_010很容易看出来,这个第一个方法是搜索网段中主机漏洞的,

    2022年6月6日
    58
  • 我的车辆过户办理经历分享(深圳市内过户)[通俗易懂]

    我的车辆过户办理经历分享(深圳市内过户)

    2022年4月8日
    202
  • Java中常用的API[通俗易懂]

    Java中常用的API[通俗易懂]1.Calendar类(日期与时间处理)使用情况:publicstaticvoidmain(String[]args){Calendarc=Calendar.getInstance();intyear=c.get(Calendar.YEAR);intmonth=c.get(Calendar.MONTH)+1;intday=c.get(Calendar.DATE);intweek

    2022年7月8日
    25
  • 动态路由协议

    动态路由协议一 动态路由 1 1 动态路由基础 1 1 1 动态路由基于某种路由协议实现 1 1 2 动态路由特点 1 减少了管理任务 2 占用了网络带宽 1 2 动态路由协议 1 2 1 概述路由器之间用来交换信息的语言 1 2 2 度量值 1 跳数 跳数度量可以简单地记录路由器的跳数 2 带宽 带宽度量将会选择高带宽路径 而不是低带宽路径

    2026年3月20日
    1
  • centos frp内网穿透_内网穿透 无需公网ip

    centos frp内网穿透_内网穿透 无需公网ip说明Linux搭建frp实现内网穿透操作步骤安装步骤省略(下载解压拷贝到server服务器和client服务器完事)具体移步:github注意程序文件需要追加可执行权限!注意相关端口放行!服务端配置文件:frps.ini[common]bind_port=7777authentication_method=tokentoken=12345678tls_only=truekcp_bind_port=7777max_pool_count=10l

    2025年11月5日
    3
  • 高并发高可用高性能的解决方案汇总整理

    高并发高可用高性能的解决方案汇总整理高并发高可用高性能的解决方案汇总整理

    2022年4月22日
    60

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号