Loading

Nginx相关参考

因为最近一直在回头练习之前学过的,这次也回头再复习—多练习一下,顺便也做一个记录回头好查看

正文:

Nginx是一种高性能的HTTP和反向代理web服务器,支持高并发和负载均衡,安装简单、配置文件简洁,同时Bug少,几乎可以做到7*24不间断运行,支持在不间断服务的情况下进行软件版本升级。在连接高并发的情况下,Nginx是Apache服务不错的替代品。同时Nginx的模块也非常丰富,能够满足不同的需求,适合做静态使用。

以centos为例

网站文件地址:/usr/local/nginx/html

配置文件地址:/usr/local/nginx/conf/nginx.conf

Nginx

配置文件解析

worker_processes 4; # 根据cpu的核数来决定工作进程数

events {
	worker_connections 1024;  # 一个工作进程最多能处理的连接数,默认1024
}
http {
    #http全局块
    include mime.types;  # include 包含,引入minme文件,当 Nginx 服务访问一个 PNG 图片文件时,
    # 会根据 mime.types 文件中的配置,将 Content-Type 设置为 image/png 并发送至客户端,客户端(如浏览器)接收到该头部信息后,
    # 会以图片格式解析并展示该文件。确保服务器能够正确告知客户端如何解析和处理不同类型的文件
    default_type  application/octet-stream;  # 3默认文件类型
    sendfile        on;
    keepalive_timeout  65; # 超时65秒,自动断开
    gzip on; #开启gzip压缩输出
    #负载均衡配置
    upstream bakend {
        #upstream的负载均衡,weight是权重,可以根据机器配置定义权重。weigth参数表示权值,权值越高被分配到的几率越大。
        server 192.168.80.121:80 weight=3;
        server 192.168.80.122:80 weight=2;
        server 192.168.80.123:80 weight=3;
        #nginx的upstream目前支持4种方式的分配
        #1、轮询(默认)
        #每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。
        #2、weight
        #指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。
        #2、ip_hash
        #每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。
        #例如:
        #upstream bakend {
        #    ip_hash;
        #    server 192.168.0.14:88;
        #    server 192.168.0.15:80;
        #}
        #3、fair(第三方)
        #按后端服务器的响应时间来分配请求,响应时间短的优先分配。
        #upstream backend {
        #    server server1;
        #    server server2;
        #    fair;
        #}
        #4、url_hash(第三方)
        #按访问url的hash结果来分配请求,使每个url定向到同一个后端服务器,后端服务器为缓存时比较有效。
        #例:在upstream中加入hash语句,server语句中不能写入weight等其他的参数,hash_method是使用的hash算法
        #upstream backend {
        #    server squid1:3128;
        #    server squid2:3128;
        #    hash $request_uri;
        #    hash_method crc32;
        #}

        #tips:
        #upstream bakend{#定义负载均衡设备的Ip及设备状态}{
        #    ip_hash;
        #    server 127.0.0.1:9090 down;
        #    server 127.0.0.1:8080 weight=2;
        #    server 127.0.0.1:6060;
        #    server 127.0.0.1:7070 backup;
        #}
        #每个设备的状态设置为:
        #1.down表示单前的server暂时不参与负载
        #2.weight为weight越大,负载的权重就越大。
        #3.max_fails:允许请求失败的次数默认为1.当超过最大次数时,返回proxy_next_upstream模块定义的错误
        #4.fail_timeout:max_fails次失败后,暂停的时间。
        #5.backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。

        #nginx支持同时设置多组的负载均衡,用来给不用的server来使用。
        #在需要使用负载均衡的server中增加 proxy_pass http://bakend/;
    }
	server {
		listen 9000;  # 监听的端口,可以只写IP,也可以IP+端口
		server_name  192.254.1.16; # 浏览器访问的域名,域名可以有多个,用空格隔开
        # location块
		location / { # 请求处理规则
			root /usr/local/nginx/html/;  # 默认页面所在地,或者说是主页所在地
            index  index.html index.htm; 
		}
        # 对php文件请求进行处理
        location ~ .*.(php|php5)?$ {
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            include fastcgi.conf;
        }
        # 错误模块
        error_page   500 502 503 504  /50x.html; 
        location = /50x.html {
            root   html;
        }
        # 图片缓存设置设置
        location ~ .*.(gif|jpg|jpeg|png|bmp|swf)$
        {
            expires 10d;表示这些图像文件在浏览器缓存中可以保存10天
        }
        #JS和CSS缓存时间设置
        location ~ .*.(js|css)?$
        {
            expires 1h;表示这些文件在浏览器缓存中可以保存1小时
        }
    }
        #这边可以有多个server块
    server {
        listen    8080;
        server_name xx_domain

        ## 1. 用户访问 http://xx_domain/cy,则反向代理到 http://bakend/ ,对 "cy" 启用反向代理
        location /cy {
            proxy_pass  http://bakend/;
            proxy_redirect     off;   # 禁用代理重定向,需要重定向时则改成url
            proxy_set_header   Host             $host;        # 传递客户端请求域名
            proxy_set_header   X-Real-IP        $remote_addr; # 传递客户端ip
            proxy_set_header   X-Scheme         $scheme;      # 传递协议
            proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for; # 后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
        }
        # 本地动静分离反向代理配置
        # 所有jsp的页面均交由tomcat或resin处理
        location ~ .(jsp|jspx|do)?$ {
            proxy_set_header Host $host;  # 传递客户端请求域名
            proxy_set_header X-Real-IP $remote_addr;  # 传递客户端ip
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
            proxy_pass http://127.0.0.1:8080; # 远程动静分离则改成远程服务器的ip+端口
        }
        # 对php文件请求进行处理
        location ~ .*.(php|php5)?$ {
            fastcgi_pass 127.0.0.1:9000; # 请求转发的IP
            fastcgi_index index.php; # 表示默认的PHP文件名为index.php
            include fastcgi.conf; # Nginx的FastCGI相关配置文件
        }
        #所有静态文件由nginx直接读取不经过tomcat或resin
        location ~ .*.(htm|html|gif|jpg|jpeg|png|bmp|swf|ioc|rar|zip|txt|flv|mid|doc|ppt|
        pdf|xls|mp3|wma)$
        {
            expires 15d;  # 表示这些静态文件在浏览器缓存中可以保存15天
        }
        location ~ .*.(js|css)?$
        {
            expires 1h; # 表示这些文件在浏览器缓存中可以保存1小时
        }
	}
}

 

posted @ 2024-06-26 19:03  青瓦深巷  阅读(26)  评论(0)    收藏  举报