ginx 有一个主进程和其他子进程。主进程的主要工作是加载和执行配置文件,并且驻留在子进程。子进程用来作为实际的请求处理。nginx 采取基于事件的模型和 OS 依赖的机制,在多个子进程之间高效的分配请求。子进程的个数会直接写在配置文件中并且,对于给定的配置可以是固定的,或者根据可用的 CPU 核数自动地进行调整(参考子进程)。 nginx 和它模块的工作方式是在配置文件中写好的。默认情况下,这个配置文件通常命名为 nginx.conf 并且会放置在 /usr/local/nginx/conf,/etc/nginx,或者 /usr/local/etc/nginx。
一、nginx 功能介绍
Nginx因为它的稳定性、丰富的模块库、灵活的配置和低系统资源的消耗而闻名.业界一致认为它是Apache2.2+mod_proxy_balancer的轻量级代替者,不仅因为响应静态页面的速度非常快,而且它的模块数量是Apache的2/3。对proxy和rewrite模块的支持很彻底,还支持mod_fcgi、ssl、vhosts ,适合用作mongrel clusters前端HTTP响应。
nginx和Apache一样用模块化设计,nginx模块包括内置模块和第三方模块,其中内置模块中包含主模块和事件模块。
nginx处理请求逻辑图
二、nginx可以提供的服务
常用来提供静态Web服务的软件
u Apache:这是中小型Web服务的主流,Web服务器中的老大哥。
u Nginx:大型网站Web服务的主流,曾经Web服务器中的初生牛犊,现已长大。
Nginx的分支Tengine(
http://tengine.taobao.org/)目前也在飞速发展。
u Lighttpd:这是一个不温不火的优秀Web软件,社区不活跃,静态解析效率很高。在Nginx流行前,
它是大并发静态业务的首选,国内百度贴吧、豆瓣等众多网站都有Lighttpd奋斗的身影。
三、nginx 的优点
1.高并发。静态小文件
2.占用资源少。2万并发、10个线程,内存消耗几百M。
3.功能种类比较多。web,cache,proxy。每一个功能都不是特别强大。
4.支持epoll模型,使得nginx可以支持高并发。
5.nginx 配合动态服务和Apache有区别。(FASTCGI 接口)
6.利用nginx可以对IP限速,可以限制连接数。
7.配置简单,更灵活。
1.静态服务器(图片,视频服务),两个lighttpd。并发几万,html,js,css,flv,jpg,gif等。
2.动态服务,nginx—fastcgi 方式运行PHP,jsp。(PHP并发约500-1500,MySQL 并发约300-1500)。
3.反向代理,负载均衡。日pv2000W以下,都可直接用nginx做代理。
4.缓存服务。类似 SQUID,VARNISH。
五、主流web服务产品对比说明
5.1 Apache-特性
1.2.2版本本身稳定强大,据官方说:其2.4版本性能更强。
2.prefork模式取消了进程创建开销,性能很高。
3.处理动态业务数据时,因关联到后端的引擎和数据库,瓶颈不在于Apache本身。
4.高并发时消耗系统资源相对多一些。
5.基于传统的select模型。
6.扩展库,DSO方法。详细教程资料关注+后台私信;资料;两个字可以免费视频领取+文档+各大厂面试题 资料内容包括:C/C++,Linux,golang,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK,嵌入式 等。
5.2 nginx-特性
1.基于异步IO模型(epoll,kqueue),性能强,能够支持上万并发。
2.对小文件支持很好,性能很高(限静态小文件1M)。
3.代码优美,扩展库必须编译进主程序。
4.消耗代码资源比较低。
5.lighttpd(百度贴吧,豆瓣)
6.基于异步IO模式,性能和nginx相近。
7.扩展库是SO模式,比nginx要灵活。
8.通过差距(mod_secdownload)可实现文件URL地址加密。
5.3 web服务产品性能对比测试
5.3.1 静态数据性能对比
1.处理动态内容三者相差不大,主要取决于PHP和数据库压力。
2.当处理动态数据时,三者差距不大,从测试结果看,Apache更有优势。这是因为处理动态数据能力取决于PHP和后端数据的提供服务能力。即瓶颈不在web服务器上。
3.一般PHP引擎的并发值300-1000,JAVA引擎并发300-1000,数据库并发300-1000.
5.3.3 为什么nginx总体性能比Apache高。
1.nginx用最新epoll、kqueue网络IO模型,而Apache使用床头的select模式。
2.目前Linux下能承受高并发访问的squid、Memcached 都采用的是epoll网络IO模型。详细教程资料关注+后台私信;资料;两个字可以免费视频领取+文档+各大厂面试题 资料内容包括:C/C++,Linux,golang,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK,嵌入式 等。
5.3.4 如何选择WEB服务器:
1.静态业务:高并发、采用nginx,lighttpd,根据自己掌握程度或公司要求。
2.动态业务:采用nginx和Apache均可。
3.既有静态业务又有动态业务:nginx或Apache,不要多选要单选。
4.动态业务可由前端代理(haproxy),根据页面元素的类型,向后转发给相应的服务器处理。
5.思想:工作都不要追求一步到位,满足需求的前提下,先用再逐步完善。
6.提示:nginx做web(Apache,lighttpd)、反向代理(haproxy、lvs、nat)及缓存服务器(squid)也是不错的。
7.最终建议:对外业务nginx,对内业务Apache(yum httpd mysql-server php)。