Nginx安装完成,能够正常跑起来后,如果想要采用nginx作为负载均衡的服务器则在配置中修改对应参数即可,如果要使用nginx作为HTTPServer处理私有业务逻辑,一般都是不能满足我们的需求的。
所以,一般都是采用nginx+X的架构,X模块可以自己根据自己的需求进行二次开发或者安装第三方。
如果自己在nginx上进行二次开发,这样对开发者要求较高,需要开发者对nginx足够了解才能进行
而第三方模块安装是比较方便的,而且nginx也有很多可以在网上搜到的开源模块,只需要在安装配置的时候进行配置即可。如下:
./configure --prefix=/opt/nginx --add-module=X
本篇暂时先不讨论二次开发和安装第三方的问题,因为我们拿到nginx跑起来后,第一件事情肯定是要把它的配置搞清楚,而且大多数是为了实现负载均衡。
网上讲述nginx.conf配置的文章有很多,但是有些过于笼统,真正用得到的还是需要我们在搭建过程中的不断实践。
所以我们挑拣出比较重要的几个来看(部分注释搜集自网络):
worker_processes 1; #启动进程数,一般和CPU数目相等
#全局错误日志及PID文件
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
use epoll;#epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能
worker_connections 1024;#单个后台worker process进程的最大并发链接数,一般设置为系统支持的最大连接数,可通过ulimit -n进行查看
}
http {
#设定mime类型,类型由mime.type文件定义
include mime.types;
default_type application/octet-stream; #默认的类型
#设置日志格式
#access_log logs/access.log main;
#sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
#必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
sendfile on;
#tcp_nopush on;
#连接超时时间,可自行设置
#keepalive_timeout 0;
keepalive_timeout 65;
#开启gzip压缩,还没弄明白这个意思
#gzip on;
#设定负载均衡的服务器列表
#weigth参数表示权值,权值越高被分配到的几率越大
upstream mysvr1 {
server 127.0.0.1:3332 weight=5;
}
upstream mysvr2 {
server 192.168.0.111:80 weight=3;
}
#本地Server配置模块
server {
listen 8080;#开启监听端口
server_name localhost;#可以使用127.0.0.1或者本机真实IP访问
#默认请求路径
location / {
root html; #定义服务器的默认根目录,其他的资源都从这个位置查找
index index.html index.htm; #定义默认的文件名称
}
#定义错误提示界面 在html目录下找到50x.html文件
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
#转发设置
#对aspx后缀的所有请求都进行转发,转发的服务器列表在下级属性proxy_pass中进行描述
location ~ .*\.aspx$ {
root html;
index index.html index.htm;
proxy_pass http://mysvr; #请求转向mysvr 定义的服务器列表
#当前的配置,如果请求的url是http://servername:8080/test.aspx
#会被代理成http://mysvr/test.aspx
#以下是在网络上找到的一些反向代理的配置,目前在学习中暂时未用到,可供以后翻阅参考
proxy_redirect off; #参数off将在这个字段中禁止所有的proxy_redirect指令
#假设被代理服务器返回Location字段为: http://localhost:8000/two/some/uri/
#这个指令: proxy_redirect http://localhost:8000/two/ http://frontend/one/;
#将Location字段重写为http://frontend/one/some/uri/。
proxy_set_header Host $host;#后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 10m; #允许客户端请求的最大单文件字节数
client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数,
proxy_connect_timeout 90; #nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout 90; #后端服务器数据回传时间(代理发送超时)
proxy_read_timeout 90; #连接成功后,后端服务器响应时间(代理接收超时)
proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2)
proxy_temp_file_write_size 64k; #设定缓存文件夹大小
}
}