Stellen Sie vor der Installation von Nginx sicher, dass die Softwarebibliotheken gcc, openssl-devel, pcre-devel und zlib-devel installiert wurden System.
Das Folgende ist der Nginx-Installationsprozess:
wget http://nginx.org/download/nginx-1.0.14.tar.gz tar zxvf nginx-1.0.14.tar.gz ./configure --with-http_stub_status_module --prefix=/opt/nginx cd nginx-1.0.14 make make install
Unter anderem kann –with-http_stub_status_module verwendet werden, um die NginxStatus-Funktion von Nginx zu aktivieren, um den Betriebsstatus von Nginx zu überwachen .
Wenn Sie mehr über das Modul erfahren möchten, können Sie es über die Option ./configure –help anzeigen.
2. Struktur der Nginx-Konfigurationsdatei
Die Konfigurationsdatei nginx.conf von Nginx befindet sich im Verzeichnis conf des Installationsverzeichnisses.
nginx.conf besteht aus mehreren Blöcken. Der Hauptblock enthält Ereignisse und HTTP enthält mehrere Standorte:
Hauptblock Einstellungen), Server (Hosteinstellungen), Upstream (Lastausgleichsservereinstellungen) und Standort (URL entspricht Einstellungen für einen bestimmten Standort).
Der Code lautet wie folgt:
1 2 3 4 5 6 7 8 9 10 Nach dem Login kopieren |
user nobody nobody; worker_processes 2; error_log logs/error.log notice; pid logs/nginx.pid; worker_rlimit_nofile 65535; events{ use epoll; worker_connections 65536; } Nach dem Login kopieren |
use ist ein Ereignismodulbefehl, der zum Festlegen des Arbeitsmodus von Nginx verwendet wird. Die von Nginx unterstützten Arbeitsmodi sind select, poll, kqueue, epoll, rtsig und /dev/poll. Unter diesen sind Select und Poll Standardarbeitsmodi, kqueue und epoll sind effiziente Arbeitsmodi. Der Unterschied besteht darin, dass epoll auf der Linux-Plattform und kqueue auf dem BSD-System verwendet wird. Für Linux-Systeme ist der
epoll-Arbeitsmodus die erste Wahl. worker_connections ist auch eine Ereignismodulanweisung, mit der die maximale Anzahl von Verbindungen für jeden Nginx-Prozess definiert wird. Der Standardwert ist 1024. Die maximale Anzahl von Clientverbindungen wird durch worker_processes und worker_connections bestimmt, d. h. Max_client=worker_processes*worker_connections.
Bei der Funktion als Reverse-Proxy wird max_clients zu: max_clients = worker_processes * worker_connections/4.
Die maximale Anzahl an Verbindungen eines Prozesses wird durch die maximale Anzahl geöffneter Dateien des Linux-Systemprozesses begrenzt. Die Einstellung von worker_connections kann erst nach Ausführung des Betriebssystembefehls „ulimit -n 65536“ wirksam werden
2.2 HTTP-ServerkonfigurationDer Nginx-Konfigurationscode für HTTP-Server-bezogene Eigenschaften lautet wie folgt:
td> |
|
Im Folgenden finden Sie eine detaillierte Einführung in die Bedeutung jeder Konfigurationsoption in diesem Code.
include ist eine Hauptmodulanweisung, die das Festlegen von in der Konfigurationsdatei enthaltenen Dateien ermöglicht, wodurch die Komplexität der Hauptkonfigurationsdatei verringert werden kann. Ähnlich der include-Methode in Apache.
default_type gehört zur HTTP-Kernmodulanweisung. Hier wird der Standardtyp auf „Binary Stream“ festgelegt, der verwendet wird, wenn der Dateityp nicht definiert ist. Wenn die PHP-Umgebung beispielsweise nicht konfiguriert ist, analysiert Nginx ihn nicht . Zu diesem Zeitpunkt greifen Sie mit einem Browser auf die PHP-Datei zu und es erscheint ein Download-Fenster.
Der folgende Code legt das Protokollformat fest:
|
td> |
log_format是Nginx的HttpLog模块指令,用于指定Nginx日志的输出格式。main为此日志输出格式的名称,可以在下面的access_log指令中引用。
2.3 HttpGzip模块配置
下面配置Nginx的HttpGzip模块。这个模块支持在线实时压缩输出数据流。
看是否安装了HttpGzip模块:
[root@vps ~]# /opt/nginx/sbin/nginx -V nginx version: nginx/1.0.14 built by gcc 4.4.6 20110731 (Red Hat 4.4.6-3) (GCC) configure arguments: --with-http_stub_status_module --with-http_gzip_static_module --prefix=/opt/nginx
通过/opt/nginx/sbin/nginx -V命令可以查看安装Nginx时的编译选项,由输出可知,我们已经安装了HttpGzip模块。
下面是HttpGzip模块在Nginx配置中的相关属性设置:
1 2 3 4 5 6 7 Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren |
gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 2; gzip_types text/plain application/x-javascript text/css application/xml; gzip_vary on; Nach dem Login kopieren |
2.4 负载均衡配置
下面设定负载均衡的服务器列表:
1 2 3 4 5 6 7 Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren |
upstream cszhi.com{ ip_hash; server 192.168.8.11:80; server 192.168.8.12:80 down; server 192.168.8.13:8009 max_fails=3 fail_timeout=20s; server 192.168.8.146:8080; } Nach dem Login kopieren |
upstream是Nginx的HTTP Upstream模块,这个模块通过一个简单的调度算法来实现客户端IP到后端服务器的负载均衡。
在上面的设定中,通过upstream指令指定了一个负载均衡器的名称cszhi.com。这个名称可以任意指定,在后面需要的地方直接调用即可。
Nginx的负载均衡模块目前支持4种调度算法,下面进行分别介绍,其中后两项属于第三方的调度方法。
在HTTP Upstream模块中,可以通过server指令指定后端服务器的IP地址和端口,同时还可以设定每个后端服务器在负载均衡调度中的状态。常用的状态有:
注意,当负载调度算法为ip_hash时,后端服务器在负载均衡调度中的状态不能是weight和backup。
2.5 server虚拟主机配置
下面介绍对虚拟主机的配置。
建议将对虚拟主机进行配置的内容写进另外一个文件,然后通过include指令包含进来,这样更便于维护和管理。
1 2 3 4 5 6 7 Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren |
server{ listen 80; server_name 192.168.8.18 cszhi.com; index index.html index.htm index.php; root /wwwroot/www.cszhi.com charset gb2312; access_log logs/www.ixdba.net.access.log main; Nach dem Login kopieren |
server标志定义虚拟主机开始,listen用于指定虚拟主机的服务端口,server_name用来指定IP地址或者域名,多个域名之间用空格分 开。index用于设定访问的默认首页地址,root指令用于指定虚拟主机的网页根目录,这个目录可以是相对路径,也可以是绝对路径。Charset用于 设置网页的默认编码格式。access_log用来指定此虚拟主机的访问日志存放路径,最后的main用于指定访问日志的输出格式。
2.6 location URL匹配配置
URL地址匹配是进行Nginx配置中最灵活的部分。 location支持正则表达式匹配,也支持条件判断匹配,用户可以通过location指令实现Nginx对动、静态网页进行过滤处理。使用location URL匹配配置还可以实现反向代理,用于实现PHP动态解析或者负载负载均衡。
以下这段设置是通过location指令来对网页URL进行分析处理,所有扩展名以.gif、.jpg、.jpeg、.png、.bmp、.swf结尾的静态文件都交给nginx处理,而expires用来指定静态文件的过期时间,这里是30天。
1 2 3 4 Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren |
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ { root /wwwroot/www.cszhi.com; expires 30d; } Nach dem Login kopieren |
以下这段设置是将upload和html下的所有文件都交给nginx来处理,当然,upload和html目录包含在/web/wwwroot/www.cszhi.com目录中。
1 2 3 4 Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren |
location ~ ^/(upload|html)/ { root /web/wwwroot/www.cszhi.com; expires 30d; } Nach dem Login kopieren |
在最后这段设置中,location是对此虚拟主机下动态网页的过滤处理,也就是将所有以.jsp为后缀的文件都交给本机的8080端口处理。
1 2 3 4 Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren |
location ~ .*.php$ { index index.php; proxy_pass http://localhost:8080; } Nach dem Login kopieren |
2.7 StubStatus模块配置
StubStatus模块能够获取Nginx自上次启动以来的工作状态,此模块非核心模块,需要在Nginx编译安装时手工指定才能使用此功能。
以下指令实指定启用获取Nginx工作状态的功能。
1 2 3 4 5 6 Nach dem Login kopieren |
location /NginxStatus { stub_status on; access_log logs/NginxStatus.log; auth_basic "NginxStatus"; auth_basic_user_file ../htpasswd; } Nach dem Login kopieren |
stub_status设置为“on”表示启用StubStatus的工作状态统计功能。access_log 用来指定StubStatus模块的访问日志文件。auth_basic是Nginx的一种认证机制。auth_basic_user_file用来指定认证的密码文件,由于Nginx的auth_basic认证采用的是与Apache兼容的密码文件,因此需要用Apache的htpasswd命令来生成密码文件,例如要添加一个test用户,可以使用下面方式生成密码文件:
/usr/local/apache/bin/htpasswd -c /opt/nginx/conf/htpasswd test
然后输入两次密码后确认之后添加用户成功。
要查看Nginx的运行状态,可以输入http://ip/NginxStatus,输入创建的用户名和密码就可以看到Nginx的运行状态:
Active connections: 1 server accepts handled requests 34561 35731 354399 Reading: 0 Writing: 3 Waiting: 0
Active connections表示当前活跃的连接数,第三行的三个数字表示 Nginx当前总共处理了34561个连接, 成功创建次握手, 总共处理了354399个请求。最后一行的Reading表示Nginx读取到客户端Header信息数, Writing表示Nginx返回给客户端的Header信息数
,“Waiting”表示Nginx已经处理完,正在等候下一次请求指令时的驻留连接数。
在最后这段设置中,设置了虚拟主机的错误信息返回页面,通过error_page指令可以定制各种错误信息的返回页面。在默认情况下,Nginx会在主目录的html目录中查找指定的返回页面,特别需要注意的是,这些错误信息的返回页面大小一定要超过512K,否者会被ie浏览器替换为ie默认的错误页面。
1 2 3 4 5 6 7 Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren Nach dem Login kopieren |
error_page 404 /404.html; error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } } Nach dem Login kopieren |
整理自:http://ixdba.blog.51cto.com/2895551/790611
以上就介绍了Nginx安装及配置文件nginxconf详解,包括了方面的内容,希望对PHP教程有兴趣的朋友有所帮助。