nginx.conf 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. worker_processes 1;
  2. error_log /var/log/nginx/error.log warn;
  3. pid /var/run/nginx.pid;
  4. events {
  5. worker_connections 1024;
  6. }
  7. http {
  8. include mime.types;
  9. default_type application/octet-stream;
  10. sendfile on;
  11. keepalive_timeout 65;
  12. # 限制 body 大小
  13. client_max_body_size 100m;
  14. log_format main '$remote_addr - $remote_user [$time_local] "$request" '
  15. '$status $body_bytes_sent "$http_referer" '
  16. '"$http_user_agent" "$http_x_forwarded_for"';
  17. access_log /var/log/nginx/access.log main;
  18. # 后端项目
  19. upstream admin-server {
  20. ip_hash;
  21. server 172.17.0.1:18000;
  22. }
  23. server {
  24. listen 443 ssl;
  25. server_name api.continew.top;
  26. # 证书直接存放 /docker/nginx/cert 目录下即可(更改证书名称即可,无需更改证书路径)
  27. ssl_certificate /etc/nginx/cert/xxx.local.pem; # /etc/nginx/cert/ 为 docker 映射路径 不允许更改
  28. ssl_certificate_key /etc/nginx/cert/xxx.local.key; # /etc/nginx/cert/ 为 docker 映射路径 不允许更改
  29. ssl_session_timeout 5m;
  30. ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
  31. ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
  32. ssl_prefer_server_ciphers on;
  33. location / {
  34. proxy_set_header Host $http_host;
  35. proxy_set_header X-Real-IP $remote_addr;
  36. proxy_set_header REMOTE-HOST $remote_addr;
  37. proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
  38. proxy_pass http://admin-server/;
  39. }
  40. error_page 500 502 503 504 /50x.html;
  41. location = /50x.html {
  42. root html;
  43. }
  44. }
  45. # HTTP 请求 将转发到 HTTPS
  46. server {
  47. listen 80;
  48. server_name api.continew.top;
  49. rewrite ^ https://$http_host$request_uri? permanent;
  50. }
  51. # 前端项目
  52. server {
  53. listen 443 ssl;
  54. server_name admin.continew.top;
  55. # 证书直接存放 /docker/nginx/cert 目录下即可(更改证书名称即可,无需更改证书路径)
  56. ssl_certificate /etc/nginx/cert/xxx.local.pem; # /etc/nginx/cert/ 为 docker 映射路径 不允许更改
  57. ssl_certificate_key /etc/nginx/cert/xxx.local.key; # /etc/nginx/cert/ 为 docker 映射路径 不允许更改
  58. ssl_session_timeout 5m;
  59. ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
  60. ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
  61. ssl_prefer_server_ciphers on;
  62. location / {
  63. root /usr/share/nginx/html;
  64. try_files $uri $uri/ /index.html;
  65. index index.html index.htm;
  66. # Nginx 部署时,POST 请求本地静态文件会返回 405 错误(Not Allowed)
  67. # 用于解决一半 mock 数据,一半后端接口的情况
  68. error_page 405 =200 https://$host$request_uri;
  69. }
  70. error_page 500 502 503 504 /50x.html;
  71. location = /50x.html {
  72. root html;
  73. }
  74. }
  75. # 将 HTTP 请求转发到 HTTPS
  76. server {
  77. listen 80;
  78. server_name admin.continew.top;
  79. rewrite ^ https://$http_host$request_uri? permanent;
  80. }
  81. }