目录
- 传送门
- 前言
- 一、快速安装
- 二、反向代理语法
- 1、基本语法
- 2、location语法
- 1. 基本语法
- 2. 匹配规则
- 3. 修饰符
- 4. 权重
- 5. 嵌套`location`
- 6. 其他指令
- 7.案例
- 三、配置反向代理
传送门
SpringMVC的源码解析(精品)
Spring6的源码解析(精品)
SpringBoot3框架(精品)
MyBatis框架(精品)
MyBatis-Plus
SpringDataJPA
SpringCloudNetflix
SpringCloudAlibaba(精品)
Shiro
SpringSecurity
java的LOG日志框架
Activiti(敬请期待)
JDK8新特性
JDK9新特性
JDK10新特性
JDK11新特性
JDK12新特性
JDK13新特性
JDK14新特性
JDK15新特性
JDK16新特性
JDK17新特性
JDK18新特性
JDK19新特性
JDK20新特性
JDK21新特性
其他技术文章传送门入口
前言
下面文章不定期更新中。。。
Linux安装JDK17(精品)
Linux安装MySQL(精品)
Linux安装Nginx
Linux安装Maven
运行一个jar包
Jenkins安装启动(JDK8/11/17)
Jenkins配置(插件/角色/凭证)
Jenkins的jdk和maven配置
Jenkins三种构建类型
Nginx主要有反向代理、负载均衡、动静分离三大核心功能,由于现在微服务的流行,微服务体系自己可以非常好的搞定负载均衡,所以Nginx很少用于负载均衡了,由于动静分离企业级使用也不是太多,至少笔者在的几家公司都没有使用。所以Nginx现在主要用于反向代理了。比如:一个域名,www.test.com; 下面要下设很多个服务器,用Nginx可以轻松实现:
www.test.com/a 对应 ip地址1:端口1
www.test.com/b 对应 ip地址2:端口2
一、快速安装
笔者的一台Linux服务器的版本是Alibaba Cloud Linux 3.2104 LTS 64位,类似CentOS8/Red Hat Enterprise Linux 8 / Oracle Linux 8 版本。
sudo dnf install nginx # 安装Nginx,dnf是yum的后继者,这里也可以用yum,一路y
sudo systemctl start nginx # 启动Nginx服务,如果启动失败,可以cat /var/log/nginx/error.log # 查看Nginx错误日志,查看错误信息。比如nginx默认的nginx.conf配置是80端口,看是否被占用。
sudo systemctl enable nginx # 设置Nginx开机自启
#sudo systemctl restart nginx # 重启Nginx服务
#sudo systemctl status nginx.service # 查看Nginx服务
#sudo systemctl stop nginx # 停止Nginx服务
#ps -ef |grep nginx 也可以 kill -9 xxx(kill master和worker两个进程)find / -name nginx.conf # 查找nginx.conf配置文件,通常位于 /etc/nginx/nginx.conf
nginx -t # nginx -t命令测试配置文件的正确性,在任何目录下都可以测试。
cat /var/log/nginx/access.log # 查看Nginx日志
cat /var/log/nginx/error.log # 查看Nginx错误日志
二、反向代理语法
1、基本语法
在NGINX中配置反向代理非常简单,以下是一个基本的NGINX反向代理配置的语法示例:
server {listen 80; # 监听端口号server_name example.com; # 指定服务器名,可以是域名或IP地址location / {proxy_pass http://backend_server; # 指定后端服务器的地址proxy_set_header Host $host; # 设置代理请求头中的Host字段proxy_set_header X-Real-IP $remote_addr; # 设置代理请求头中的X-Real-IP字段proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; # 设置代理请求头中的X-Forwarded-For字段proxy_set_header X-Forwarded-Proto $scheme; # 设置代理请求头中的X-Forwarded-Proto字段}
}
在上面的示例中:
listen
指令用于指定NGINX监听的端口号。server_name
指令用于指定访问该NGINX服务器的域名或IP地址。location / {}
块定义了NGINX对请求的处理规则,/
表示匹配所有请求。proxy_pass
指令用于指定要代理到的后端服务器的地址。proxy_set_header
指令用于设置传递给后端服务器的请求头内容,确保正确传递客户端的信息。
除了上述基本的反向代理配置语法外,NGINX还提供了更多高级的配置选项,如负载均衡、缓存控制、HTTPS支持等。根据具体的需求,可以灵活地配置NGINX来满足不同的反向代理需求。
在实际应用中,你可以根据自己的需求和后端服务的特点进行相应的调整和扩展,以实现更复杂和灵活的反向代理配置。如果需要更多帮助或针对特定情况的配置建议,请提供更多详细信息,我将尽力为你提供支持。
默认的NGINX配置,监控80端口,但是server_name没有配置。
server_name+listen就是浏览器访问的地址,对外暴露的真实地址。后面配置的location,就是内部服务器对应的地址了,可以是域名,可以是内网IP地址,可以是内部jar包的某个网页或者接口。
2、location语法
在NGINX配置中,location
指令用于指定匹配请求的URL路径,并定义对这些请求的处理规则。location
块可以包含一系列指令,用于配置NGINX对特定URL路径的处理方式。以下是关于NGINX中location
指令的一些常见用法和语法:
1. 基本语法
location /path {# 指定对特定路径/path的处理规则
}
2. 匹配规则
-
精确匹配:使用
=
前缀来进行精确匹配location = /path {# 仅匹配精确路径/path }
-
正则表达式匹配:使用
~
前缀表示区分大小写的正则表达式匹配,~*
前缀表示不区分大小写的正则表达式匹配location ~ /path/regex {# 使用正则表达式匹配路径 }
3. 修饰符
-
限制请求方法:使用
=
修饰符限制请求方法location = /path {limit_except GET {deny all;} }
-
内容重定向:使用
@
符号定义命名的位置并在需要时进行内部重定向location /path {try_files $uri $uri/ @named_location; }location @named_location {# 内部重定向到命名位置 }
4. 权重
- 权重匹配:使用
=
修饰符定义权重,数字越小,优先级越高location = /path {# 优先级最高 }location = /path2 {# 优先级其次 }
5. 嵌套location
location
块可以嵌套,实现更复杂的匹配规则和处理逻辑。
location / {location /images {# 处理/images路径下的请求}location /videos {# 处理/videos路径下的请求}
}
6. 其他指令
除了上述示例中的用法外,location
块还可以包含其他一些指令,如proxy_pass
、root
、try_files
等,用于定义NGINX对请求的具体处理方式。
总之,location
指令是NGINX配置中非常重要的一部分,它允许你灵活地定义对不同URL路径的请求的处理规则,从而实现各种复杂的网站和应用程序的需求。通过合理的使用location
指令,可以实现对不同请求路径的定制化处理,满足各种复杂的需求。
7.案例
三、配置反向代理
修改/etc/nginx/nginx.conf文件时,强烈建议先备份一份,例如 :/etc/nginx/nginxbackup.conf
cp /etc/nginx/nginx.conf /etc/nginx/nginxbackup.conf # 备份
vim /etc/nginx/nginx.conf # 修改nginx.conf
笔者有一个主域名:http://wwwfe517.com,然后一台服务器,服务器上面部署了两个jar包,分别是8081端口和8082端口,想让浏览器访问 http://wwwfe517.com 走向8082端口的jar包服务,访问
http://wwwfe517.com/my 走向8081端口的jar包服务。所以走向8082用了回环地址127.0.0.1,是因为nginx和8082的jar包在同一台服务器上面,类似请求转发,本质是一次浏览器请求。走向8081用了重定向外网地址www517.com,这里为什么不用回环,是因为重定向的本质是两次请求,再次请求一次重定向后的地址,如果用内网地址是无法在公网支撑二次请求的。
下面为一个server的内容:
server {listen 80;listen [::]:80;server_name http://wwwfe517.com;root /usr/share/nginx/html;# Load configuration files for the default server block.include /etc/nginx/default.d/*.conf;location /my {rewrite ^/my(.*)$ http://wwwfe517.com:8081$1 permanent;}location / {proxy_pass http://127.0.0.1:8082;}error_page 404 /404.html;location = /40x.html {}error_page 500 502 503 504 /50x.html;location = /50x.html {}}
nginx -t # nginx -t命令测试配置文件的正确性,在任何目录下都可以测试。
sudo systemctl restart nginx # 重启Nginx服务
额外扩展:
一般主流做法是主域名划分多个子域名,然后去配置多个server。比如 wwwfe517.com是主域名,
可以用a.wwfe517.com对应a子域名,b.wwwfe517.com对应b子域名。
server {listen 80;server_name wwwfe517.com;location / {# 配置 wwwfe517.com 的处理逻辑proxy_pass http://127.0.0.1:8082;}
}server {listen 80;server_name a.wwwfe517.com;location / {# 配置 a.wwwfe517.com 的处理逻辑proxy_pass http://127.0.0.1:8083;}
}server {listen 80;server_name b.wwwfe517.com;location / {# 配置 b.wwwfe517.com 的处理逻辑proxy_pass http://127.0.0.1:8084;}
}