nginx配置根据规则匹配路由

复杂转发设置

一般nginx配置路径,各种服务如没有做到合理规划,就会出来各种情况,难以维护.
不过幸好,nginx功能强大,可以支持各种过滤.
以下对配置信息做以说明:

http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;//超时时间
    gzip  on;//gzip压缩
    gzip_min_length 1024;
    gzip_comp_level 5;
    gzip_types text/plain text/css application/json application/javascript application/x-javascript text/xml application/xml application/xml+rss text/javascript;

	server {
          listen 80;
          server_name  test.com;

           location ~* "(sse)" {//过滤请求包含sse,代理到1001端口
            proxy_pass http://127.0.0.1:1001;
            index  index.html index.htm;
            client_max_body_size  100m;
         }


          location ~* "\.(htm|gif|jpg|png|js|css)" {//请求包含css等等 代理到html位置
            root /html/test2;
            index index.html;
            client_max_body_size  100m;
          }
		//这里规则也是包含,多个是或的关系,代理到1001(说明一下1001服务是一个后台分发网关)
          location ~* "(wms|login|api|export|import|upload|template|route)"  {
            proxy_pass http://127.0.0.1:1001;
            index  index.html index.htm;
            client_max_body_size  100m;
          }
         location / {//转发所有地址
            root /html/test2;
            index index.html;
            client_max_body_size  100m;
          }
        }
  }
alias与root区别

alias: 使用场景为从子目录查找

          location /css {
            alias   /home/java/public/css;
            index  index.html index.htm;
        }
#        location /css {
#            root   /home/java/public;
#            index  index.html index.htm;
#        }

http://xxx.com/css/loader.css 访问成功

  location /css {
    alias   /home/java/dc/dc_frontend/public;
    index  index.html index.htm;
}

访问404

location proxy_pass 截取问题
 location /micro/ {
	proxy_pass_header Server;
	proxy_set_header Host $http_host;
	proxy_redirect off;
	proxy_set_header X-Real-IP $remote_addr;
	proxy_set_header X-Scheme $scheme;
	proxy_pass http://192.168.0.241:8400/;  # 最后加 /
}

http://xxx.com/micro/stat 访问 -> http://192.168.0.241:8400/stat

cat websocket.conf

  map $http_upgrade $connection_upgrade { //map指令可以将变量组合成为新的变量
    default upgrade;
    ''      close;
  }

  server {
    listen       80;
    server_name localhost; //换成域名
    access_log /var/log/nginx/yourdomain.log;

    location / {
      proxy_pass http://192.168.0.4:2048;
      proxy_read_timeout 300s;//延长无数据传输断开时间

      proxy_set_header Host $host;
      proxy_set_header X-Real-IP $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

      proxy_http_version 1.1;
      proxy_set_header Upgrade $http_upgrade;//升级协议为WebSocket
      proxy_set_header Connection $connection_upgrade;
        }
    }

http请求头不能使用带下划线的key:
在nginx.conf的http配置下添加:
underscores_in_headers on;

降级处理
访问127.0.0.1:12100 出现错误码时
跳转http://xxx.aliyuncs.com

location /  {
                proxy_pass_header Server;
                proxy_set_header Host $http_host;
                proxy_redirect off;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Scheme $scheme;
                proxy_pass http://127.0.0.1:12100/;
                proxy_intercept_errors on;
                recursive_error_pages on;
                error_page 404 500 502 503 504  = @aliyun;
        }
        location @aliyun {
            proxy_pass http://xxx.aliyuncs.com;
        }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
nginx中部署多个项目可以通过修改配置文件实现。具体步骤如下: 1. 在nginx配置文件中,比如`/etc/nginx/nginx.conf`,可以找到类似以下的代码段: ``` server { listen 1111 default_server; listen [::]:1111 default_server; server_name localhost; root /usr/share/nginx/resume/; index index.html; } ``` 这段代码指定了一个项目在1111端口的部署路径为`/usr/share/nginx/resume/`。你可以复制这段代码,并修改端口和路径以适应其他项目的部署。 2. 在复制的代码段中,修改端口号和项目路径以适应新的项目。比如,你可以将端口改为2222,并将路径改为新项目的路径。 ``` server { listen 2222 default_server; listen [::]:2222 default_server; server_name localhost; root /usr/share/nginx/new_project/; index index.html; } ``` 3. 重启nginx服务使配置生效。 这样,你就可以通过访问相应的端口号来访问不同的项目。例如,`http://服务器url:1111/`和`http://服务器url:2222/`分别对应不同的项目。 另外,你还可以使用nginx的location指令来实现在同一端口下部署多个项目。例如,可以像以下代码一样修改配置文件: ``` server { listen 3333 default_server; listen [::]:3333 default_server; server_name localhost; root /usr/share/nginx/test/; location /test1 { alias /usr/share/nginx/test/test1; index index.html; } location /test2 { alias /usr/share/nginx/test/test2; index index.html; } } ``` 这样,通过`http://服务器url:3333/test1/`和`http://服务器url:3333/test2/`就可以访问不同的项目。 以上是nginx部署多个项目的一种方式。希望对你有所帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Nginx部署多项目](https://blog.csdn.net/sinat_17775997/article/details/121414657)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [docker nginx 部署多个项目的示例方法](https://download.csdn.net/download/weixin_38590541/12899793)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值