Nginx实现HTTP反向代理配置

旧城等待, 2022-05-23 02:39 622阅读 0赞

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

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

什么是反向代理?

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

nginx.conf 配置文件如下:

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

  1. #运行用户
  2. #user somebody;
  3. #启动进程,通常设置成和cpu的数量相等
  4. worker_processes 1;
  5. #全局错误日志
  6. error_log D:/Tools/nginx-1.10.1/logs/error.log;
  7. error_log D:/Tools/nginx-1.10.1/logs/notice.log notice;
  8. error_log D:/Tools/nginx-1.10.1/logs/info.log info;
  9. #PID文件,记录当前启动的nginx的进程ID
  10. pid D:/Tools/nginx-1.10.1/logs/nginx.pid;
  11. #工作模式及连接数上限
  12. events {
  13. worker_connections 1024; #单个后台worker process进程的最大并发链接数
  14. }
  15. #设定http服务器,利用它的反向代理功能提供负载均衡支持
  16. http {
  17. #设定mime类型(邮件支持类型),类型由mime.types文件定义
  18. include D:/Tools/nginx-1.10.1/conf/mime.types;
  19. default_type application/octet-stream;
  20. #设定日志
  21. log_format main '[$remote_addr] - [$remote_user] [$time_local] "$request" '
  22. '$status $body_bytes_sent "$http_referer" '
  23. '"$http_user_agent" "$http_x_forwarded_for"';
  24. access_log D:/Tools/nginx-1.10.1/logs/access.log main;
  25. rewrite_log on;
  26. #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,
  27. #必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
  28. sendfile on;
  29. #tcp_nopush on;
  30. #连接超时时间
  31. keepalive_timeout 120;
  32. tcp_nodelay on;
  33. #gzip压缩开关
  34. #gzip on;
  35. #设定实际的服务器列表
  36. upstream zp_server1{
  37. server 127.0.0.1:8089;
  38. }
  39. #HTTP服务器
  40. server {
  41. #监听80端口,80端口是知名端口号,用于HTTP协议
  42. listen 80;
  43. #定义使用www.xx.com访问
  44. server_name www.helloworld.com;
  45. #首页
  46. index index.html
  47. #指向webapp的目录
  48. root D:\01_Workspace\Project\github\zp\SpringNotes\spring-security\spring-shiro\src\main\webapp;
  49. #编码格式
  50. charset utf-8;
  51. #代理配置参数
  52. proxy_connect_timeout 180;
  53. proxy_send_timeout 180;
  54. proxy_read_timeout 180;
  55. proxy_set_header Host $host;
  56. proxy_set_header X-Forwarder-For $remote_addr;
  57. #反向代理的路径(和upstream绑定),location 后面设置映射的路径
  58. location / {
  59. proxy_pass http://zp_server1;
  60. }
  61. #静态文件,nginx自己处理
  62. location ~ ^/(images|javascript|js|css|flash|media|static)/ {
  63. root D:\01_Workspace\Project\github\zp\SpringNotes\spring-security\spring-shiro\src\main\webapp\views;
  64. #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。
  65. expires 30d;
  66. }
  67. #设定查看Nginx状态的地址
  68. location /NginxStatus {
  69. stub_status on;
  70. access_log on;
  71. auth_basic "NginxStatus";
  72. auth_basic_user_file conf/htpasswd;
  73. }
  74. #禁止访问 .htxxx 文件
  75. location ~ /\.ht {
  76. deny all;
  77. }
  78. #错误处理页面(可选择性配置)
  79. #error_page 404 /404.html;
  80. #error_page 500 502 503 504 /50x.html;
  81. #location = /50x.html {
  82. # root html;
  83. #}
  84. }
  85. }

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

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

    1. 127.0.0.1 www.helloworld.com
  3. 启动前文中 startup.bat 的命令 20180531162230269
  4. 在浏览器中访问 www.helloworld.com,不出意外,已经可以访问了。
  5. 20180531162418821

总结一哈:(个人理解如果有误,还请各位大神指出)

上述测试使用Nginx进行反向代理HTTP请求实质有经过几个步骤。首先,访问 www.helloworld.com后,会进入hosts文件,寻到对应访问的IP地址(节省去了域名解析的时间)。而后请求变为127.0.0.1 :80,而后借助Nginx中的代理配置,将请求代理到端口为8089的端口,即完成使用域名对127.0.0.1 :8089的访问。

  1. ** 还有一个需要注意点就是DNS解析是有缓存的,可能导致访问反向代理不生效,可以使用ipconfig /flushdns 刷新一下本地 dns 缓存**

发表评论

表情:
评论列表 (有 0 条评论,622人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Nginx配置反向代理

    一、前言 反向代理作用 隐藏服务器信息 -> 保证内网的安全,通常将反向代理作为公网访问地址,web服务器是内网,即通过nginx配置外网访问web服务器内网 举例

    相关 Nginx实现HTTP反向代理配置

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