当前位置: 首页 > article >正文

Nginx中间件配置

Nginx中间件配置

  • 概要
  • 相关内容
  • 技术细节
  • 链接

概要

  • 用于Linux服务器,Nginx中间件搭建。

相关内容

  • 配置涵盖域名配置,TLS配置,及配置安全的加密算法,处理跨域问题,请求头问题等

技术细节

nginx.conf 配置文件

user  root;
worker_processes  2;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;

events {
    worker_connections 10000;
}

http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    server_tokens off;
    server_names_hash_bucket_size 128;
    client_header_buffer_size 32k;
    large_client_header_buffers 4 64k;
    client_max_body_size 50m;
    sendfile on;
    tcp_nopush  on;
    tcp_nodelay on;
    keepalive_timeout 80;
    fastcgi_connect_timeout 300;
    fastcgi_send_timeout 300;
    fastcgi_read_timeout 300;
    fastcgi_buffer_size 64k;
    fastcgi_buffers 4 64k;
    fastcgi_busy_buffers_size 128k;
    fastcgi_temp_file_write_size 256k;
	proxy_buffer_size 64k;
	proxy_buffers   4 32k;
	proxy_busy_buffers_size 64k;
    gzip on;
    gzip_min_length  1k;
    gzip_buffers     4 16k;
    gzip_http_version 1.0;
    gzip_comp_level 2;
    gzip_types       text/plain application/x-javascript text/css application/xml;
    gzip_vary on;

    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  /var/log/nginx/access.log  main;

	upstream business_server {
		#ip_hash;
		server localhost:8080 weight=10 max_conns=10000 max_fails=3 fail_timeout=15;
		server localhost:8081 weight=10 max_conns=10000 max_fails=3 fail_timeout=15;
		server localhost:8082 weight=10 max_conns=10000 max_fails=3 fail_timeout=15;
	}

    server {
        add_header X-XSS-Protection 1;
		add_header Set-Cookie "Path=/; HttpOnly; Secure";
        listen 443 ssl;   #SSL协议访问端口号为443。此处如未添加ssl,可能会造成Nginx无法启动。
		server_name www.business.com;  #将localhost修改为您证书绑定的域名,例如:www.business.com。
		root html;
		index index.html index.htm;
        ssl_certificate      /app/business/www.business.com.pem;
        ssl_certificate_key  /app/business/www.business.com.key;
		ssl_session_timeout 5m;
		ssl_protocols TLSv1.2;
		ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA384:AES128-GCM-SHA256:AES256-GCM-SHA384:AES128-SHA256:AES256-SHA256:ECDHE-ECDSA-AES128-SHA:ECDHE-ECDSA-AES256-SHA:ECDHE-RSA-AES128-SHA:ECDHE-RSA-AES256-SHA:AES128-SHA:AES256-SHA;
		ssl_prefer_server_ciphers on;

		client_max_body_size 1024M;

		location / {
			root html;
			index index.html index.htm;
		}
		error_page   500 502 503 504  /50x.html;
		location = /50x.html {
        	root   /usr/share/nginx/html;
		}

		#访问地址方式一
		location  /business-pc/ {
			add_header Access-Control-Allow-Origin *;
			alias   /app/business-pc/;
        }
		#访问地址方式二
		location  /business-pc/ {
			add_header Access-Control-Allow-Origin http://192.168.0.1;
			add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS';
			add_header Access-Control-Allow-Headers 'DNT,X-Mx-ReqToken,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Authorization';
			if ($request_method = 'OPTIONS') {
				return 204;
			}
			add_header X-Frame-Options SAMEORIGIN;
			add_header Content-Security-Policy "worker-src 'self'";
			add_header X-Content-Type-Options nosniff;
			alias   /app/business-pc/;
		}
		
		#访问接口
		location /business-web{
        	access_log /etc/nginx/logs/business-web.log;
	        proxy_pass             http://business_server/business-web;
	        proxy_set_header   Host             $host;
	        proxy_set_header   X-Real-IP        $remote_addr;
	        proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;
		}

    }

}

链接

下载链接:https://download.csdn.net/download/qq_38254635/89532087

OK,就这些吧。
有什么不对的还望指正,书写不易,觉得有帮助就点个赞吧!☺☺☺


http://www.kler.cn/a/289527.html

相关文章:

  • 【设计模式-结构型】装饰器模式
  • 使用 ChatGPT 生成和改进你的论文
  • 使用Go语言中的Buffer实现高性能处理字节和字符串
  • 工作记录小点
  • SpringBoot入门实现简单增删改查
  • 在AI智能中有几种重要的神经网络类型?6种重要的神经网络类型分享!
  • RLHF(带有人类反馈的强化学习)初探
  • 科研绘图系列:python语言制标准差的直方图(STD histogram plot)
  • 模拟登录页,华为账号一键登录
  • Charles抓包全流程(Mac端+iOS端)
  • SpringBoot学习(3)Redis使用
  • blender中获取虚拟相机渲染图片上每像素对应的纹理上的像素值
  • C_深入理解指针(四) —— 回调函数、qsort使用举例、qsort函数的模拟实现
  • idea问题解决:java: -source 7 中不支持 方法引用 (请使用 -source 8 或更高版本以启用 方法引用)
  • zhidianyun01/基于 ThinkPHP+Mysql 灵活用工+灵活用工源码+灵活用工平台源码
  • EF框架中的修改
  • 利用Spring Boot实现服务降级与熔断机制
  • Spring MVC中的DispatcherServlet:核心调度者
  • 行为型设计模式-备忘录(memento)模式
  • Shell编程基础知识
  • Trm理论 2(Word2Vec)
  • 如何通过k8s来降低运营成本?
  • cuda编程[5]:矩阵乘法--使用静态共享内存优化
  • C/C++语言基础--函数基础(函数定义、调用、生命周期、递归)
  • Linux服务器CPU和IO的监控利器-iostat简介
  • 【重学 MySQL】一、数据库概述