Nginx学习(3)—— 反向代理、负载均衡、动静分离、URLRewrite、防盗链

news2025/1/22 18:07:35

文章目录

  • 网关、代理与反向代理
  • Nginx的反向代理配置
  • 基于反向代理的负载均衡的配置
  • 负载均衡策略
    • 负载均衡权重相关配置(weight)
  • 动静分离
    • Nginx配置动静分离
  • URL-rewrite伪静态配置
  • 负载均衡+URL-rewrite
  • 防盗链

网关、代理与反向代理

什么是反向代理:
在这里插入图片描述
所谓代理,指的是在用户和服务器之间有个中间人,对于用户而言它是代理的服务器,对服务器而言它是代理的用户。
那么正向代理就是用户主动配置的代理服务器,通过代理服务器向目标服务器发送请求。
反向代理就是服务器主动提供的,供用户来访问的代理。

什么是网关:
当一个网络需要访问另一个网络时总需要一些出入口,这些出入口就是网关。所谓的反向代理服务器,负载均衡服务器只是网关的一个特殊实现,他们都包含在网关这个大概念里面。

Nginx的反向代理配置

nginx配置文件中添加proxy_pass 参数:(注意下面配置会有问题)
在这里插入图片描述
刷新配置文件后浏览器请求localhost,访问到qq.com:
此时有个问题就是,请求localhost后地址栏的地址会变成https://www.qq.com 原因是proxy_pass选项后的地址是不支持https协议的,否则nginx发出一个页面跳转的响应,从而跳转到指定的网址。
在这里插入图片描述

下面配置也会有问题: 因为地址不全
在这里插入图片描述

正确配置应该是:
在这里插入图片描述
在这里插入图片描述

基于反向代理的负载均衡的配置

在这里插入图片描述

负载均衡策略

轮询:
逐一将请求分发给服务器。缺点:不能保持会话。
ip_hash:
判断来源的ip地址,相同的ip指向相同的服务器。缺点:ip变化时会话也会丢失,比如移动端。
least-conn:
最少连接数访问。哪个服务器接收的用户少就给谁分配。
URL_hash:
根据用户访问的URL定向指定服务器。定向流量转发(对URL取hash相同的hash转发给相同的服务器)。也不能保持会话,比如注册页面和登陆页面的hash不同,在一台服务器上注册后再发起登录请求时又是另一台服务器,此时就找不到登录信息。适用于访问固定资源不在同一服务器时。
fair:
根据服务器的响应时间分发请求。会有流量倾斜的风险。

注意:
fair、url_hash、least-conn、ip_hash生产上都不常用,最大的原因是这些策略不能动态的上线或下线服务器。非常不灵活。
一般都是用lua脚本语言来自定义转发。

负载均衡权重相关配置(weight)

服务器集群中的设备条件总会有差异,所以需要牛一点的设备多承担一些作业,此时就可以给性能高的服务器较高的权重,以此来提高用户体验。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

动静分离

场景:
只适用于中小型并发较小的网站。

原理:
用户的以此请求会伴随很多个动态请求和静态请求,其中获取js、图片等资源属于静态访问。
原始的服务是Nginx只负责做反向代理,所有的资源都在应用服务器上,用户请求Nginx,Nginx再请求应用服务器,服务器将资源返回给Nginx再由Nginx返回给用户。
动静分离是指将本来在应用服务器上的静态资源放到Nginx反向代理服务器上,当用户发起静态请求时直接由Nginx提供资源,动态请求再去转发,以此来实现动静分离。从而提高网页的访问速度。

Nginx配置动静分离

在这里插入图片描述

URL-rewrite伪静态配置

在这里插入图片描述
在这里插入图片描述
rewrite 也可以写正则表达式

rewrite 结尾标志:

  1. last:本条规则匹配完成后,继续向下匹配新的location URI规则。
  2. break:本条规则匹配完成立即终止,不再匹配后面的任何规则。
  3. redirect:返回302临时重定向,浏览器地址会显示跳转后的URL地址。
  4. permanent:返回301永久重定向,浏览器地址栏会显示跳转后的URL地址。

负载均衡+URL-rewrite

在这里插入图片描述

防盗链

什么是防盗链:
在跨站访问资源的时候,被称为“盗链”。假设B站点作为一个商业网站,有很多自主版权的图片,用于商业目的。而A站点,希望在自己的网站上面也展示这些图片,直接使用。
这样,大量的客户端在访问A站点时,实际上消耗了B站点的流量,这就称之为“盗链”。
我们要防止这种情况的发生,就称为“防盗链”。

怎么实现防盗链:
HTTP协议和标准的浏览器对于解决这个问题提供便利,浏览器在加载非本站的资源时,会增加一个头域,头域名字固定为referer,该字段记录了一个请求的来源,第一次请求是没有referer字段的。
在这里插入图片描述
服务器可以检测referer是否是允许的主机,如果是那就接收请求否则拒绝。

防盗链的配置:

valid_referers none | blocked | server_names | strings...

- none:检测referer头域不存在的情况。
- blocked:检测referer头域的值被防火墙或者代理服务器删除或伪装的情况。这种情况该头域的值不以"http://""https://"开头。
- server_names:设置一个或多个URL,检测Referer头域的值是否是这些URL中的某一个。

Nginx配置文件中在需要防盗链的location中添加如下配置

valid_referers none 主机名;	# none 表示没有referer头域的时候允许访问,也可不配置,不配置时没有referer则不能访问
if ($invalid_referer){
	return 403;
}
# 解释:valid_referers配置表示 如果referer头域中匹配到“主机名”那就接收请求。if处理的是无效的引用就返回403

在这里插入图片描述

使用curl测试:

# 1. 查看192.168.165.101站点响应的头信息
curl -I http://192.168.165.101/img/img.png

# 2. 带引用,表示从http://baidu.com访问的192.168.165.101站点
curl -e "http://baidu.com" -I http://192.168.165.101/img/img.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/397286.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在linux上部署Java项目

在Linux部署Java环境 要是想要部署java web程序,首先要配置环境 jdk tomcat mysql 安装jdk 推荐的方法是使用yum直接安装openjdk(开源的,与官方的jdk功能差不多),目前使用的最多的就是jdk8系列 yum list | grep jdk 在源上搜索所有关于jdk的文件 devel表示development的意思…

3.8多线程

案例一-线程安全的单例模式(面试)是一种设计模式,设计模式针对写代码时的一些常见场景给出一些经典解决方案单例模式的两种典型实现饿汉模式懒汉模式饿汉的单例模式:比较着急去进行创建实例懒汉的单例模式,是不太着急创建实例,,只是在用的时候,才真正创建这个是类对象,也就是.c…

【C++修炼之路】26.C++11(语法糖)

每一个不曾起舞的日子都是对生命的辜负 C11C11(语法糖)本节目标一.C11简介二.统一的列表初始化2.1 {}初始化2.2 std::initializer_list三.声明3.1 auto3.2 decltype3.3 nullptr四.总结C11(语法糖) 本节目标 C11简介 列表初始化 变量类型推导 一.C11简介 在2003年C标准委员…

信息收集-

url: https://en.wikipedia.org:443/wiki/hypertext_Transfer_Protocol?id123#HTTP/1.1_response_messages https:协议 en.wikipedia.org:域名 443:端口 wiki/hypertext_Transfer_Protocol:文件路径 id123&…

Unity 混合操作(Blending)

渲染图形时,在执行所有着色器并应用所有纹理后,像素将写入到屏幕。这些像素与已有像素的组合方式由 Blend 命令控制。用于生成透明对象。《Unity Shader入门精要》大致解释:片元通过了模板测试和深度测试之后,会进行混合步骤。如果…

三、SpringMVC的拦截器

1. SpringMVC的拦截器 针对请求和响应进行的额外的处理.在请求和响应的过程中添加预处理,后处理和最终处理. 2. 拦截器的应用场景 1、日志记录:记录请求信息的日志 2、权限检查,如登录检查 3、性能检测:检测方法的执行时间 3. 拦截器执行的…

调用一个函数时发生了什么?

欢迎来到 Claffic 的博客 💞💞💞 前言: 用C语言写代码,如果一个工程相对复杂时,我们往往会采取封装函数的方式。在主函数中调用函数 这一看似简单的过程,实际上有很多不宜观察的细节&#xff0…

计算机组成原理|第三章(笔记)

目录第三章 系统总线3.1 总线的基本概念3.2 总线的分类3.2.1 片内总线3.2.2 系统总线3.2.3 通信总线3.3 总线特性及性能指标3.3.1 总线的特性3.3.2 总线性能指标3.4 总线结构3.4.1 单总线结构3.4.2 多总线结构3.4.3 总线结构举例3.5 总线控制3.5.1 总线判优控制3.5.2 总线通信控…

ALG和STUN

目录 ALG 应用层网关讲解 Client1使用FTP主动模式建立FTP Client1使用FTP被动模式建立FTP STUN讲解 ALG 应用层网关讲解 用来替换应用层信息 Client1使用FTP主动模式建立FTP 主动模式:服务器收到客户端发来的请求FTP的地址和端口 服务器使用20端口直接向客户端建…

webpack dll 提升构建速度

DLL,动态链接库(Dynamic Link Library 或者 Dynamic-link Library),由微软公司提出。目的是为了节约应用程序所需的磁盘和内存空间。 在一个传统的非共享库中,如果两个程序调用同一个子程序,就会出现两份那…

Redis-6集群

文章目录前言Redis集群原理搭建Redis集群集群拓展后记前言 前两期介绍和搭建了Redis的主从复制架构和哨兵模式,虽然哨兵模式能够实现自动故障转移主备切换,一定程度上提高了系统的容错性 但这两种架构模式都不能解决单节点的并发压力和物理上线的问题&…

行测-判断推理-图形推理-样式规律-空间重构-立体拼合

有凸必有凹,排除A CD显然不对选BA和4能组成长方体B和3能组成长方体C和1能组成长方体选D这两个东西应该在同一侧,排除A C中间应该要由凸起,排除D选B图1向左旋转90图2逆时针旋转90选A

内网环境解决SSL证书问题

本来这个没什么好写的,但是坑实在有点多,不得不写个文章记录下来。 创建证书看这里!!! 很多知识点要结合这个页面内容来看。 创建证书已经看过相关文章,然后用unity跑的时候发现连不上,完全没…

【Go】基于VS Code配置Go语言环境

教程 1. 安装go环境 打开官网:https://go.dev/dl/,找到对应系统的环境文件。 安装完成后软件会自动把路径添加到环境变量,可以在命令行中检验一下 2. 在VS Code中安装必要的插件 这一步我理解的就是提供语法高亮和代码提示 3. 打开一个路…

基于智能边缘和云计算的数字经济服务细粒度任务调度机制

数字经济被各国视为推动经济增长的必然选择,为经济高质量发展提供了新机遇、新路径。对于中国市场而言,云计算背后的强大基础是数字经济不可阻挡的发展趋势。在数字经济中,云作为基础设施成为构建数字经济金字塔的基础。为缓解数字经济服务器…

Windows下实现Linux内核的Python开发(WSL2+Conda+Pycharm)

许多软件可以通过Python交互,但没有开发Windows版本,这个时候装双系统或虚拟机都很不方便,可以采取WSL2CondaPycharm的策略来进行基于Linux内核的Python开发。启动WSL2,安装Linux内核教程:旧版 WSL 的手动安装步骤 | M…

交并比(IOU)的计算方法

交并比(IOU, Intersetion Over Union),意思就是交集和并集的比值,用来评价两个几何图形的面积重合度,在目标检测算法模型中,通常被用来计算预测框与真实框的误差(损失函数)或者在非极大值抑制&a…

便捷式储能电源核心技术--单相逆变器设计

便捷式储能电源核心技术–单相逆变器设计 1.逆变器的规格参数 输入电压直流400V输出电压交流rms220V开关频率10kHz滤波电容6.23uF控制方式单极性倍频2.视频学习链接 视频学习链接 3.主电路仿真设计

日志服务搭建-ES-FileBeat-Kibana

1次订单量突增问题,导致了有几个数据没有录库,但是确有支付的记录,啥玩意,还能有这个操作,组内安排问题定位,解决,一看打出来的日志,只有支付有,生成订单这边没有&#x…

读书笔记-终身学习

前言人需要终身成长,也需要终身学习,以下是记录个人读书学习的笔记总结,希望能给大家一点借鉴,仅供参考。笔记1、《匠人精神》秋山利辉是日本神奈川县横滨市都筑区“秋山木工”的经营者,从事订制家具制作业务。是一家小…