Nginx配置反向代理

前言:最近项目使用的用过,是Nginx做为反向代理,之前也有用过,但是同事配置好的,自己没有动手配置过,这次到自己配置的时候还是遇到了很多的问题。后面就自己查了一些资料,了解了一些配置项的作用。

http {
   
    #设定日志格式
    access_log    /var/log/nginx/access.log;

    #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
    #必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
    sendfile        on;
    #将tcp_nopush和tcp_nodelay两个指令设置为on用于防止网络阻塞
    tcp_nopush      on;
    tcp_nodelay     on;
    #连接超时时间
    keepalive_timeout  65;

    include /etc/nginx/conf.d/*.conf;  可以包含多个conf文件,里面配置server同级目录。
  
    server {
        #侦听80端口
        listen       80;
        #定义访问的域名
        server_name  localhost;

        #设定本虚拟主机的访问日志
        access_log  logs/www.xx.com.access.log  main;
 
 
    #定义服务器的全局网站根目录位置
        root /webapp/web;

# 定义错误提示页面 error_page 500 502 503 504 /50x.html; location = /50x.html { root /root; } #静态文件,nginx自己处理 location ~ ^/(images|javascript|js|css|flash|media|static)/ { root /var/www/virtual/ htdocs; #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。 expires 30d; }
        #配置静态资源        
        location /web/jadp{                 
 
 
        #定义服务器的默认网站根目录位置,可配在全局,也可配在局部。   注意:此处配置根目录有root和alias两种方法           
                root /webapp/web;  
        }        


        location
/web/api {
            proxy_pass  http://webapp/web;  #请求转向的服务器地址
            #配置缓存是否开启.         
            proxy_redirect off;
            #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP             
            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;  #nginx跟后端服务器连接超时时间(代理连接超时)             
            proxy_send_timeout 90;        #后端服务器数据回传时间(代理发送超时)             
            proxy_read_timeout 90;         #连接成功后,后端服务器响应时间(代理接收超时)             
            proxy_buffer_size 4k;             #设置代理服务器(nginx)保存用户头信息的缓冲区大小             
            proxy_buffers 4 32k;               #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置             
            proxy_busy_buffers_size 64k;    #高负荷下缓冲大小(proxy_buffers*2)             
            proxy_temp_file_write_size 64k;  #设定缓存文件夹大小,大于这个值,将从upstream服务器传
}
         #设定查看Nginx状态的地址 location
/NginxStatus { stub_status on; access_log on; auth_basic "NginxStatus" ; auth_basic_user_file conf/htpasswd; } #禁止访问 .htxxx 文件 location ~ /\.ht { deny all; }                
       include /etc/nginx/conf.d/*.conf;  可以包含多个conf文件,里面配置location
}

说明:

nginx配置下有两个指定目录的执行,root和alias的区别:

location /img/ {
    alias /var/www/image/;
}
#若按照上述配置的话,则访问/img/目录里面的文件时,ningx会自动去/var/www/image/目录找文件
location /img/ {
    root /var/www/image;
}
#若按照这种配置的话,则访问/img/目录下的文件时,nginx会去/var/www/image/img/目录下找文件。]

alias是一个目录别名的定义,root则是最上层目录的定义。

还有一个重要的区别是alias后面必须要用“/”结束,否则会找不到文件的。。。而root则可有可无~~



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值