nginx 初学者指引

编译自:
http://nginx.org/en/docs/beginners_guide.html

** 目录
nginx 启动、停止、重新加载配置
nginx 配置文件的结构
nginx 提供静态内容的服务
将 nginx 配置为简单的代理服务器
nginx 设置 FastCGI 代理,连接 FastCGI 应用 **

本文会简单介绍 nginx 并演示相关的简单任务。首先你需要安装好 nginx。

nginx 拥有一个主进程和几个 worker 进程。主进程的主要工作是读取和处理配置,维护 worker 进程。worker 进程负责处理实际的用户请求。nginx 采用 event-based 模型和 OS-dependent 机制对用户请求进行高效的分发。worker 进程的数量在配置文件中定义,可在配置中修改,或者根据可用的 CPU 核心数进行自动调整。参考 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 "<h1>HTML File</h1>" > /data/www/index.html

然后创建 /data/images 目录,放一些图像文件到该目录中。

之后打开配置文件。默认的配置文件已经包含一些 server 区块的示例,大多数被注释了。
现在将所有 server 区块注释掉,然后创建一个新的 server 区块:

http {
    server {
    }
}

一般来说,配置文件可能包含几个 server 区块,它们拥有不同的监听端口(listen指令)和 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 目录中的文件发送给客户端。

例如,对于访问请求:http://localhost/images/example.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 "<h1>backend server</h1>" > /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)$” 语句中, ~ 表示使用正则表达式匹配,
正则表达式为:\.(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
<h1>backend server</h1>

在浏览器中访问:
http://192.168.0.171/p1035007771.jpg

关于配置代理连接,更深入的探讨可参考:ngx_http_proxy_module

设置 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 / {
        root /data/www;
        fastcgi_index index.php;
        fastcgi_pass  localhost:9000;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param QUERY_STRING    $query_string;
    }
    location ~ \.(gif|jpg|png)$ {
        root /data/images;
    }
}

通过这个配置[1],对于静态图形文件的请求由本地服务响应,除此之外的请求将通过 FastCGI 协议被路由到工作于 localhost:9000 的服务器上。

创建测试文件:

echo "<?php phpinfo(); ?>" >> /data/www/index.php

使用浏览器访问 http://192.168.0.171 (这里替换为你的服务器 IP 地址),即可看到 php 的测试页面。


版权信息
本文编译自 nginx.org ,遵循其原来的 licence 声明: 2-clause BSD-like license


  1. 译者根据自己的测试情况,修改了该配置

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,875评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,569评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,475评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,459评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,537评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,563评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,580评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,326评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,773评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,086评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,252评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,921评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,566评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,190评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,435评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,129评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,125评论 2 352

推荐阅读更多精彩内容

  • 1. Nginx的模块与工作原理 Nginx由内核和模块组成,其中,内核的设计非常微小和简洁,完成的工作也非常简单...
    rosekissyou阅读 10,207评论 5 124
  • 第一章 Nginx简介 Nginx是什么 没有听过Nginx?那么一定听过它的“同行”Apache吧!Ngi...
    JokerW阅读 32,661评论 24 1,002
  • Nginx简介 解决基于进程模型产生的C10K问题,请求时即使无状态连接如web服务都无法达到并发响应量级一万的现...
    魏镇坪阅读 1,997评论 0 9
  • 《老男孩Linux运维》笔记 隐藏Nginx软件版本号 一般来说,软件的漏洞都和版本有关。因此要尽量隐藏对访问用户...
    Zhang21阅读 3,635评论 0 28
  • 1.ngnix介绍 ngnix www服务软件 俄罗斯人开发 开源 性能很高 本身是一款静态WWW软件 静态小文件...
    逗比punk阅读 2,088评论 1 6