Nginx基础
一、Nginx基本概念
1.1 什么是Nginx
Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,其特点是占有内存少,并发能力强,事实上Nginx的并发能力在同类型的网页服务器中表现较好。Nginx可以作为静态页面的web服务器,同时还支持CGI协议的动态语言。如perl、php等,但是不支持java。java程序只能通过与tomcat配合完成。Nginx专为性能优化而开发,性能是其最重要的考量,非常注重效率,能经受住高负载的考验,支持高达50000个并发连接数。
1.2 代理
1.2.1 正向代理
在客户端(浏览器)配置代理服务器,通过代理服务器进行互联网访问。适用于客户端知道目标服务器地址,但由于网络限制等原因无法直接目标服务器,通过代理服务器去访问目标服务器获取服务。
1.2.2 反向代理
用户将请求发送到反向代理服务器,由反向代理服务器去选择目标服务器数据后,再返回给客户端。此时的反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器IP,具体是哪个台服务器在提供服务,用于对于客户端用户是无感知的。比如现实中我们通过访问百度的代理服务器对外提供的域名后,代理服务器把我们的请求到他们N多的服务器节点中的一个,节点服务器我们的请求进行搜索后将结果返回。
1.3 负载均衡
客户端发送多个请求到服务器,服务器随后分发处理请求到不同的服务器。服务器处理完毕后,再将结果返回给客户端。上述架构模式对于早期的系统相对单一,并发请求相对较少的情况下比较合适。但随着信息数量的不断增长,访问量和数据量的飞速增长,以及系统业务的复杂度增加,这种架构会造成相应客户端的请求日益缓慢,并发量特别大的时候,还容易造成服务器直接崩溃。负载均衡:基于集群的概念,增加服务器的数量,将请求分发到各个服务器上,将原先请求集中到单个服务器上的情况,改为请求分发到多个服务器上,将负载分发到不同的服务器。
1.4 动静分离
为了加快网站的解析速度,可以把动态页面和静态页面由不同的服务器来解析,加快解析的速度,降低原来单个服务器的压力。
二、Nginx的配置文件介绍
2.1 Nginx配置文件位置
配置文件位置:/usr/local/nginx/conf/nginx.conf
2.2 Nginx配置文件组成
配置文件由三部分组成
2.2.1 全局块
从配置文件开始到events块之间的内容,主要是设置一些影响Nginx服务器整体运行的配置指令。主要包括:配置运行Nginx服务器的用户(组)、允许生成的work process数、进程PID存放路径、日志存放路径和类型
配置文件的引入
work_process值越大,可以支持的并发处理量也越多,但是会受到硬件、软件等设备的制约。
2.2.2 events块
events块的指令主要影响Nginx服务器与用户的网络连接,常用的设置包括:是否开启对多work_process下的网络连接进行序列化、是否允许同时接收多个网络连接、选取哪种时间驱动模型来处理连接请求、每个work_process可以同时支持的最大连接数。
每个work_process支持的最大连接数为1024,这部分配置对Nginx的性能影响较大,在实际中应该灵活配置
2.2.3 http块
http块是Nginx服务器配置中最频繁的部分,代理、缓存、日指定以等绝大多数功能和第三方模块的配置都在这里。包括:http全局块、server块
2.2.3.1 http全局块
http全局块配置的指令包括:文件引入、MIME-TYPE定义、日志自定义、连接超时时间、单链接请求数上限
2.2.3.2 server块
server块与虚拟主机有密切关系,虚拟主机从用户角度看,和一台独立的硬件主机完成一样,该技术的产生是为了节省互联网服务器硬件成本。每个http块可以包括多个server块,而每个server块相当于一个虚拟主机。每个server块也分为全局server块,以及可以同时包含多个的location块。
全局server块 ,最常见的配置时本虚拟机主机的监听配置和本虚拟机主机的名称或IP配置
location块
一个server块可以配置多个location块,location块的作用时基于nginx服务器接收到的请求字符串(如 server_name/uri-string),对虚拟主机名称(IP别名也可)之外的字符串(如 前面的/uri-string)进行匹配,对特定的请求进行处理。地址定向、数据缓存、应答控制等功能,还有许多第三方模块的配置也在这里进行。