51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

Nginx入门简介及安装

Nginx简介

Nginx (engine x) 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。

其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。
文章源自小柒网-https://www.yangxingzhen.cn/578.html

Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上Nginx的并发能力确实在同类型的网页服务器中表现较好,中国大陆使用Nginx网站用户有:百度、京东新浪网易腾讯淘宝等。文章源自小柒网-https://www.yangxingzhen.cn/578.html

Nginx 是一个安装非常的简单、配置文件非常简洁(还能够支持perl语法)、Bug非常少的服务器。Nginx 启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。你还能够不间断服务的情况下进行软件版本的升级。
文章源自小柒网-https://www.yangxingzhen.cn/578.html

Nginx特点是占有内存少,并发能力强,事实上Nginx的并发能力确实在同类型的网页服务器中表现较好。
文章源自小柒网-https://www.yangxingzhen.cn/578.html

Nginx相对于Apache优点如下:文章源自小柒网-https://www.yangxingzhen.cn/578.html

1)高并发响应性能非常好,官方Nginx处理静态文件并发5w/s;文章源自小柒网-https://www.yangxingzhen.cn/578.html

2)负载均衡及反向代理性能非常强;文章源自小柒网-https://www.yangxingzhen.cn/578.html

3)系统内存和CPU占用率低;文章源自小柒网-https://www.yangxingzhen.cn/578.html

4)可对后端服务进行健康检查;文章源自小柒网-https://www.yangxingzhen.cn/578.html

5)支持PHP cgi方式和FastCGI方式;文章源自小柒网-https://www.yangxingzhen.cn/578.html

6)可以作为缓存服务器、邮件代理服务器;

7)配置代码简洁且容易上手;

8)支持 SSL 和 TLSSNI。

Nginx工作原理

Nginx WEB服务器最主要就是各种模块的工作,模块从结构上分为核心模块、基础模块和第三方模块,其中三类模块分别如下:

1)核心模块:HTTP模块、EVENT模块和MAIL模块等;

2)基础模块:HTTP Access模块、HTTP FastCGI模块、HTTP Proxy模块和HTTP Rewrite模块;

3)第三方模块:HTTP Upstream Request Hash模块、Notice模块和HTTP Access Key模块、Limit_req模块、Upstream check module等;

Nginx的模块从功能上分为如下三类。

1)Handlers(处理器模块):此类模块直接处理请求,并进行输出内容和修改headers信息等操作,Handlers处理器模块一般只能有一个;

2)Filters (过滤器模块):此类模块主要对其他处理器模块输出的内容进行修改操作,最后由Nginx输出;

3)Proxies (代理类模块):此类模块是Nginx的HTTP Upstream之类的模块,这些模块主要与后端一些服务比如FastCGI等进行交互,实现服务代理和负载均衡等功能。

Nginx由Nginx内核和模块组成,其中内核的设计非常微小和简洁,完成的工作也非常简单,仅仅通过查找配置文件将客户端的请求映射到一个location block,而location是Nginx配置中的一个指令,用于访问的URL匹配,而在这个location中所配置的每个指令将会启动不同的模块去完成相应的工作,如图所示:

Nginx的高并发得益于其采用了epoll模型,与传统的服务器程序架构不同,epoll是Linux内核2.6以后才出现的,Nginx采用epoll模型,异步非阻塞,而apache采用的是select模型:

Select特点:select 选择句柄的时候,是遍历所有句柄,也就是说句柄有事件响应时,select需要遍历所有句柄才能获取到哪些句柄有事件通知,因此效率是非常低。

epoll的特点:epoll对于句柄事件的选择不是遍历的,是事件响应的,就是句柄上事件来就马上选择出来,不需要遍历整个句柄链表,因此效率非常高。

Nginx默认以80端口监听在服务器上,并且启动一个master进程,同时有master进程生成多个工作进程,当浏览器发起一个HTTP连接请求,每个进程都有可能处理这个连接,怎么做到的呢?怎么保证同一时刻一个HTTP请求被一个工作进程处理呢。

首先每个worker进程都是从Master进程fork出来,在Master进程里面,建立好需要listen的socket(listenfd)之后,会fork出多个worker进程。

所有worker进程的listenfd会在新连接到来时变得可读,为保证只有一个进程处理该连接,所有worker进程在注册listenfd读事件前抢accept_mutex,抢到互斥锁的那个进程注册listenfd读事件,在读事件里调用accept接受该连接。

当一个worker进程在accept这个连接之后,就开始读取请求、解析请求、处理请求,产生数据后,再返回给客户端,最后才断开连接,这样形成一个完整的请求流程。如图所示:

Nginx安装部署

Nginx WEB安装时可以指定很多的模块,默认需要安装Rewrite模块,也即是需要系统有PCRE库,安装Pcre支持Rewrite功能。如下为安装Nginx WEB服务器方法:

1、安装PCRE库、SSL支持

[root@localhost ~]# yum -y install pcre pcre-devel openssl openssl-devel gcc gcc-c++ wget

2、下载Nginx源码包

[root@localhost ~]# wget -c http://mirrors.yangxingzhen.com/nginx/nginx-1.12.0.tar.gz

3、解压Nginx源码包

[root@localhost ~]# tar zxf nginx-1.12.0.tar.gz

4、进入解压目录,预编译Nginx

[root@localhost ~]# cd nginx-1.12.0

[root@localhost nginx-1.12.0]# useradd -s /sbin/nologin www

[root@localhost nginx-1.12.0]# ./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_ssl_module --with-http_stub_status_module

5、编译及安装Nginx

[root@localhost nginx-1.12.0]# make && make install

#至此Nginx WEB服务器安装完毕。

测试Nginx服务安装是否正确,同时启动Nginx WEB 服务,代码命令如下:

[root@localhost nginx-1.12.0]# /usr/local/nginx/sbin/nginx -t //检查nginx配置文件是否正确,返回OK即正确。

#启动Nginx,执行以下命令

[root@localhost nginx-1.12.0]# /usr/local/nginx/sbin/nginx

#查看Nginx进程和端口,执行以下命令

[root@localhost nginx-1.12.0]# ps -ef | grep nginx

[root@localhost nginx-1.12.0]# netstat -lntup | grep nginx

#通过浏览器访问Nginx默认测试页面,如图所示


继续阅读 Nginx最后更新:2022-11-22

赞(0)
未经允许不得转载:工具盒子 » Nginx入门简介及安装