nginx 初学者指引
本文会简单详情 nginx 并演示相关的简单任务。首先你需要安装好 nginx。
nginx 拥有一个主进程和几个 worker 进程。主进程的主要工作是读取和解决配置,维护 worker 进程。worker 进程负责解决实际的使用户请求。nginx 采使用 event-based 模型和 OS-dependent 机制对使用户请求进行高效的分发。worker 进程的数量在配置文件中定义,可在配置中修改,或者者根据可使用的 CPU 核心数进行自动调整。
参考 http://nginx.org/en/docs/ngx_core_module.html#worker_processes
Syntax: worker_processes number | auto;
Default: worker_processes 1;
Context: main
Defines the number of worker processes.
worker 进程的最佳个数受许多因素影响,比方 CPU 核心数,磁盘驱动的个数,nginx 负载模式等。假如不确定设为多少合适,能设置为 CPU 核心数。假如设置为 auto,nginx 会尝试自动检测CPU核心数并设置为 worker 进程数。(auto 参数从 1.3.8 和 1.2.5 版开始支持)
nginx 及其板块的工作由配置文件定义,默认的配置文件为 nginx.conf,该配置文件可可以位于:
/usr/local/nginx/conf, /etc/nginx, or /usr/local/etc/nginx.
nginx 启动、中止、重新加载配置
——————————-
执行 nginx 命令启动 nginx。启动 nginx 之后,可用如下命令:
nginx -s stop 快速关闭 nginx
nginx -s quit 优雅的关闭 nginx
nginx -s reload 重新加载配置
nginx -s reopen 重新打开日志文件
优雅地关闭 nginx,这是说 nginx 主进程会等待 worker 进程完成当前使用户请求的解决。
执行:nginx -s quit (以启动 nginx 时的使用户身份执行该命令)
更改配置之后,必需执行重新加载配置的命令,或者者重新启动 nginx,以使得配置生效:
nginx -s reload
当主进程接收到 reload 信号,它会检查配置文件的语法,而后尝试应使用该配置。假如成功,主进程启动新的 worker 进程,并发送消息给原来的 worker 进程要求他们关闭。假如加载配置失败,主进程会对改动进行回滚,继续以原来的配置进行工作。当原来的 worker 进程接收到消息要他们关闭,他们会中止接收新的连接,并继续解决当前的请求直到完成。完成之后,原来的 worker 进程将会退出。
给 nginx 发送信号,可借助于 kill 命令。kill 命令用进程 pid 发送信号。nginx 主进程的 pid 存储在pid 文件中,默认为 nginx.pid,位于 /usr/local/nginx/logs 或者 /var/run 目录下。
例如,假如 nginx 主进程 pid 为 1628,用 kill 命令发送 QUIT 信号给 nginx,使其优雅地关闭:
kill -s QUIT 1628
假如要获取所有运行中的 nginx 进程的列表,用 ps 命令:
ps -ax | grep nginx
关于发送信号给 nginx 的更多信息,请参考:http://nginx.org/en/docs/control.html
配置文件的结构
——————-
nginx 由许多板块组成,这些板块可在配置文件中进行配置。nginx 的配置指令分为:简单配置指令,区块配置指令。
简单配置指令由 “名称” 和 “参数” 组成, “名称” 和 “参数” 以空格分隔,指令的最后以分号 “;” 为结尾。
区块配置指令和简单配置指令拥有同样的结构,区块指令不以分号结尾。区块指令用花括号 “{}” 将一组设置包含于其中。假如在区块指令的括号中包含其余指令,这个区块指令就被称为 “context” (上下文)。例如 events,http,server,location 指令。
所有在 context 之外的指令,被认为处于 main context 之中。
events 和 http 指令使用于 main context 之中。
server 指令使用于 http 之中。
location 指令使用于 server 指令之中。
配置文件中以 # 起始的行为注释行。
nginx 提供静态内容的服务
—————————
web 服务器的重要任务之一是提供文件服务(比方 image 文件、静态 HTML 页面等)。
我们将实现一个示例,根据请求的不同,nginx 通过不同的目录提供文件给使用户。我们通过
/data/www 目录提供 HTML 文件,通过 /data/images 目录提供 image 文件。
为达到这个目标,需要在配置文件中设置 server 区块,并在 server 区块中设置两个 location 区块。server 区块位于 http 区块之中。首先,创立 /data/www 目录,并在其中创立 index.html 文件,文件内容任意,比方:
echo “
HTML File
” > /data/www/index.html
而后创立 /data/images 目录,放少量图像文件到该目录中。之后打开配置文件。默认的配置文件已经包含少量 server 区块的示例,大多数被注释了。
现在将所有 server 区块注释掉,而后创立一个新的 server 区块:
http {
server {
}
}
一般来说,配置文件可可以包含几个 server 区块,它们拥有不同的监听端口和 server name。
一旦 nginx 决定好用哪一个 server 解决使用户请求,nginx 测试请求首部的 URI 字段,
将它与 server 区块中的 location 指令定义的参数进行比照。
在 server 区块中增加如下 location 区块:
location / {
root /data/www;
}
这个 location 区块指定 “/” 前缀,并将它和请求首部中的 URI 进行比较。对于匹配的请求,
URI 将被增加到 root 指令所指定的路径的末尾,这里 root 指令定义的路径是 /data/www,
这样形成使用户所请求的文件的本地路径。假如有多个 location 区块与请求的 URI 匹配,nginx
选择其中前缀最长的那个 location 区块。
这里的 location 提供了最短的前缀,长度为 1,所以只有当所有其余 location 区块都匹配失败,
才会选择这个 location 区块。
下一步,增加第二个 location 区块:
location /images/ {
root /data;
}
这个 location 区块可以够匹配 URI 以 /images/ 起始的请求 (location / 也可以匹配这样的请求,但它的
前缀比 /images/ 短,所以优先匹配 location /images/)
我们的 server 区块的配置是这样的:
server {
location / {
root /data/www;
}
location /images/ {
root /data;
}
}
这已经是一个可工作的服务配置,nginx 监听于 80 端口,可通过本地访问 http://localhost/ 。
对于 URI 以 /images/ 起始的请求,nginx 会将 /data/images 目录中的文件发送给用户端。
例如,对于访问请求:https://img.songma.com/wenzhang/20180605/yrimki5tldt2681.png,nginx 会发送 /data/images/example.png 文件。假如这个文件不存在,nginx 会发送 404 error 响应给用户端。
对于 URI 不是以 /images/ 起始的请求,会被映射到 /data/www 目录。
例如,对于访问请求:http://localhost/some/example.html,nginx 会发送 /data/www/some/example.html 文件。
修改了配置文件之后,为使新配置生效,可重启 nginx ,或者者用 nginx 命令发送 reload 信号给 nginx 主进程:
nginx -s reload
Note:
当出现了错误,请查看 access.log 和 error.log 文件寻觅可可以的起因。
这两个文件的位置假如是 yum 安装,在 /var/log/nginx 目录下,假如是编译安装,
默认在 prefix/logs/ 目录下。
将 nginx 配置为简单的代理商服务器
——————————–
nginx 经常被使用来设置成一个代理商服务器,这时 nginx 接收请求,而后将请求转发给被代理商的后台服务器,并从后台服务器取回响应报文,而后发送给用户端。
我们将配置一个基础的代理商服务器,服务器对于 image 文件的请求选择从本地响应,对于其余请求,服务器转发给一个后台服务器。在这个示例中,这两个服务器将被定义在同一个 nginx 实例之上。首先定义后台服务器,增加一个 server 区块定义:
server {
listen 8080;
root /data/up1;
location / {
}
}
这个服务器监听在 8080 端口(在前一小节的配置中,我们并没有指定 listen 指令,nginx 默认用 80 端口),并将所有请求映射到本地的 /data/up1 目录中。创立 /data/up1 目录,并在其中创立一个 index.html 文件。注意 root 指令被放置于 server context 中,这样只有当一个没有包含自己的 root 指令的 location 区块被选中时,这个 server 区块中的 root 指令才会被用。
[root@lamp1 nginx]# mkdir /data/up1[root@lamp1 nginx]# echo “
backend server
” > /data/up1/index.html
下一步,沿使用前一小节的配置,将其修改为一个代理商服务器的配置。在第一个 locaiton 区块中加入 proxy_pass 指令,指定后台服务器的:协议、主机名、端口(本例中,指定为 http://localhost:8080):
server {
location / {
proxy_pass http://localhost:8080/;
}
location /images/ {
root /data;
}
}
我们将修改第二个 location 区块,目前这个 location 区块将 URI 以 /images/ 起始的请求映射到
/data/images 目录。将其修改为可以够匹配对于典型图像文件的请求,这些图像文件有典型的后缀名:
location ~ \.(gif|jpg|png)$ {
root /data/images;
}
在 “location ~ \.(gif|jpg|png)$” 语句中, ~ EXPRESSION 表示用正则表达式匹配,
正则表达式为:\.(gif|jpg|png)$。
这个正则表达式可以够匹配所有以 .gif, .jpg, .png 结尾的 URI。匹配的请求将被映射到 /data/images 目录中。
当 nginx 选择以哪个 location 区块匹配请求时,nginx 首先检查指定了 prefix 前缀的 location 指令,nginx 会记住被匹配的拥有最长 prefix 的 location 指令,而后开始检查正则表达式。
假如有一个正则表达式被匹配了,nginx 会选择这个正则表达式的 location,假如没有正则表达式被匹配,它选择之前记下的那个拥有最长前缀的 location。
最终我们的配置文件是这样的:
server {
location / {
proxy_pass http://localhost:8080/;
}
location ~ \.(gif|jpg|png)$ {
root /data/images;
}
}
nginx 服务器会过滤以 .gif, .jpg, .png 为结尾的 URI 的请求,将它们映射到 /data/images 目录中(将 URI 增加到 root 指令的参数后面),并将其余请求转发给后台服务器。
使新的配置生效,执行 nginx -s reload。
在另一个 Linux 虚拟机中测试访问:
[root@vm1 nginx]# curl http://192.168.0.171
backend server
在浏览器中访问:
https://img.songma.com/wenzhang/20180605/fkdltlghnzt2682.jpg
关于配置代理商连接,更深入的讨论可参考:
http://nginx.org/en/docs/http/ngx_http_proxy_module.html
设置 FastCGI 代理商
————————
nginx 可使用于将请求路由到 FastCGI 服务器,在 FastCGI 服务器上运行着以各种框架和编程语言构建的应使用,比方 PHP。
配置 nginx 与 FastCGI 服务器协同工作,最基础的配置包括:用 fastcgi_pass 指令替代 proxy_pass指令,并用 fastcgi_param 指令设置传递给 FastCGI 服务器的参数。
假设 FastCGI 服务器可通过 localhost:9000 访问,我们以前面的配置为基础,首先将 proxy_pass 指令替换为 fastcgi_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;
}
}
通过这个配置,对于静态图形文件的请求由本地服务响应,除此之外的请求将通过 FastCGI 协议
被路由到工作于 localhost:9000 的服务器上。
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » nginx 初学者指引