nginx的配置文件默认在nginx安装目录中的conf子目录中,主配置文件为nginx.conf,
root@mgmserver conf]# pwd
/usr/local/nginx/conf
1、配置文件
[root@mgmserver conf]# vi nginx.conf
1
2 #user nobody; #指定运行的用户和组;
3 worker_processes 1; #工做进程数,通常与CPU核数相同或是2倍;
4#指定全局错误日志的路径,错误日志可选项 有[debug|info|notice|warn|error|crit]
5 #error_log logs/error.log;
6 #error_log logs/error.log notice;
7 #error_log logs/error.log info;
8
9 #pid logs/nginx.pid; #指定pid文件存放的路径
10
11
12 events {
use epoll;使用的网络I/O模式,LINUX下使用epoll模型;freebsd使用kqueue模型;在events 这里,默认的是否是没有设置使用的模型;若是要使用epoll 模型要在安装时带上--with-poll_module=epoll;
13 worker_connections 1024; #容许的链接数;
14 }
15
16#设定http服务器,利用它的反向代理功能提供负载均衡支持;
17 http {
18 include mime.types; #设定mime类型;
19 default_type application/octet-stream;
20#设置日志格式
21 #log_format main '$remote_addr - $remote_user [$time_local] "$request" '
22 # '$status $body_bytes_sent "$http_referer" '
23 # '"$http_user_agent" "$http_x_forwarded_for"';
24
25 #access_log logs/access.log main;
26
27 sendfile on; #默认开启sendfile,sendfile能有效提升web传输文件的效率,nginx会自动使用
28 #tcp_nopush on; #容许或禁止使用socket的tcp_nopush(on freebsd)或tcp_cork(on linux)选项,这个选项仅仅使用sendfile的时候能够用。
tcp_nodelay on;
转帖自:http://blog.phpwap.net/?p=14对TCP_NODELAY 和 TCP_CORK的解释,
这两个选项都对网络链接的行为具备重要的做用。许多UNIX系统都实现了 TCP_NODELAY选项,可是,TCP_CORK则是Linux系统所独有的 并且相对较新;它首先在内核版本2.4上得以实现。此外,其余UNIX系统版本也有功能相似的选项,值得注意的是,在某种由BSD派生的系统上的 TCP_NOPUSH选项其实就是TCP_CORK的一部分具体实现。
TCP_NODELAY和TCP_CORK基本上控制了包的“Nagle 化”,Nagle化在这里的含义是采用Nagle算法把较小的
包组装为更大的帧。 John Nagle是Nagle算法的发明人,后者就是用他的名字来命名的,他在1984年首次用这种方法来尝试解决福特汽车公司的网络拥塞问题(欲了解详情请参 看IETF RFC 896)。他解决的问题就是所谓的silly window syndrome ,中文称“愚蠢窗口症候群”,具体含义是,由于广泛终端应用程序每产生一次击键操做就会发送一个包,而典型状况下一个包会拥有一个字节的数据载荷以及40 个字节长的包头,因而产生4000%的过载,很轻易地就能令网络发生拥塞,。 Nagle化后来成了一种标准而且当即在因特网上得以实现。它如今已经成为缺省配置了,但在咱们看来,有些场合下把这一选项关掉也是合乎须要的。
如今让咱们假设某个应用程序发出了一个请求,但愿发送小块数据。咱们能够选择当即发送数据或者等待产生更多的数据而后再一次发送两种策略。若是咱们立刻发 送数据,那么交互性的以及客户/服务器型的应用程序将极大地受益。例如,当咱们正在发送一个较短的请求而且等候较大的响应时,相关过载与传输的数据总量相 比就会比较低,并且,若是请求当即发出那么响应时间也会快一些。以上操做能够经过设置套接字的TCP_NODELAY选项来完成,这样就禁用了Nagle 算法。
另一种状况则须要咱们等到数据量达到最大时才经过网络一次发送所有数据,这种数据传输方式有益于大量数据的通讯性能,典型的应用就是文件服务器。应用 Nagle算法在这种状况下就会产生问题。可是,若是你正在发送大量数据,你能够设置TCP_CORK选项禁用Nagle化,其方式正好同 TCP_NODELAY相反(TCP_CORK 和 TCP_NODELAY 是互相排斥的)。下面就让咱们仔细分析下其工做原理。
假设应用程序使用sendfile()函数来转移大量数据。应用协议一般要求发送某些信息来预先解释数据,这些信息其实就是报头内容。典型状况下报头很 小,并且套接字上设置了TCP_NODELAY。有报头的包将被当即传输,在某些状况下(取决于内部的包计数器),由于这个包成功地被对方收到后须要请求 对方确认。这样,大量数据的传输就会被推迟并且产生了没必要要的网络流量交换。
可是,若是咱们在套接字上设置了TCP_CORK(能够比喻为在管道上插入“塞子”)选项,具备报头的包就会填补大量的数据,全部的数据都根据大小自动地 经过包传输出去。当数据传输完成时,最好取消TCP_CORK 选项设置给链接“拔去塞子”以便任一部分的帧都能发送出去。这同“塞住”网络链接同等重要。
总而言之,若是你确定能一块儿发送多个数据集合(例如HTTP响应的头和正文),那么咱们建议你设置TCP_CORK选项,这样在这些数据之间不存在延迟。能极大地有益于WWW、FTP以及文件服务器的性能,同时也简化了你的工做。示例代码以下:
intfd, on = 1;
…
/* 此处是建立套接字等操做,出于篇幅的考虑省略*/
…
setsockopt (fd, SOL_TCP, TCP_CORK, &on, sizeof (on)); /* cork */
write (fd, …);
fprintf (fd, …);
sendfile (fd, …);
write (fd, …);
sendfile (fd, …);
…
on = 0;
setsockopt (fd, SOL_TCP, TCP_CORK, &on, sizeof (on)); /* 拔去塞子 */
不幸的是,许多经常使用的程序并无考虑到以上问题。例如,Eric Allman编写的sendmail就没有对其套接字设置任何选项。
Apache HTTPD是因特网上最流行的Web服务器,它的全部套接字就都设置了TCP_NODELAY选项,并且其性能也深受大多数用户的满意。这是为何呢?答 案就在于实现的差异之上。由BSD衍生的TCP/IP协议栈(值得注意的是FreeBSD)在这种情况下的操做就不一样。当在TCP_NODELAY 模式下提交大量小数据块传输时,大量信息将按照一次write()函数调用发送一块数据的方式发送出去。然而,由于负责请求交付确认的记数器是面向字节而 非面向包(在Linux上)的,因此引入延迟的几率就下降了不少。结果仅仅和所有数据的大小有关系。而 Linux 在第一包到达以后就要求确认,FreeBSD则在进行如此操做以前会等待好几百个包。
在Linux系统上,TCP_NODELAY的效果同习惯于BSD TCP/IP协议栈的开发者所指望的效果有很大不一样,并且在Linux上的Apache性能表现也会更差些。其余在Linux上频繁采用TCP_NODELAY的应用程序也有一样的问题。
#设定请求缓冲;
client_header_buffer_size 1k;
large_client_header_size 50k;
#设定客户端可以上传文件的大小
client_max_body_size 8m;
29
30 #keepalive_timeout 0;
31 keepalive_timeout 65;
32
33 #gzip on; #是否开启gzip压缩模块
34#设定虚拟主机
35 server {
36 listen 80; #监听端口
37 server_name localhost;#主机名称
38
39 #charset koi8-r;#设置使用字符集
40
41 #access_log logs/host.access.log main;#访问日志文件存放路径
42
43 location / {
44 root html;#网页存放的目录,也但是绝对路径
45 index index.html index.htm;#默认首页顺序
46 }
47
48 error_page 404 /404.html;
49
50 # redirect server error pages to the static page /50x.html
51 #
52 error_page 500 502 503 504 /50x.html;
53 location = /50x.html {
54 root html;
55 }
56
57 # proxy the PHP scripts to Apache listening on 127.0.0.1:80
58 #
59 #location ~ \.php$ {
60 # proxy_pass http://127.0.0.1;
61 #}
62
63 # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
64 #
65 #location ~ \.php$ {
66 # root html;
67 # fastcgi_pass 127.0.0.1:9000;
68 # fastcgi_index index.php;
69 # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
70 # include fastcgi_params;
71 #}
72
73 # deny access to .htaccess files, if Apache's document root
74 # concurs with nginx's one
75 #
76 #location ~ /\.ht {
77 # deny all;
78 #}
79 }
80
81
82 # another virtual host using mix of IP-, name-, and port-based configuration
83 #
84 #server {
85 # listen 8000;
86 # listen somename:8080;
87 # server_name somename alias another.alias;
88
89 # location / {
90 # root html;
91 # index index.html index.htm;
92 # }
93 #}
94
95
96 # HTTPS server
97 #
98 #server {
99 # listen 443;
100 # server_name localhost;
101
102 # ssl on;
103 # ssl_certificate cert.pem;
104 # ssl_certificate_key cert.key;
105
106 # ssl_session_timeout 5m;
107
108 # ssl_protocols SSLv2 SSLv3 TLSv1;
109 # ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP;
110 # ssl_prefer_server_ciphers on;
111
112 # location / {
113 # root html;
114 # index index.html index.htm;
115 # }
116 #}
117
118 }
=========================================================
2、配置文件格式:上面的是nginx.conf的配置示例,有些是添加上去的,主要构成能够简化为:
......
events
{
......
}
http{
......
server{
......
}
server{
.......
}
.......
}
实际上这么分开咱们就能一目了然的看到nginx.conf配置文件的结构,不是很难;
3、nginx的代理文件注释
proxy_redirect off;
#proxy_set_header 指令用于在反向代理的后端web服务器发起请求时添加指定的header头信息;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
#容许客户端请求的最大单个文件字节数;
client-max_body_size 10m;
#缓冲区代理缓冲用户端请求的最大字节数,能够理解为先保存到本地再传给用户;
client_body_buffer_size 128;
#跟后端服务器链接超时时间,发起握手等候响应超时时间;
poxy_connect_timeout 5;
#链接成功后,等候后端服务器响应时间,其实已经进入后端的排队之中等候处理;
proxy_read_timeout 60;
#后端服务器数据回传时间,就是规定时间内后端服务器必须传完全部的数据;
proxy_send_timeout 5;
#代理请求缓存区,这个缓存区见会保护用户的头信息以提供nginx进行校对规则,通常只要能保存下头
#信息便可
proxy_buffer_size 16k;
#同上 ,告诉nginx保存单个用的几个buffer最大用多大空间
proxy_buffers 4 64k;
#若是系统很忙的时候能够申请更大的proxy_buffers官方推荐×2
proxy_busy_buffers_size 128k;
#proxy缓存临时文件的大小;
proxy_temp_file_write_size 128k;php