Nginx实现https反向代理配置

太过爱你忘了你带给我的痛 2022-05-23 07:54 353阅读 0赞

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

一些对安全性要求比较高的站点,可能会使用 HTTPS(一种使用ssl通信标准的安全HTTP协议)。

先了解一些http相关的概念:

  •  HTTP:是互联网上应用最为广泛的一种网络协议,是一个客户端和服务器端请求和应答的标准(TCP),用于从WWW服务器传输超文本到本地浏览器的传输协议,它可以使浏览器更加高效,使网络传输减少。
  •  HTTPS:是以安全为目标的HTTP通道,简单讲是HTTP的安全版,即HTTP下加入SSL层,HTTPS的安全基础是SSL,因此加密的详细内容就需要SSL。

使用 nginx 配置 https 需要知道以下几点:

  • HTTPS 的固定端口号是 443,不同于 HTTP 的 80 端口
  • SSL 标准需要引入安全证书,所以在 nginx.conf 中你需要指定证书和它对应的 key

其他和 http 反向代理基本一样,只是在 Server 部分配置有些不同。配置如下:

  1. #运行用户
  2. #user somebody;
  3. #启动进程,通常设置成和cpu的数量相等
  4. worker_processes 1;
  5. #全局错误日志
  6. error_log C:/Users/wangcw/Desktop/nginx-1.13.12/logs/error.log;
  7. error_log C:/Users/wangcw/Desktop/nginx-1.13.12/logs/notice.log notice;
  8. error_log C:/Users/wangcw/Desktop/nginx-1.13.12/logs/info.log info;
  9. #PID文件,记录当前启动的nginx的进程ID
  10. pid C:/Users/wangcw/Desktop/nginx-1.13.12/logs/nginx.pid;
  11. #工作模式及连接数上限
  12. events {
  13. worker_connections 1024; #单个后台worker process进程的最大并发链接数
  14. }
  15. #设定http服务器,利用它的反向代理功能提供负载均衡支持
  16. http {
  17. #设定mime类型(邮件支持类型),类型由mime.types文件定义
  18. include C:/Users/wangcw/Desktop/nginx-1.13.12/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 C:/Users/wangcw/Desktop/nginx-1.13.12/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:8077;
  38. }
  39. #HTTP服务器
  40. server {
  41. #监听443端口。443为知名端口号,主要用于HTTPS协议
  42. listen 443 ssl;
  43. #定义使用www.xx.com访问
  44. server_name www.aabbccdd.com;
  45. #ssl证书文件位置(常见证书文件格式为:crt/pem)
  46. ssl_certificate cert.pem;
  47. #ssl证书key位置
  48. ssl_certificate_key cert.key;
  49. #ssl配置参数(选择性配置)
  50. ssl_session_cache shared:SSL:1m;
  51. ssl_session_timeout 5m;
  52. #数字签名,此处使用MD5
  53. ssl_ciphers HIGH:!aNULL:!MD5;
  54. ssl_prefer_server_ciphers on;
  55. location / {
  56. root /root;
  57. index index.html index.htm;
  58. }
  59. #编码格式
  60. charset utf-8;
  61. #代理配置参数
  62. proxy_connect_timeout 180;
  63. proxy_send_timeout 180;
  64. proxy_read_timeout 180;
  65. proxy_set_header Host $host;
  66. proxy_set_header X-Forwarder-For $remote_addr;
  67. #反向代理的路径(和upstream绑定),location 后面设置映射的路径
  68. location / {
  69. proxy_pass http://zp_server1;
  70. }
  71. #静态文件,nginx自己处理
  72. location ~ ^/(images|javascript|js|css|flash|media|static)/ {
  73. root C:/XMCARES_X/WorkSpace/nginx/src/main/webapp/views;
  74. #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。
  75. expires 30d;
  76. }
  77. #设定查看Nginx状态的地址
  78. location /NginxStatus {
  79. stub_status on;
  80. access_log on;
  81. auth_basic "NginxStatus";
  82. auth_basic_user_file conf/htpasswd;
  83. }
  84. #禁止访问 .htxxx 文件
  85. location ~ //.ht {
  86. deny all;
  87. }
  88. #错误处理页面(可选择性配置)
  89. #error_page 404 /404.html;
  90. #error_page 500 502 503 504 /50x.html;
  91. #location = /50x.html {
  92. # root html;
  93. #}
  94. }
  95. }

然后还需要配置域名解析:

  1. hosts文件:
  2. 127.0.0.1 www.aabbccdd.com

发表评论

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

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

相关阅读

    相关 Nginx配置反向代理

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

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

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