初识 Nginx

简介: Nginx 是一个免费的,开源的,高性能的HTTP服务器和反向代理,以及IMAP / POP3代理服务器。 Nginx以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。

Nginx 是一个免费的,开源的,高性能的HTTP服务器和反向代理,以及IMAP / POP3代理服务器。 Nginx

以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。很多高知名度的网站都使用

Nginx,如:Netflix,GitHub,SoundCloud,MaxCDN 等。

Nginx 有一个主线程( master process)和几个工作线程(worker process)。主线程的目的是加载验证配置文件、维护工作线程。

工作线程处理实际的请求,Nginx 采用基于事件的模型和依赖操作系统的机制在工作线程之间高效地分发请求。工作线程的数量可配置,也可自动调整为服务器CPU的数量。

Nginx 及其模块的工作方式由配置文件确定。 默认情况下,配置文件名为nginx.conf,放在/usr/local/nginx/conf、/etc/nginx或者/usr/local/etc/nginx文件夹中。

基本命令

Nginx 启动之后,可以使用以下命令控制:

nginx -s

其中-s意思是向主进程发送信号,signal可以为以下四个中的一个:

stop— 快速关闭

quit— 优雅关闭

reload— 重新加载配置文件

reopen— 重新打开日志文件

当运行nginx -s quit时,Nginx 会等待工作进程处理完成当前请求,然后将其关闭。当你修改配置文件后,并不会立即生效,而是等待重启或者收到nginx -s reload信号。

当 Nginx 收到nginx -s reload信号后,首先检查配置文件的语法。语法正确后,主线程会开启新的工作线程并向旧的工作线程发送关闭信号,如果语法不正确,则主线程回滚变化并继续使用旧的配置。当工作进程收到主进程的关闭信号后,会在处理完当前请求之后退出。

配置文件

Nginx 配置的核心是定义要处理的URL以及如何响应这些URL请求,即定义一系列的虚拟服务器(Virtual Servers)控制对来自特定域名或者 IP 的请求的处理。

每一个虚拟服务器定义一系列的location控制处理特定的 URI 集合。每一个location定义了对映射到自己的请求的处理场景,可以返回一个文件或者代理此请求。

Nginx 由不同的模块组成,这些模块由配置文件中指定的指令控制。 指令分为简单指令块指令

一个简单指令包含指令名称指令参数,以空格分隔,以分号(;)结尾。 块指令与简单指令类似,但是由大括号({和})包围。 如果块指令大括号中包含其他指令,则称该指令为上下文(如:events,http,server和location)。

配置文件中的放在上下文之外的指令默认放在主配置文件中(类似继承主配置文件)。events和http放置在主配置文件中,server放置在http块指令中,location放置在server块指令中。

配置文件的注释以#开始。

静态内容

Web 服务器一个重要的功能是服务静态文件(图像或静态HTML页面)。例如,Nginx 可以很方便的让服务器从/data/www获取 html 文件,从/data/images获取图片来返回给客户端,这只需要在http块指令中的server块指令中设置两个location块指令。

首先,创建/data/www目录,并放入index.html,创建/data/images目录并在其中放置一些图片。

接下来,打开配置文件。 创建一个server块:

http { server {

}

}

通常,配置文件可以包括多个server块,它们以端口服务器名称来区分。当 Nginx 决定某一个server处理请求后,它将请求头中的URI和server块中的location块进行对比。

加入location块指令到server中:

将以下位置块添加到服务器块:

location / { root /data/www;

}

上面的location块指定/前缀与请求中的URI对比。对于匹配的请求,URI将被添加到root指令中指定的路径,即/data/www,以此形成本地文件系统的路径,如访问http://localhost/bog/welcome.html,对应服务器文件路径为/data/www/bog/welcome.html。 如果URI匹配多个location块,Nginx 采用最长前缀匹配原则(类似计算机网络里面的IP匹配), 上面的location块前缀长度为 1,因此只有当所有其他location块匹配时,才使用该块。

接下来,添加第二个位置块:

location /images/ { root /data;

}

它将匹配以/images/(/也匹配这样的请求,但具有较短的前缀)开始的请求。

server块的最终配置如下:

server { location / { root /data/www;

} location /images/ { root /data;

}

}

到目前为止,这已经是一个可以正常运行的服务器,它监听端口80,并且可以在本地计算机上访问http://localhost/。 对于/images/开头的请求,服务器将从/data/images目录发送文件。 如,对于http://localhost/images/example.png请求,nginx 将响应/data/images/example.png文件。 如果不存在,nginx 将返回404。URI不以/images/开头的请求将映射到/data/www目录。 例如,对于http://localhost/some/example.html请求,nginx 将响应/data/www/some/example.html文件。

代理服务器

Nginx 的一个常见应用是将其设置为代理服务器(Proxy Server),即接受客户端的请求并将其转发给代理服务器,再接受代理服务器发来的响应,将它们发送到客户端。

比如我们可以用一个 Nginx 实例实现对图片文件的请求使用本地文件系统,而其他请求转发到代理服务器。

首先,向 Nginx 的配置文件中添加一个server块来定义代理服务器:

server { listen 8080; root /data/up1; location / {

}

}

此服务器侦听端口8080,并将所有请求映射到本地文件系统上的/data/up1目录。 创建此目录并将index.html放入其中。 注意,root指令放在server上下文中,这样 当location块中不含root指令时将使用所属server的root指令。

接下来,使用上一节中的服务器配置,并将其修改为代理服务器配置。 在第一个位置块中,加上proxy_pass指令:

server { location / { # proxy_pass指令的参数为:协议+主机名+端口号

proxy_pass http://localhost:8080;

} location /images/ { root /data;

}

}

修改第二个 匹配/images/前缀的location块,使其与请求图像文件的扩展名相匹配:

location ~ \.(gif|jpg|png)$ { root /data/images;

}

该参数是一个正则表达式,匹配以.gif,.jpg或.png结尾的所有URI。 正则表达式应该以~开头。 相应的请求将映射到/data/images目录。

当 Nginx 选择一个location块来处理请求时,它首先检查指定location块的前缀,记住具有最长前缀的location块,然后检查正则表达式。 如果与正则表达式匹配, Nginx 选择此location块,否则,选择先前记住的location块。

代理服务器的最终配置如下:

server { location / { proxy_pass http://localhost:8080/;

} location ~ \.(gif|jpg|png)$ { root /data/images;

}

}

此服务器将过滤以.gif,.jpg或.png结尾的请求,并将它们映射到/data/images目录(通过向root指令的参数添加请求的URI),并将所有其他请求发送给上面配置的代理服务器。

这样,图片和其他请求就可以使用不同的服务器来处理。

FastCGI代理

Nginx 可用于将请求路由到 FastCGI 服务器。快速通用网关接口(Fast Common Gateway

Interface/FastCGI)是一种让交互程序与Web服务器通信的协议。因此 Nginx 可以将请求路由到 FastCGI

运行的应用程序,如 PHP 程序。

使用 FastCGI 服务器的最基本的 Nginx 配置包括使用fastcgi_pass指令而不是proxy_pass指令,以及使用fastcgi_param指令来设置传递给 FastCGI 服务器的参数。 假设FastCGI服务器可在localhost:9000上访问。 以上一节中的代理服务器配置为基础,使用fastcgi_pass指令替换proxy_pass指令,并将参数更改为localhost:9000。 在 PHP 中,SCRIPT_FILENAME参数用于确定脚本名称,而QUERY_STRING参数用于传递请求参数。 生成的配置将是:

server

{ location / { fastcgi_pass localhost:9000; fastcgi_param

SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param

QUERY_STRING $query_string;

} location ~ \.(gif|jpg|png)$ { root /data/images;

}

}

这将设置一个服务器,将路由除静态图像以外的所有请求到运行在localhost:9000的 FastCGI 服务器。

目录
相关文章
|
缓存 负载均衡 算法
|
1月前
|
应用服务中间件 BI nginx
Nginx的location配置详解
【10月更文挑战第16天】Nginx的location配置详解
|
1月前
|
缓存 负载均衡 安全
Nginx常用基本配置总结:从入门到实战的全方位指南
Nginx常用基本配置总结:从入门到实战的全方位指南
265 0
|
1月前
|
应用服务中间件 Linux nginx
Jetson 环境安装(四):jetson nano配置ffmpeg和nginx(亲测)之编译错误汇总
这篇文章是关于在Jetson Nano上配置FFmpeg和Nginx时遇到的编译错误及其解决方案的汇总。
94 4
|
11天前
|
存储 负载均衡 中间件
Nginx反向代理配置详解,图文全面总结,建议收藏
Nginx 是大型架构必备中间件,也是大厂喜欢考察的内容,必知必会。本篇全面详解 Nginx 反向代理及配置,建议收藏。
Nginx反向代理配置详解,图文全面总结,建议收藏
|
24天前
|
应用服务中间件 API nginx
nginx配置反向代理404问题
【10月更文挑战第18天】本文介绍了使用Nginx进行反向代理的配置方法,解决了404错误、跨域问题和302重定向问题。关键配置包括代理路径、请求头设置、跨域头添加以及端口转发设置。通过调整`proxy_set_header`和添加必要的HTTP头,实现了稳定的服务代理和跨域访问。
116 1
nginx配置反向代理404问题
|
9天前
|
应用服务中间件 网络安全 nginx
轻松上手Nginx Proxy Manager:安装、配置与实战
Nginx Proxy Manager (NPM) 是一款基于 Nginx 的反向代理管理工具,提供直观的 Web 界面,方便用户配置和管理反向代理、SSL 证书等。本文档介绍了 NPM 的安装步骤,包括 Docker 和 Docker Compose 的安装、Docker Compose 文件的创建与配置、启动服务、访问 Web 管理界面、基本使用方法以及如何申请和配置 SSL 证书,帮助用户快速上手 NPM。
42 1
|
1月前
|
编解码 Ubuntu 应用服务中间件
Jetson 环境安装(三):jetson nano配置ffmpeg和nginx(亲测)
本文介绍了在NVIDIA Jetson Nano上配置FFmpeg和Nginx的步骤,包括安装、配置和自启动设置。
153 1
Jetson 环境安装(三):jetson nano配置ffmpeg和nginx(亲测)
|
28天前
|
缓存 负载均衡 应用服务中间件
Nginx配置
【10月更文挑战第22天】在实际配置 Nginx 时,需要根据具体的需求和环境进行调整和优化。同时,还需要注意配置文件的语法正确性和安全性。
46 7
|
1月前
|
前端开发 JavaScript 应用服务中间件
终极 Nginx 配置指南
本文介绍了Nginx的基本配置及其优化方法。首先,通过删除注释简化了Nginx的默认配置文件,使其更易于理解。接着,文章将Nginx配置文件分为全局块、events块和http块三部分进行详细解释。此外,还提供了如何快速上线网站、解决前端history模式404问题、配置反向代理、开启gzip压缩、设置维护页面、在同一IP上部署多个网站以及实现动静分离的具体配置示例。最后,附上了Nginx的基础命令,包括安装、启动、重启和关闭等操作。