`

Nginx完整配置说明

 
阅读更多
#用户 用户组   
user       www www;   
#工作进程,根据硬件调整,有人说几核cpu,就配几个,我觉得可以多一点   
worker_processes  5;   
#错误日志   
error_log  logs/error.log;   
#pid文件位置   
pid        logs/nginx.pid;   
worker_rlimit_nofile 8192;   
  
events {   
#工作进程的最大连接数量,根据硬件调整,和前面工作进程配合起来用,尽量大,但是别把cpu跑到100%就行   
    worker_connections  4096;   
}   
  
http {   
    include    conf/mime.types;   
    #反向代理配置,可以打开proxy.conf看看   
    include    /etc/nginx/proxy.conf;   
    #fastcgi配置,可以打开fastcgi.conf看看   
    include    /etc/nginx/fastcgi.conf;   
  
    default_type application/octet-stream;   
    #日志的格式   
    log_format   main '$remote_addr - $remote_user [$time_local] $status '  
                      '"$request" $body_bytes_sent "$http_referer" '  
                      '"$http_user_agent" "$http_x_forwarded_for"';   
    #访问日志   
    access_log   logs/access.log  main;   
    sendfile     on;   
    tcp_nopush   on;   
    #根据实际情况调整,如果server很多,就调大一点   
    server_names_hash_bucket_size 128; # this seems to be required for some vhosts   
  
    #这个例子是fastcgi的例子,如果用fastcgi就要仔细看   
    server { # php/fastcgi   
        listen       80;   
        #域名,可以有多个   
        server_name  domain1.com www.domain1.com;   
        #访问日志,和上面的级别不一样,应该是下级的覆盖上级的   
        access_log   logs/domain1.access.log  main;   
        root         html;   
  
        location / {   
            index    index.html index.htm index.php;   
        }   
  
        #所有php后缀的,都通过fastcgi发送到1025端口上   
         #上面include的fastcgi.conf在此应该是有作用,如果你不include,那么就把fastcgi.conf的配置项放在这个下面。   
        location ~ \.php$ {   
            fastcgi_pass   127.0.0.1:1025;   
        }   
    }   
  
    #这个是反向代理的例子   
    server { # simple reverse-proxy   
        listen       80;   
        server_name  domain2.com www.domain2.com;   
        access_log   logs/domain2.access.log  main;   
  
        #静态文件,nginx自己处理   
        location ~ ^/(images|javascript|js|css|flash|media|static)/  {   
                root    /var/www/virtual/big.server.com/htdocs;   
                #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。   
                expires 30d;   
        }   
  
        #把请求转发给后台web服务器,反向代理和fastcgi的区别是,反向代理后面是web服务器,fastcgi后台是fasstcgi监听进程,当然,协议也不一样。   
        location / {   
            proxy_pass      http://127.0.0.1:8080;   
        }   
    }   
  
    #upstream的负载均衡,weight是权重,可以根据机器配置定义权重。据说nginx可以根据后台响应时间调整。后台需要多个web服务器。   
    upstream big_server_com {   
        server 127.0.0.3:8000 weight=5;   
        server 127.0.0.3:8001 weight=5;   
        server 192.168.0.1:8000;   
        server 192.168.0.1:8001;   
    }   
  
    server {   
        listen          80;   
        server_name     big.server.com;   
        access_log      logs/big.server.access.log main;   
  
        location / {   
                proxy_pass      http://big_server_com;   
        }   
    }   
} 

 

上面说的include的几个文件,都没有必要改,用的时候include一下就可以。

# fastcgi.conf   
fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;   
fastcgi_param  QUERY_STRING       $query_string;   
fastcgi_param  REQUEST_METHOD     $request_method;   
fastcgi_param  CONTENT_TYPE       $content_type;   
fastcgi_param  CONTENT_LENGTH     $content_length;   
fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;   
fastcgi_param  REQUEST_URI        $request_uri;   
fastcgi_param  DOCUMENT_URI       $document_uri;   
fastcgi_param  DOCUMENT_ROOT      $document_root;   
fastcgi_param  SERVER_PROTOCOL    $server_protocol;   
fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;   
fastcgi_param  SERVER_SOFTWARE    nginx/$nginx_version;   
fastcgi_param  REMOTE_ADDR        $remote_addr;   
fastcgi_param  REMOTE_PORT        $remote_port;   
fastcgi_param  SERVER_ADDR        $server_addr;   
fastcgi_param  SERVER_PORT        $server_port;   
fastcgi_param  SERVER_NAME        $server_name;   
  
fastcgi_index  index.php;  
 
# PHP only, required if PHP was built with --enable-force-cgi-redirect   
fastcgi_param  REDIRECT_STATUS    200; 

 

# proxy.conf   
proxy_redirect          off;   
proxy_set_header        Host            $host;   
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;   
proxy_send_timeout      90;   
proxy_read_timeout      90;   
proxy_buffers           32 4k;  

 

 

# mime.types   
types {   
    text/html                             html htm shtml;   
    text/css                              css;   
    text/xml                              xml rss;   
    image/gif                             gif;   
    image/jpeg                            jpeg jpg;   
    application/x-javascript              js;   
    text/plain                            txt;   
    text/x-component                      htc;   
    text/mathml                           mml;   
    image/png                             png;   
    image/x-icon                          ico;   
    image/x-jng                           jng;   
    image/vnd.wap.wbmp                    wbmp;   
    application/java-archive              jar war ear;   
    application/mac-binhex40              hqx;   
    application/pdf                       pdf;   
    application/x-cocoa                   cco;   
    application/x-java-archive-diff       jardiff;   
    application/x-java-jnlp-file          jnlp;   
    application/x-makeself                run;   
    application/x-perl                    pl pm;   
    application/x-pilot                   prc pdb;   
    application/x-rar-compressed          rar;   
    application/x-redhat-package-manager  rpm;   
    application/x-sea                     sea;   
    application/x-shockwave-flash         swf;   
    application/x-stuffit                 sit;   
    application/x-tcl                     tcl tk;   
    application/x-x509-ca-cert            der pem crt;   
    application/x-xpinstall               xpi;   
    application/zip                       zip;   
    application/octet-stream              deb;   
    application/octet-stream              bin exe dll;   
    application/octet-stream              dmg;   
    application/octet-stream              eot;   
    application/octet-stream              iso img;   
    application/octet-stream              msi msp msm;   
    audio/mpeg                            mp3;   
    audio/x-realaudio                     ra;   
    video/mpeg                            mpeg mpg;   
    video/quicktime                       mov;   
    video/x-flv                           flv;   
    video/x-msvideo                       avi;   
    video/x-ms-wmv                        wmv;   
    video/x-ms-asf                        asx asf;   
    video/x-mng                           mng;   
}

 

分享到:
评论

相关推荐

    nginx搭建配置详细说明

    3.1. Nginx的主配置文件概述 3.1.1. 认识配置文件 3.1.2. nginx的配置文件结构 3.1.3. nginx的全局配置 3.2. events配置 3.3. http的配置 3.4. nginx重要指令之location 4. nginx中的rewrite 4.1. 什么是...

    Nginx配置文件详细说明

    在此记录下Nginx服务器nginx.conf的配置文件说明, 部分注释收集与网络. #运行用户 user www-data; #启动进程,通常设置成和cpu的数量相等 worker_processes 1; #全局错误日志及PID文件 error_log /var/log/...

    Nginx配置文件说明.

    Nginx的配置文件通常位于/etc/nginx/nginx.conf或/usr/local/nginx/conf/nginx.conf,根据不同的系统和安装路径可能会有所差异。 在Nginx的配置文件中,主要有以下几个部分: 1. **全局块**:这部分设置影响Nginx...

    02nginx动态配置.zip

    在修改Nginx配置文件后,应先检查语法是否正确。可以使用`nginx -t`或`sudo nginx -t`命令进行测试,如果返回`configuration file /etc/nginx/nginx.conf test is successful`,则说明配置无误。然后重启Nginx以使...

    nginx详细配置说明

    ### Nginx详细配置说明 #### 一、Nginx简介与重要性 Nginx是一款高性能的HTTP和反向代理服务器,同时也是一款IMAP/POP3/SMTP代理服务器。它以其稳定性、丰富的功能集、示例配置文件和低资源消耗而著称。在现代...

    windows下 php+nginx配置详解

    以下是对"windows下 php+nginx配置详解"的详细说明。 首先,我们需要安装Nginx。Nginx是一款高性能的HTTP和反向代理服务器,以其稳定性和高并发处理能力著称。下载适用于Windows的Nginx安装包,然后按照安装向导...

    Nginx配置文件说明

    以下是对标题和描述中提及的Nginx配置文件部分知识点的详细说明: 1. **基本配置** - `user www www`: 这行指定Nginx运行时使用的用户和组,通常为非root用户以提高安全性。 - `worker_processes 1`: 定义了Nginx...

    Nginx安装配置、Resin安装配置说明文档

    2) Nginx配置 - 1 - a)对c:\nginx\conf\nginx.conf文件进行配置: - 1 - b)常用的 Nginx 参数 - 3 - c)静态文件处理 - 4 - d)动态页面请求处理 - 4 - e)下面为nginx.conf配置实例: - 5 - f)Nginx 启动,停止等命令 ...

    nginx简单配置说明(开发人员了解)

    ### Nginx简单配置说明(开发人员了解) #### 概述 本文档旨在为开发人员提供一份简明的Nginx配置指南。通过本指南,读者可以了解到如何在本地环境中安装并配置Nginx,使其能够顺利运行。Nginx是一款高性能的HTTP...

    nginx的各项详细配置-超多注释

    Nginx配置项详解 - **server_name**: 指定服务器域名,可以是多个,支持通配符。 - **root**: 设置网站根目录,用于定位静态资源。 - **index**: 指定默认首页文件,如"index.html index.htm"。 - **listen**: ...

    nginx配置的全说明

    nginx配置的全说明,对nginx配置不太清楚的小伙伴可以下载了

    NGINX-配置手册

    本指南主要聚焦于NGINX代理Tomcat应用服务器的相关配置,包括但不限于设置NGINX为系统服务、修改NGINX配置文件以及优化负载均衡策略等核心内容。 **文档约定:** - 使用统一的文档模板,以便于后续管理和更新。 - ...

    Nginx如何配置url_hash转发方式.docx

    如果看到80端口处于监听状态,说明Nginx已经成功启动。 7. **浏览器测试**: 通过浏览器访问Nginx服务器的IP地址,如`http://your_nginx_server_ip/`,如果能正常访问,表示Nginx安装成功。 8. **配置url_hash**...

    ubuntu+nginx安装配置应用说明

    对于更高级的配置,如SSL/TLS支持、反向代理、负载均衡等,你需要在Nginx配置文件中添加相应的指令。例如,为实现HTTPS,你需要获取SSL证书,并在服务器块中添加如下内容: ```nginx server { listen 443 ssl; ...

    nginx配置文件说明[参考].pdf

    【Nginx配置详解】 Nginx是一款高性能的HTTP和反向代理服务器,因其轻量级、高效能和高并发处理能力,在软件开发领域中被广泛使用。与Apache服务器相比,Nginx采用异步非阻塞的事件驱动模型,这使得它在处理大量...

    Nginx配置SSL自签名证书的方法

    3. **编辑Nginx配置文件**:找到Nginx的配置文件,通常是`/etc/nginx/nginx.conf`或`/usr/local/nginx/conf/nginx.conf`。添加一个新的`server`块,配置如下: ```nginx server { listen 80; listen 443 ssl; # ...

    Nginx 资源配置及说明

    Nginx配置文件是一个基础模板,用于设置和优化Nginx服务器。它帮助定义服务器运行的用户、工作进程数、日志记录位置等基本参数。配置文件还包含HTTP服务设置,如文件类型定义、日志格式、sendfile优化和gzip压缩等,...

    nginx配置详细说明

    非常有用, nginx配置详细说明。欢迎大家下载使用。

Global site tag (gtag.js) - Google Analytics