Nginx实现HTTP反向代理配置

Nginx实现HTTP反向代理配置

 

无意中发现了一个巨牛的人工智能教程,忍不住分享一下给大家。教程不仅是零基础,通俗易懂,而且非常风趣幽默,像看小说一样!觉得太牛了,所以分享给大家。点这里可以跳转到教程

此文中不考虑Nginx的其他复杂的配置,仅仅实现HTTP反向代理即可。

 

什么是反向代理?

反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

 

Nginx.conf 配置文件如下:

注:conf / nginx.conf 是 nginx 的默认配置文件。你也可以使用 nginx -c 指定你的配置文件。

#运行用户
#user somebody;
 
#启动进程,通常设置成和cpu的数量相等
worker_processes  1;
 
#全局错误日志
error_log  D:/Tools/nginx-1.10.1/logs/error.log;
error_log  D:/Tools/nginx-1.10.1/logs/notice.log  notice;
error_log  D:/Tools/nginx-1.10.1/logs/info.log  info;
 
#PID文件,记录当前启动的nginx的进程ID
pid        D:/Tools/nginx-1.10.1/logs/nginx.pid;
 
#工作模式及连接数上限
events {
    worker_connections 1024;    #单个后台worker process进程的最大并发链接数
}
 
#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
    #设定mime类型(邮件支持类型),类型由mime.types文件定义
    include       D:/Tools/nginx-1.10.1/conf/mime.types;
    default_type  application/octet-stream;
    
    #设定日志
    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    D:/Tools/nginx-1.10.1/logs/access.log main;
    rewrite_log     on;
    
    #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
    #必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
    sendfile        on;
    #tcp_nopush     on;
 
    #连接超时时间
    keepalive_timeout  120;
    tcp_nodelay        on;
    
    #gzip压缩开关
    #gzip  on;
 
    #设定实际的服务器列表 
    upstream zp_server1{
        server 127.0.0.1:8089;
    }
 
    #HTTP服务器
    server {
        #监听80端口,80端口是知名端口号,用于HTTP协议
        listen       80;
        
        #定义使用www.xx.com访问
        server_name  www.helloworld.com;
        
        #首页
        index index.html
        
        #指向webapp的目录
        root D:\01_Workspace\Project\github\zp\SpringNotes\spring-security\spring-shiro\src\main\webapp;
        
        #编码格式
        charset utf-8;
        
        #代理配置参数
        proxy_connect_timeout 180;
        proxy_send_timeout 180;
        proxy_read_timeout 180;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarder-For $remote_addr;
 
        #反向代理的路径(和upstream绑定),location 后面设置映射的路径
        location / {
            proxy_pass http://zp_server1;
        } 
 
        #静态文件,nginx自己处理
        location ~ ^/(images|javascript|js|css|flash|media|static)/ {
            root D:\01_Workspace\Project\github\zp\SpringNotes\spring-security\spring-shiro\src\main\webapp\views;
            #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。
            expires 30d;
        }
    
        #设定查看Nginx状态的地址
        location /NginxStatus {
            stub_status           on;
            access_log            on;
            auth_basic            "NginxStatus";
            auth_basic_user_file  conf/htpasswd;
        }
    
        #禁止访问 .htxxx 文件
        location ~ /\.ht {
            deny all;
        }
        
        #错误处理页面(可选择性配置)
        #error_page   404              /404.html;
        #error_page   500 502 503 504  /50x.html;
        #location = /50x.html {
        #    root   html;
        #}
    }
}

 

启动后可以进行一下测试:      

  • 启动 webapp,注意启动绑定的端口要和nginx中的 upstream 设置的端口保持一致。
  • 更改 host:在 C:\Windows\System32\drivers\etc 目录下的hosts文件中添加一条 DNS 记录
    • 127.0.0.1 www.helloworld.com

    • 启动前文中 startup.bat 的命令  

  • 在浏览器中访问 www.helloworld.com,不出意外,已经可以访问了。

                                                                                                                                                                                                                                                      

PS: DNS解析是有缓存的,可能导致访问反向代理不生效,可以使用ipconfig /flushdns 刷新一下本地 dns 缓存

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Nginx实现反向代理,您需要进行以下配置: 1. 打开 Nginx 配置文件:通常,Nginx配置文件位于 `/etc/nginx/nginx.conf`。 2. 在 `http` 配置块中添加反向代理配置:在 `http` 配置块中,可以添加多个 `server` 配置块来定义不同的反向代理规则。示例如下: ```nginx http { ... server { listen 80; server_name yourdomain.com; location / { proxy_pass http://backend_server; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } ... } ``` 在上述示例中,我们创建了一个反向代理服务器,监听在端口 80,并将请求转发到名为 `backend_server` 的后端服务器。通过 `proxy_pass` 指令指定了要转发请求的目标服务器。 3. 配置其他代理相关的选项:您还可以根据需要配置其他代理相关的选项。例如,您可以使用 `proxy_set_header` 指令设置自定义的请求头。 4. 保存并退出配置文件。 5. 检查配置文件的语法:在终端中执行以下命令检查配置文件的语法是否正确: ```bash nginx -t ``` 如果没有错误提示,则表示语法正确。 6. 重启 Nginx 服务:在终端中执行以下命令重启 Nginx 服务: ```bash sudo service nginx restart ``` 7. 验证反向代理配置:访问您在配置中指定的域名,Nginx 将会将请求转发到后端服务器,并将响应返回给客户端。 请根据您的实际需求修改上述示例,并确保配置文件语法正确。这样就完成了在 Nginx实现反向代理配置。如果您有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值