前言

Nginx简介

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。
使用nginx的好处很多,用过的人都知道~

我们先来看看,nginx配置文件的结构:

... #全局块 

#events块 
events { 
 ... 
} 
http #http块 
{ 
 ... #http全局块 
 server #server块 
 {  
 ... #server全局块 
 location [PATTERN] #location块 
 { 
 ... 
 } 
 location [PATTERN]  
 { 
 ... 
 } 
 } 
 server 
 { 
 ... 
 } 
 ... #http全局块 
} 

具体的含义以及功能:
1、全局块:配置影响nginx全局的指令。一般有运行nginx服务器的用户组,nginx进程pid存放路径,日志存放路径,配置文件引入,允许生成worker process数等。

2、events块:配置影响nginx服务器或与用户的网络连接。有每个进程的最大连接数,选取哪种事件驱动模型处理连接请求,是否允许同时接受多个网路连接,开启多个网络连接序列化等。

3、http块:可以嵌套多个server,配置代理,缓存,日志定义等绝大多数功能和第三方模块的配置。如文件引入,mime-type定义,日志自定义,是否使用sendfile传输文件,连接超时时间,单连接请求数等。

4、server块:配置虚拟主机的相关参数,一个http中可以有多个server。

5、location块:配置请求的路由,以及各种页面的处理情况。

下面将自己的服务器上的nginx配置文件贴在下面,并且做一些简要的分析,以供自己查阅以及大家参考


#user  nobody;  #配置用户或组,默认的为nobody

worker_processes  1;#允许生成的进程数,默认为1

#error_log  logs/error.log; #指定日志路径、级别、这个设置可以放在http块,server块中
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid; # 指定nginx运行进程文件的存放地址

events {
    worker_connections  1024; #最大连接数,默认为512
}

#
http {
    include       mime.types; #文件扩展名以及文件类型映射表
    default_type  application/octet-stream; #默认文件类型,默认为text/plain  

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main; #以上为日志文件配置

    sendfile        on; #允许sendfile方式传输文件,默认为off,可以在http块,server块,location块。 
    #tcp_nopush     on; 

    #keepalive_timeout  0; #连接超时时间,默认为75s,可以在http,server,location块
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80; #监听的端口
        server_name  mblog.cloud; # 监听的地址

        #charset koi8-r;

        #access_log  logs/host.access.log  main;
	client_max_body_size 1024m; 
	#监听的地址
        location / {
        #    root   html;
        #    index  index.html index.htm;
	    #代理的真实地址
            proxy_pass http://127.0.0.1:8080;
    	    proxy_set_header HOST $host;
            proxy_set_header X-Forwarded-Proto $scheme;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; #设置请求头
        }

        #error_page  404              /404.html; # 错误页设置

        # redirect server error pages to the static page /50x.html
        #
       # error_page   500 502 503 504  /50x.html;
       # location = /50x.html {
        #    root   html;
       # }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #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;
    #    }
    #}
    server {
        listen       8090;
        server_name  localhost;
        location / {
            root   html;
            index  weixin.html;
        }
    }


}

Q.E.D.


Hello welcome to my blog