nginx 详解

#运行用户

#user  nobody;

#启动进程,通常设置成和cpu的数量相等或者2倍于cpu的个数(具体结合cpu和内存)。默认为1

worker_processes  1;

#全局的错误日志和日志级别[ debug | info | notice | warn | error | crit ]

#error_log  logs/error.log;

#error_log  logs/error.log  notice;

#error_log  logs/error.log  info;

#pid进程文件

#pid        logs/nginx.pid;

#一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(系统的值ulimit -n)

#与nginx进程数相除,但是nginx分配请求并不均匀,所以建议与ulimit -n的值保持一致。

#默认不需设置

#worker_rlimit_nofile 65535;

#工作模式以及连接数上限

events {

    #epoll是多路复用IO(I/O Multiplexing)中的一种方式,

    #仅用于linux2.6以上内核,可以大大的提高nginx的性能

    #参考事件模型,use [ kqueue | rtsig | epoll | /dev/poll | select | poll ];

    #在FreeBSD上面,就用kqueue模型

    #window下没有epoll

    #use epoll;

    

    #单个后台worker process进程的最大并发连接数。默认为1024

    #单个进程最大连接数(最大连接数=连接数*进程数)

    worker_connections  1024;

    

    #并发总数是worker_processes和worker_connections的乘积

    #即 max_clients=worker_processes * worker_connections

    #在设置了反向代理的情况下,max_clients=worker_processes * worker_connections / 4

    #worker_connections 值的设置跟物理内存大小有关

    #因为并发受IO约束,max_clients的值须小于系统可以打开的最大文件数

    #而系统可以打开的最大文件数和内存大小成正比,一般1GB内存的机器上可以打开的文件数大约是10万左右

    #我们来看看360M内存的VPS可以打开的文件句柄数是多少:

    #$ cat /proc/sys/fs/file-max

    #输出 34336

    #32000 < 34336,即并发连接总数小于系统可以打开的文件句柄总数,这样就在操作系统可以承受的范围之内

    #所以,worker_connections 的值需根据 worker_processes 进程数目和系统可以打开的最大文件总数进行适当地进行设置

    #使得并发总数小于操作系统可以打开的最大文件数目

    #其实质也就是根据主机的物理CPU和内存进行配置

    #当然,理论上的并发总数可能会和实际有所偏差,因为主机还有其他的工作进程需要消耗系统资源。

    #ulimit -SHn 65535

}

#设定http服务器

http {

    #设定mime类型,类型由mime.type文件定义。文件扩展名与文件类型映射表

    include       mime.types;

    

    ##默认文件类型

    default_type  application/octet-stream;

    

    #默认编码

    #charset utf-8; 

    

    #服务器名字的hash表大小

    #server_names_hash_bucket_size 128; 

    

    #上传文件大小限制

    #client_header_buffer_size 32k; 

    

    #设定请求缓

    #large_client_header_buffers 4 64k; 

    

    #设定请求缓

    #client_max_body_size 8m; 

    

    #开启高效文件传输模式,sendfile指令指定nginx是否调用sendfile函数来输出文件,

    #对于普通应用设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off,

    #以平衡磁盘与网络I/O处理速度,降低系统的负载。注意:如果图片显示不正常把这个改成off。默认开启状态

    sendfile on; 

    

    #开启目录列表访问,合适下载服务器,默认关闭。

    #autoindex on; 

    

    #防止网络阻塞

    #tcp_nopush on; 

    

    #防止网络阻塞

    #tcp_nodelay on; 

    

    #长连接超时时间,单位是秒

    #keepalive_timeout 120; 

    keepalive_timeout  65;

    

    #FastCGI相关参数是为了改善网站的性能:减少资源占用,提高访问速度。下面参数看字面意思都能理解。

    #fastcgi_connect_timeout 300;

    #fastcgi_send_timeout 300;

    #fastcgi_read_timeout 300;

    #fastcgi_buffer_size 64k;

    #fastcgi_buffers 4 64k;

    #fastcgi_busy_buffers_size 128k;

    #fastcgi_temp_file_write_size 128k;

    #gzip模块设置

    #开启gzip压缩输出

    #gzip on; 

    #gzip_min_length 1k; #最小压缩文件大小

    #gzip_buffers 4 16k; #压缩缓冲区

    #gzip_http_version 1.0; #压缩版本(默认1.1,前端如果是squid2.5请使用1.0)

    #gzip_comp_level 2; #压缩等级

    #gzip_types text/plain application/x-javascript text/css application/xml;

    #压缩类型,默认就已经包含text/html,所以下面就不用再写了,写上去也不会有问题,但是会有一个warn。

    #gzip_vary on;

    

    #开启限制IP连接数的时候需要使用

    #limit_zone crawler $binary_remote_addr 10m; 

    upstream www.xttblog.com {

        #upstream的负载均衡,weight是权重,可以根据机器配置定义权重。weigth参数表示权值,权值越高被分配到的几率越大。

        #server 192.168.80.121:80 weight=3;

        

        #每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。

        ip_hash;

        

        server 10.10.2.71:8080;

        #server 192.168.80.123:80 weight=3;

    }

    

    #设定日志格式

    #log_format  main  ‘$remote_addr - $remote_user [$time_local] "$request" ‘

    #                  ‘$status $body_bytes_sent "$http_referer" ‘

    #                  ‘"$http_user_agent" "$http_x_forwarded_for"‘;

    #access日志文件的路径,采用上面定义的main 格式记录

    #access_log  logs/access.log  main;   

    #虚拟主机的配置

    server {

        #侦听80端口

        listen       80;

        

        #定义使用 localhost,可以自定义域名访问

        #域名可以有多个,用空格隔开

        server_name  localhost;        

        #编码

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        #默认请求

        location / {

            proxy_pass http://www.xttblog.com;

            proxy_redirect off;

            proxy_set_header X-Real-IP $remote_addr;

            

            #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP

            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

            

            #以下是一些反向代理的配置,可选。

            proxy_set_header Host $host;

        

            #定义服务器的默认网站根目录位置

            root D:/apache-tomcat-6.0.41/webapps/test;

            

            #定义首页索引文件的名称。定义多个用空格分隔

            index index.jsp;

        }

        

        #定义404错误提示页面

        #error_page  404              /404.html;

        

        #定义50x错误提示页面

        error_page   500 502 503 504  /50x.html;

        location = /50x.html {

            #定义服务器的默认网站错误页面位置

            root   html;

        }

        #静态文件,nginx自己处理。正则表达式

        #location ~ ^/(images|javascript|js|css|flash|media|static|htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|pdf|xls|mp3|wma)/ {

            #过期30天,静态文件不怎么更新,过期可以设大一点,

            #如果频繁更新,则可以设置得小一点。

            #expires 30d;

        #}

        

        #禁止访问 .htxxx 文件

        #location ~ /\.ht {

        #    deny  all;

        #}

        

        #对 "/" 启用反向代理

        #location / {

            #proxy_pass http://127.0.0.1:88;

            #proxy_redirect off;

            #proxy_set_header X-Real-IP $remote_addr;

            

            #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP

            #proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

            

            #以下是一些反向代理的配置,可选。

            #proxy_set_header Host $host;

            

            #允许客户端请求的最大单文件字节数

            #client_max_body_size 10m; 

            

            #缓冲区代理缓冲用户端请求的最大字节数

            #client_body_buffer_size 128k; 

            

            #nginx跟后端服务器连接超时时间(代理连接超时)

            #proxy_connect_timeout 90; 

            

            #后端服务器数据回传时间(代理发送超时)

            #proxy_send_timeout 90; 

            

            #连接成功后,后端服务器响应时间(代理接收超时)

            #proxy_read_timeout 90; 

            

            #设置代理服务器(nginx)保存用户头信息的缓冲区大小

            #proxy_buffer_size 4k; 

            

            #proxy_buffers缓冲区,网页平均在32k以下的设置

            #proxy_buffers 4 32k; 

            

            #高负荷下缓冲大小(proxy_buffers*2)

            #proxy_busy_buffers_size 64k; 

            

            #设定缓存文件夹大小,大于这个值,将从upstream服务器传

            #proxy_temp_file_write_size 64k;

        #}

        

        #设定查看Nginx状态的地址

        #location /NginxStatus {

            #stub_status on;

            #access_log on;

            #auth_basic "NginxStatus";

            #auth_basic_user_file conf/htpasswd;

            #htpasswd文件的内容可以用apache提供的htpasswd工具来产生。

        #}

        

        #本地动静分离反向代理配置

        #所有jsp的页面均交由tomcat或resin处理

        #location ~ .(jsp|jspx|do)?$ {

            #proxy_set_header Host $host;

            #proxy_set_header X-Real-IP $remote_addr;

            #proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

            #proxy_pass http://127.0.0.1:8080;

        #}

        

    }

    #另一个虚拟主机使用混合的IP的配置

    #server {

    #    listen       8000;

    #    listen       somename:8080;

    #    server_name  somename  alias  another.alias;

    #    location / {

    #        root   html;

    #        index  index.html index.htm;

    #    }

    #}

    #HTTPS server的配置,默认不开启

    #server {

    #    listen       443 ssl;

    #    server_name  localhost;

    #    ssl_certificate      cert.pem;

    #    ssl_certificate_key  cert.key;

    #    ssl_session_cache    shared:SSL:1m;

    #    ssl_session_timeout  5m;

    #    ssl_ciphers  HIGH:!aNULL:!MD5;

    #    ssl_prefer_server_ciphers  on;

    #    location / {

    #        root   html;

    #        index  index.html index.htm;

    #    }

    #}

}

时间: 2024-11-05 17:22:07

nginx 详解的相关文章

【转】Web服务器之Nginx详解(理论部分)

大纲 一.前言 二.Web服务器提供服务的方式 三.多进程.多线程.异步模式的对比 四.Web 服务请求过程 五.Linux I/O 模型 六.Linux I/O 模型具体说明 七.Linux I/O模型的具体实现 八.Apache 的工作模式 九.支持高并发的Web服务器 十.Nginx 详解 一.前言 注,在说Web服务器之前,先说说线程.进程.以及并发连接数. 1.进程与线程 进程是具有一定独立功能的程序,关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位.从逻辑

Nginx 详解 (二)

13.反向代理模块   (1).常用指令: l  proxy_connect_timeout:nginx将一个请求发送至upstream server之前等待的最大时长: l  proxy_cookie_domain:将upstreamserver通过Set-Cookie首部设定的domain属性修改为指定的值,其值可以为一个字符串.正则表达式的模式或一个引用的变量: l  proxy_cookie_path: 将upstream server通过Set-Cookie首部设定的path属性修改为

nginx详解及配置

Nginx特性:     模块化设计.较好的扩展性:       高可靠       master --> worker       低内存消耗       10000个keep-alive模式下的connection,仅需要2.5MB的内存:       支持热部署       不停机而更新配置文件.日志文件滚动.升级程序版本: 支持事件驱动.AIO.mmap: 基本功能:      静态资源的web服务器,能缓存打开的文件描述符:       http.smtp.pop3协议的反向代理服务器

第十四章 nginx详解

14.1 nginx简介 Nginx(发音同engine x)是一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like协议下发行. Nginx由俄罗斯的程序设计师Igor Sysoev所开发,最初供俄国大型的入口网站及搜寻引擎Rambler使用. 第一个公开版本0.1.0发布于2004年10月4日.其将源代码以类BSD许可证的形式发布,因它的稳定性.丰富的功能集.示例配置文件和低系统资源的消耗而闻名.2011年6月1日,nginx 1.0.4

Nginx详解(二)操作

一.前言二.Nginx安装三.Nginx的配置文件详解四.nginx配置之http段五.其他模块六.实验 一.前言http://www.nginx.cn/doc/  nginx安装等各个操作界面介绍Nginx主要实现两个功能:Web服务器和反向代理Nginx的模块类型:    核心模块:core module    标准模块:        Stanard HTTP modules        Optional HTTP modules        Mail modules    第三方模块

nginx详解反向代理、负载均衡、LNMP架构上线动态网站

nginx介绍 Nginx是俄罗斯人编写的十分轻量级的HTTP服务器,Nginx,它的发音为“engine X”,是一个高性能的HTTP和反向代理服务器,同时也是一个IMAP/POP3/SMTP 代理服务器.Nginx是由俄罗斯人 Igor Sysoev为俄罗斯访问量第二的 Rambler.ru站点开发的,它已经在该站点运行超过两年半了.Igor Sysoev在建立的项目时,使用基于BSD许可. nginx和apache区别 Nginx 轻量级,采用 C 进行编写,同样的 web 服务,会占用更

nginx详解

Nginx是一款<strong>轻量级高性能的http和反向代理服务器</strong>,并且还是一个<strong>邮件代理服务器</strong>. Nginx与apache的区别    1.Nginx默认是<strong>异步单进程非阻塞工作模式</strong>,一个进程连接多个线程,一个线程对应一个请求连接,采用<strong>epoll(事件驱动)IO模型</strong>,占用资源少,高性能高并发

Nginx详解-服务器集群

Nginx是什么 代理服务器:一般是指局域网内部的机器通过代理服务器发送请求到互联网上的服务器,代理服务器一般作用在客户端.应用比如:GoAgent,FQ神器.  一个完整的代理请求过程为:客户端首先与代理服务器创建连接,接着根据代理服务器所使用的代理协议,请求对目标服务器创建连接.或者获得目标服务器的指定资源. Web代理(proxy)服务器是网络的中间实体. 代理位于Web客户端和Web服务器之间,扮演“中间人”的角色.HTTP的代理服务器即是Web服务器又是Web客户端. 代理服务器是介于

Nginx详解-服务器集群(转载)

Nginx是什么 代理服务器:一般是指局域网内部的机器通过代理服务器发送请求到互联网上的服务器,代理服务器一般作用在客户端.应用比如:GoAgent,FQ神器.  一个完整的代理请求过程为:客户端首先与代理服务器创建连接,接着根据代理服务器所使用的代理协议,请求对目标服务器创建连接.或者获得目标服务器的指定资源. Web代理(proxy)服务器是网络的中间实体. 代理位于Web客户端和Web服务器之间,扮演"中间人"的角色.HTTP的代理服务器即是Web服务器又是Web客户端. 代理服

Nginx详解(正向代理、反向代理、负载均衡原理)

nginx概述 nginx是一款自由的.开源的.高性能的HTTP服务器和反向代理服务器:同时也是一个IMAP.POP3.SMTP代理服务器:nginx可以作为一个HTTP服务器进行网站的发布处理,另外nginx可以作为反向代理进行负载均衡的实现. 这里主要通过三个方面简单介绍nginx 反向代理 负载均衡 nginx特点 1. 反向代理 关于代理 说到代理,首先我们要明确一个概念,所谓代理就是一个代表.一个渠道: 此时就设计到两个角色,一个是被代理角色,一个是目标角色,被代理角色通过这个代理访问