Nginx(enginex)是一个开源的,具备高性能、高并发、高可靠性的WWW服务和代理服务软件。
由俄罗斯人IgorSysoev开发,作者将源代码以类BSD许可证的形式开源出来供全球使用。
年,F5将收购NGINX,总价值约为6.7亿美元。F5负载均衡厂商。
开源,是说可以直接获取Nginx的源代码,并且可以免费使用。
高性能,是说处理速度非常快,且消耗的资源很低。
高并发,支持并发连接1-5万,且消耗的资源很低。
高可靠,体现在服务非常稳定。
并发5万,说的是静态小文件,NGINX(5万并发)+PHP(个并发)。
选择Nginx原因
1、开源、免费
2、功能强大、并且简单易用
3、高性能、高并发
4、高可靠性、高可扩展性(模块多,开发第三方模块)
5、社区活跃(前1万互联网网站),排名no.1,且增长快。
Nginx生态状况
OpenResty?是一个基于Nginx与Lua的高性能Web平台,其内部集成了大量精良的Lua库、第三方模块以及大多数的依赖项
用于方便地搭建能够处理超高并发、扩展性极高的动态Web应用、Web服务和动态网关。诞生于年
Kong网关是一款基于OpenResty(Nginx+Lua模块)编写的高可用、易扩展的,由Mashape公司开源的APIGateway项目
Kong是基于NGINX和ApacheCassandra或PostgreSQL构建的,能提供易于使用的RESTfulAPI来操作和配置API管理系统,所以它可以水平扩展多个Kong服务器,通过前置的负载均衡配置把请求均匀地分发到各个Server,来应对大批量的网络请求
Lua是脚本语言,nginx+Lua是脚本语言,对请求过滤、控制
mysql-proxy读写分离软件使用lua开发的
Tengine是由淘宝网发起的Web服务器项目( Nginx企业应用
作为Web服务软件
Nginx是一个支持高性能、高并发的Web服务软件,它具有很多优越的特性,作为Web服务器,和Apache相比,Nginx能够支持更多的并发连接访问,而占用的资源却更少,效率更高,在功能上也强大了很多,几乎不逊色于Apache,而且Nginx更新频率更快,社区用户更火爆。
1、Nginx是一个静态Web服务软件,使用Nginx运行HTML、JS、CSS、小图片等静态数据(此功能类似lig 2、支持动静分离功能apache,lig 3、支持动态Web服务扩展PHP(fastcgi_pass)JAVA(proxy_pass)Python(uwsgi_pass)memcache(memcache_pass)......
Nginx结合FastCGI运行PHP动态程序(使用fastcgi_pass方式)
Nginx结合proxy_pass支持tomcat动态程序(使用proxy_pass)
Nginx结合uwsgi_pass支持Python(使用uwsgi_pass)
4、支持安全的Web服务(
作为反向代理或负载均衡服务软件
在反向代理或负载均衡服务方面,Nginx可以作为Web服务、PHP/Tomcat/Python等动态服务及Memcached缓存的代理服务器,它具有类似专业反向代理软件(如Haproxy)的功能,同时也是一个优秀的邮件代理服务软件(最早开发这个产品的目的之一也是作为邮件代理服务),在Nginx的代理功能方面,已经支持TCP和UDP的代理,Nginx的代理功能已经越来越强大了
1、负载均衡同类软件:haproxy,lvs,硬件:F5,netscalernginx早期只支持 2、反向代理与负载均衡区别强调
正向代理:由内向外。代替效率低代替局域网内PC,请求外部应用服务。
反向代理:由外向内,代替,效率低代替外部的用户请求内部的应用服务器。
负载均衡:转发、效率高(LVS)甩手掌柜,后抛请求。
3、负载均衡和Web服务的走向
缓存服务器
在Web缓存服务方面,Nginx可通过自身的proxy_cache模块实现类Squid等专业缓存软件的功能。
常见缓存软件:squid,varnish,nginx,ats
Nginx主要应用场景总结
1、静态Web服务器:使用Nginx运行HTML、JS、CSS、小图片等静态数据(此功能类似lig 2、配合运行动态Web服务器:Nginx结合FastCGI运行PHP等动态程序(例如使用fastcgi_pass方式)。Nginx结合proxy_pass支持Java动态程序(tomcat/resin服务)。Nginx结合uwsgi_pass支持Python。
3、反向代理/负载均衡 4、做Web缓存服务器(把文件放入内存里)。
5、支持安全的Web服务(
Nginx核心特点
静态小文件高并发,占用资源少,而且软件本身小
1、支持高并发:能支持几万并发连接(特别是静态小文件业务环境)
2、资源消耗少:在3万并发连接下,开启10个Nginx线程消耗不到MB内存
3、可以做HTTP反向代理及加速缓存,即负载均衡功能,内置对RS节点服务器健康检查功能,这相当于专业的haproxy软件或lvs的功能。具备squid等专业缓存软件等的缓存功能
Nginxepoll模型和Apacheselect模型区别
Nginx使用最新的epoll(Linux2.6内核)和kqueue(freebsd)异步网络I/O模型,而Apache则使用的是传统的select模型
目前Linux下能够承受高并发访问的Squid、Memcached软件都采用的是epoll模型
简单总结:
1、epoll和select网络IO处理模型
2、epoll异步网络IO模型,支持高并发
3、select传统的网络IO模型,高并发能力弱
4、Apache则使用的是传统的select模型,Nginx使用高并发的epoll模型
异步和同步:以及异步的静态化的案例
网络IO模型概述
通常来说,网络IO可以抽象成用户态和内核态之间的数据交换。一次网络数据读取操作(read),可以拆分成两个步骤:
1、网卡驱动等待数据准备好(内核态)
2、将数据从内核空间拷贝到进程空间(用户态)
根据这两个步骤处理方式不一样,我们通常把网络IO划分成阻塞IO和非阻塞IO
Nginx软件核心组成
1、Nginx可执行命令:
它是Nginx本身框架以及相关模块等构建的一个二进制文件,这个文件就相当于汽车本身,所有的功能都由它提供
2、nginx.conf配置文件:
它相当于驾驶人员,虽然二进制可执行文件已经提供了许多的功能,但是这些功能究竟有没有开启,或者开启后定义怎样的行为去处理请求,都是由nginx.conf这个文件决定的,所以他就相当于这个汽车的驾驶员,控制这个汽车的行为
3、访问日志access.log:
它相当于这辆汽车经过所有地方形成的GPS轨迹,access.log会记录Nginx处理过的每一条HTTP的请求信息、响应信息
4、错误日志error.log:
它相当于飞机的黑匣子,当出现了一些不可预期的问题时,可以通过error.log将问题定位出来
Nginx软件安装
yum安装
配置nginx源
#方法一:#vim/etc/yum.repos.d/nginx.repo[nginx-stable]name=nginxstablerepobaseurl= 安装并启动
yuminstallnginx-yrpm-qanginx#如果服务器上开启
编译安装
下载源码包
mkdir-p/server/toolscd/server/toolswget 安装依赖
#rewrite正则相关pcre:URL重写软件,实现伪静态\URL跳转等、SEO优化yuminstallpcrepcre-devel-y# 编译安装步骤
userdel-r 验证最终的安装是否正确
wget10.0.0.8#将IP地址改为自己服务器的IPcurl10.0.0.8#将IP地址改为自己服务器的IP或浏览器访问
configure参数作用
配置nginxPATH环境变量
#在/etc/profile文件里加入vim/etc/profileexportPATH="/application/nginx/sbin/:$PATH"#增加后执行下面,使之生效./etc/profile#检查测试echo$PATHnginx-t
配置systemd启动方式
#vim/usr/lib/systemd/system/nginx.service[Unit]Description=ThenginxHTTPandreverseproxyserverAfter=network-online.targetremote-fs.targetnss-lookup.targetWants=network-online.target[Service]Type=forkingPIDFile=/application/nginx/logs/nginx.pidExecStartPre=/usr/bin/rm-f/application/nginx/logs/nginx.pidExecStartPre=/application/nginx/sbin/nginx-tExecStart=/application/nginx/sbin/nginxExecReload=/application/nginx/sbin/nginx-sreloadKillSignal=SIGQUITTimeoutStopSec=5KillMode=processPrivateTmp=true[Install]WantedBy=multi-user.target#chmod+x/usr/lib/systemd/system/nginx.service#systemctlenablenginx#pkillnginx#systemctlstartnginx#lsof-i:80
原文来源于: