nginx使用详解:转发规则、负载均衡、server_name

news/2024/7/7 21:47:25 标签: nginx, 负载均衡, 运维

文章目录

  • 一、nginx常用的转发规则
    • location 指令说明
    • location转发使用
  • 二、upstream负载均衡使用
  • 三、server_name使用
  • 四、其他常用配置
    • 限制请求类型
    • 处理静态资源目录遍历问题
    • 限制客户端使用的ip或者域名
  • 五、需要注意的地方
    • location /api1 探讨
    • location ~ /api1 探讨(正则表达式)
    • $host 和 $remote_addr 的区别
  • 其他
    • Rewrite命令语法
    • springboot 打印请求路径
    • springboot打印controller被调用的方法
    • Controller获取请求头的内容
  • 参考文档

nginx_1">一、nginx常用的转发规则

location 指令说明

  • 该指令用于匹配 URL,语法如下:
指令说明
=用于不含正则表达式的 uri 前,要求请求字符串与 uri 严格匹配,如果匹配 成功,就停止继续向下搜索并立即处理该请求。
~用于表示 uri 包含正则表达式,并且区分大小写。
~*用于表示 uri 包含正则表达式,并且不区分大小写。
^~用于不含正则表达式的uri前,要求Nginx服务器找到标识uri和请求字 符串匹配度最高的 location 后,立即使用此 location 处理请求,而不再使用 location 块中的正则 uri 和请求字符串做匹配。
!~区分大小写不匹配。
!~*不区分大小写不匹配
/a普通前缀匹配,优先级低于带参数前缀匹配。
/任何请求都会匹配
  • 首先匹配 =
  • 其次匹配^~,
  • 其次是按文件中顺序的正则匹配
  • 最后是交给 / 通用匹配
  • 当有匹配成功时候,停止匹配,按当前匹配规则处理请求。

location转发使用

  • location /api1/
# 如果请求的是:http://localhost:80/api1,
# 转发形成的就会是:http://localhost:8001/
		location /api1/ {
			proxy_pass http://localhost:8001/;
        }       
  • location = /api1/ (精确匹配)
# 如果请求的是:http://localhost:80/api1,会被匹配到
# 转发形成的就会是:http://localhost:8001/
# 如果请求的是:http://localhost:80/api1/test,不会被匹配到,因为是精确匹配
		location = /api1/ {
			proxy_pass http://localhost:8001/;
        }
  • location ~ /api1 (正则表达式匹配)
# rewrite重写了请求路径,break不可省略,$1为正则匹配的内容
# ^/api1/(.*)$,在这个正则表达式中,$1为(.*)中的内容
# proxy_set_header的使用并不会失效
# 如果请求的是:http://localhost:80/api1,
# 转发形成的就会是:http://localhost:8001/
		location ~ /api1 {	
			rewrite ^/api1/(.*)$ /$1 break;
			proxy_set_header test001 $host:$server_port;
			proxy_set_header test002 $remote_addr;
			proxy_pass http://localhost:8001;
        }

二、upstream负载均衡使用

#server只能是ip+端口,不然启动报错
	upstream api{
		server localhost:9001;
		server localhost:9002;
		server localhost:9003;
	}
#proxy_pass里面的api对应的是upstream后面的api
		location /api/ {	
			proxy_pass http://api/;
        }

三、server_name使用

  • 看下列代码,端口一样,server_name不一样
  • 访问http://www.test001.com/api/test,进入第一个server,转发的实际为http://localhost:9001/test
  • 访问http://www.test002.com/api/test,进入第二个server,转发的实际为http://localhost:9002/test
  • 对于没有配置的server_name,默认进入第一个server处理
  • 访问http://127.0.0.1/api/test,进入第一个server,转发的实际为http://localhost:9001/test
  • 访问http://www.test003.com/api/test,进入第一个server,转发的实际为http://localhost:9001/test
#本机host配置
127.0.0.1 www.test001.com
127.0.0.1 www.test002.com
127.0.0.1 www.test003.com
    server {						
		#监听端口
        listen       80;		
		#服务名
        server_name  www.test001.com;		
		
		
	    location / {
            root   html;
            index  index.html index.htm;
        }
		
		location /api/ {	
			proxy_pass http://localhost:9001/;
        }
		
		#500类型错误处理
        error_page   500 502 503 504  /50x.html;
		#映射文件50x.html
        location = /50x.html {	
			#相对路径
            root   html;
        }

    }
	
	server {						
		#监听端口
        listen       80;		
		#服务名
        server_name  www.test002.com;		
		
		
	    location / {
            root   html;
            index  index.html index.htm;
        }
		
		location /api/ {	
			proxy_pass http://localhost:9002/;
        }
		
		#500类型错误处理
        error_page   500 502 503 504  /50x.html;
		#映射文件50x.html
        location = /50x.html {	
			#相对路径
            root   html;
        }
    }

四、其他常用配置

限制请求类型

  • 只允许GET和POST请求,写在server块
if($request_method !~ ^(GET|POST)$ ){
	return 403;
}

处理静态资源目录遍历问题

  • 过滤…/ |…\,写在server块
if( $request_uri ~* \.\.[\\\\/] ){
	return 404;
}

限制客户端使用的ip或者域名

  • 写在server块
#当写127.0.0.1的时候,使用localhost会报500,只能使用127.0.0.1
if ( $host !~ ^127.0.0.1 ){
	return 500;
}

五、需要注意的地方

  • 当使用 location ~ 的时候, proxy_pass结尾不能为 / ,不然会报错
  • access_log需要写在log_format后面,不然启动会报错。
  • access_log只能打印出请求的路径,无法打印出代理之后的路径。

location /api1 探讨

# 如果请求的是:http://localhost:80/api1,
# 转发形成的就会是:http://localhost:8001/api1
		location /api1 {
			proxy_pass http://localhost:8001;
        }        
# 如果请求的是:http://localhost:80/api1,
# 转发形成的就会是:http://localhost:8001/
		location /api1/ {
			proxy_pass http://localhost:8001/;
        }        
# 如果请求的是:http://localhost:80/api1,
# 转发形成的就会是:http://localhost:8001//
		location /api1 {
			proxy_pass http://localhost:8001/;
        }     

location ~ /api1 探讨(正则表达式)

#proxy_pass最多只能写到端口
#比如http://localhost:9001/,多个/报错
#比如http://localhost:9001/test,多个/test报错
#所以正则表达式的转发经常配合rewrite使用
		location ~ /api1 {	
			proxy_pass http://localhost:9001;
        }

$host 和 $remote_addr 的区别

  • $host 是客户端使用的ip或者域名,$remote_addr是客户端真正的ip
# $host为127.0.0.1
# $remote_addr为127.0.0.1
http://127.0.0.1/api/test

# $host为www.test001.com
# $remote_addr为127.0.0.1
http://www.test001.com/api/test

# $host为localhost
# $remote_addr为127.0.0.1
http://localhost/api/test

# 假设我本机ip为192.168.1.27
# $host为www.baidu.com
# $remote_addr为192.168.1.27
https://www.baidu.com/s?wd=北京

其他

Rewrite命令语法

rewrite < regex > < replacement > [flag]
regex:正则表达式
replacement :跳转后的内容
flag:rewrite支持的flag标记
flag标记说明
标记说明
last相当于Apache的【L】标记,表示完成rewrite
break本条规则匹配完成即终止,不在匹配后面的任何规则
redirect返回302临时重定向,浏览器地址栏会显示跳转后的URL地址,爬虫不会更新url
permanent返回301永久重定向,浏览器地址栏会显示跳转后的URL地址,爬虫更新url
ast和break比较
lastbreak
使用场景一般写在server和if中一般使用在location中
URL匹配不重质重写后的url匹配终止重写后的url匹配
#$1为(.*)
rewrite ^/api1/(.*)$ /$1 break;

#$1为前面的(.*),$2为后面的(.*)
rewrite ^/(.*)/(.*)$ /$1 break;

#当正则表达式和请求不匹配的时候,后面的/$1将不被执行,请求不会被rewrite替换
rewrite ^/apitest/(.*)$ /$1 break;

springboot 打印请求路径

logging:
  level:
    org.springframework: debug

springboot打印controller被调用的方法

logging:
  level:
    org:
      springframework:
        web:
          servlet:
            mvc:
              method:
                annotation:
                  RequestMappingHandlerMapping: trace

Controller获取请求头的内容

HttpServletRequest request;
Enumeration<String> enumeration= request.getHeaderNames();

参考文档

  • springboot 打印请求的uri和请求参数
  • Servlet–HttpServletRequest获取请求信息(请求头、请求行、参数)详解
  • Nginx配置文件
  • Nginx之正则表达式、location匹配简介以及rewrite重写
  • nginx 正则路径匹配
  • Nginx的基本使用

http://www.niftyadmin.cn/n/5204285.html

相关文章

c++11新特性篇-列表初始化

列表初始化 概述 列表初始化是 C11 引入的一个新特性。**它允许使用花括号 {} 来初始化变量、数组、结构体等。**列表初始化具有更加统一和直观的语法&#xff0c;同时也提供了一些优势&#xff0c;例如防止窄化转换&#xff08;narrowing conversion&#xff09;等。 下面是…

入门C++协程:理解和使用协程的基础知识

一、线程的缺点 首先&#xff1a;线程分为用户线程和内核线程。&#xff08;用户线程处于用户空间&#xff0c;内核线程处于内核空间&#xff09;其次&#xff1a;用户线程和内核线程可以是一对多或者一对一的关系。再次&#xff1a;多线程编程时如果线程过多&#xff0c;会导…

软件测试工具常用的都有哪些

软件测试工具是用于辅助软件测试的软件工具&#xff0c;可以帮助测试人员执行测试用例、记录测试结果、跟踪缺陷状态等&#xff0c;提高测试效率和质量。以下是一些常见的软件测试工具&#xff1a; 一、AutoRunner自动化测试工具 AutoRunner(简称AR&#xff09;是国内自主研发…

oracle 杀掉正在“执行”的SQL

1、 找到正在执行的 SQL&#xff0c;或者造成等待事件的SQL 的 sid 和 serial#&#xff0c;通过这两个值确定一个 session SELECT b.username 用户名,b.sid, session_idb.serial#, 串口号spid 操作系统ID,paddr, session对应的进程地址&#xff0c;sql_text 正…

JVM参数之堆栈空间配置

JVM 中最重要的一部分就是堆空间了&#xff0c;基本上大多数的线上 JVM 问题都是因为堆空间造成的 OutOfMemoryError。因此掌握 JVM 关于堆空间的参数配置对于排查线上问题非常重要。 堆配置 我们使用 -Xms 设置堆的初始空间大小&#xff0c;使用 -Xmx 设置堆的最大空间大小。…

原始类型 vs. 对象(基本类型 vs. 引用类型)

原始类型 首先我们先看一段代码&#xff1a; let age 30; let oldAge age; age 31; console.log(age); console.log(oldAge);在 JavaScript 中&#xff0c;原始类型的赋值是通过值复制的方式进行的&#xff0c;而不会相互影响。只有对象类型的值才是通过引用复制的方式进行…

PAT甲级 科学计数法

1073 Scientific Notation 分数 20 Scientific notation is the way that scientists easily handle very large numbers or very small numbers. The notation matches the regular expression [-][1-9].[0-9]E[-][0-9] which means that the integer portion has exactly o…

笔记59:序列到序列学习Seq2seq

本地笔记地址&#xff1a;D:\work_file\&#xff08;4&#xff09;DeepLearning_Learning\03_个人笔记\3.循环神经网络\第9章&#xff1a;动手学深度学习~现代循环神经网络 a a a a a a a a a a a a a a a