Nginx负载均衡及动静分离

目录

一、Nginx负载均衡【重点】

1.1 轮询

1.2 权重

1.3 ip_hash

二、Nginx动静分离【重点】

2.1 动态资源代理

2.2 静态资源代理


官方文档 nginx

一、Nginx负载均衡【重点


Nginx为我们默认提供了三种负载均衡的策略:

  • 轮询:将客户端发起的请求,平均的分配给每一台服务器。

  • 权重:会将客户端的请求,根据服务器的权重值不同,分配不同的数量。

  • ip_hash:基于发起请求的客户端的ip地址不同,他始终会将请求发送到指定的服务器上。

1.1 轮询

想实现Nginx轮询负载均衡机制只需要在配置文件中添加以下内容

upstream 名字 {server ip:port;server ip:port;...
}
​
server {listen 80;server_name localhost;location / {proxy_pass http://upstream的名字/;}
}
例如:http {include       /etc/nginx/mime.types;default_type  application/octet-stream;
​upstream win {server ip:8080;server ip:8081;}
​server {listen       80;server_name  localhost;location / {proxy_pass http://win/;}.....略

1.2 权重

实现权重的方式

upstream 名字 {server ip:port weight=权重比例;server ip:port weight=权重比例;...
}
server {listen 80;server_name localhost;location / {proxy_pass http://upstream的名字/;}
}
例如:http {include       /etc/nginx/mime.types;default_type  application/octet-stream;
​upstream win {server ip:8080 weight=3;server ip:8081 weight=7;}
​server {listen       80;server_name  localhost;location / {proxy_pass http://win/;}.....略

1.3 ip_hash

ip_hash实现

upstream 名字 {ip_hash;server ip:port;server ip:port;...
}
server {listen 80;server_name localhost;location / {proxy_pass http://upstream的名字/;}
}例如:http {include       /etc/nginx/mime.types;default_type  application/octet-stream;
​upstream win {ip_hash;server ip:8080;server ip:8081;}
​server {listen       80;server_name  localhost;location / {proxy_pass http://win/;}.....略

二、Nginx动静分离【重点


什么是动态资源和静态资源?

​ 动态资源:一般指后端资源

​ 静态资源:一般指html,js,css,img,plugins

什么是动静分离?

​ 将静态资源部署在nginx上,当接收到请求是访问静态资源时,直接在nginx配置的静态资源目录下面获取静态资源。如果是动态资源,利用nginx 反向代理原理,将请求转发给后台应用处理,这就是动静分离。

Nginx的并发能力公式:

​ worker_processes * worker_connections / 4 | 2 = Nginx最终的并发能力

动态资源需要/4,静态资源需要/2.

Nginx通过动静分离,来提升Nginx的并发能力,更快的给用户响应。

2.1 动态资源代理

使用proxy_pass动态代理

# 配置如下
location / {proxy_pass 路径;
}

2.2 静态资源代理

使用root静态代理

# 配置如下
location / {root 静态资源路径;index 默认访问路径下的什么资源;autoindex on; # 代表展示静态资源全的全部内容,以列表的形式展开。
}
​
# 先修改docker,添加一个数据卷,映射到Nginx服务器的一个目录
# 添加了index.html和1.jpg静态资源
# 修改配置文件

项目是nginx.conf 配置文件的编写方式.

worker_processes  1;        
error_log  /var/log/nginx/error.log warn;
# 以上统称为全局块, 
# worker_processes他的数值越大,Nginx的并发能力就越强
# error_log 代表Nginx的错误日志存放的位置
​
events {worker_connections  1024;
}
# events块
# worker_connections他的数值越大,Nignx并发能力越强
​
​
http {include       /etc/nginx/mime.types;default_type  application/octet-stream;
​upstream win {ip_hash;server ip:8080;server ip:8081;}
​server {listen       80;server_name  localhost;location / {root   /html;index  index.html index.htm;proxy_pass http://win/;}
​location ~* \.(gif|jpg|png)$ {root   /html/img;}
​}
}

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

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

相关文章

【chatgpt】pytorch中requires_grad=True

在 PyTorch 中,requires_gradTrue 是一个非常重要的标志,它指示 PyTorch 是否需要为某个张量计算梯度。这在训练神经网络时尤为关键,因为我们通常需要通过反向传播来更新模型参数,以最小化损失函数。 requires_gradTrue 的作用 …

Perl变量作用域全解析:掌握变量的可见之旅

Perl变量作用域全解析:掌握变量的可见之旅 Perl是一种灵活的脚本语言,以其对文本处理的强大能力而闻名。在Perl编程中,变量作用域的概念至关重要,它决定了变量在代码中的可见性和生命周期。本文将深入探讨Perl中变量作用域的定义…

AI降重,不再难:降AI率的实用技巧大揭秘

如何有效降低AIGC论文的重复率,也就是我们说的aigc如何降重?AIGC疑似度过高确实是个比较愁人的问题。如果你用AI帮忙写了论文,就一定要在交稿之前做一下AIGC降重的检查。一般来说,如果论文的AIGC超过30%,很可能会被判定…

CAS操作

CAS 全称:Compare and swap,能够比较和交换某个寄存器中的值和内存中的值,看是否相等,如果相等,则把另外一个寄存器中的值和内存进行交换. (这是一个伪代码,所以这里的&address实际上是想要表示取出address中的值) 那么我们可以看到,CAS就是这样一个简单的交换操作,那么…

基于SpringBoot房屋租赁管理系统设计和实现(源码+LW+调试文档+讲解等)

💗博主介绍:✌全网粉丝10W,CSDN作者、博客专家、全栈领域优质创作者,博客之星、平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌💗 Java精品实战案例《1000套》 2025-2026年最值得选择的Java毕业设计选题大全&#xff…

TVBox自定义配置+软件密码版本

apk地址 : https://gitee.com/wheat-wheat/kekeda-duck-apk 1、安装安卓SDK Android SDK Windows 安装及环境配置教程_sdk manager windows-CSDN博客 修改点: 基础配置: java版本:

在系统已经存在postgres时,安装gitlab

以下作废,感觉直接装gitlab太不稳定了,现在转而使用dockers安装gitlab https://cloud.tencent.com/developer/article/2309562 https://www.cnblogs.com/lvzhenjiang/p/14949722.html https://cloud.tencent.com/developer/article/2256871 https://blo…

新火种AI|国产大模型展开决战,是资本游戏还是技术革命?

作者:一号 编辑:美美 资本角逐与技术革新,国产大模型的双线战场已然开启。 随着人工智能技术的不断进步,国产大模型正迅速成为行业关注的焦点。在这个由数据驱动的时代,资本的注入和技术创新的加速,让国…

Spring Cloud中的服务路由与过滤技术实现

Spring Cloud中的服务路由与过滤技术实现 大家好,我是微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿! 在微服务架构中,服务路由与过滤是确保服务之间通信有效性和安全性的重要技术。Spring Cloud作为…

Python28-6 随机森林

随机森林算法详细介绍 1. 理论背景 随机森林(Random Forest)是一种由Leo Breiman和Adele Cutler在2001年提出的集成学习方法。它结合了多个决策树的预测结果,以提高模型的准确性和鲁棒性。 2. 算法细节 随机森林的构建过程可以分为以下几…

Qt——升级系列(Level Eight):界面优化

目录 QSS 背景介绍 基本语法 QSS设置方式 指定控件样式设置 全局样式设置 从文件加载样式表 使用Qt Designer 编辑样式 选择器 选择器概况 子控件选择器 伪类选择器 样式属性 盒模型 控件样式示例 按钮 复选框、单选框 输入框 列表 菜单栏 登录界面 绘图 基本概念 绘制各种形…

[Go 微服务] Kratos 使用的简单总结

文章目录 1.Kratos 简介2.传输协议3.日志4.错误处理5.配置管理6.wire 1.Kratos 简介 Kratos并不绑定于特定的基础设施,不限定于某种注册中心,或数据库ORM等,所以您可以十分轻松地将任意库集成进项目里,与Kratos共同运作。 API -&…

Linux内网端口转公网端口映射

由于服务商做安全演练,把原先服务器内网的端口映射到外网端口全都关闭了,每次维护服务器特别麻烦,像数据库查询如果用原生的mysql 去连接,查询返回的结果乱了,非常不方便。 查了服务还是可以正常访问部分外网的&#x…

知识图谱查询语言的表示

文章目录 SPARQL知识图谱查询基本构成常见的SPARQL查询算子语义Markup表示语言SPARQL知识图谱查询基本构成 RDF 支持类似数据库的查询语言,叫作SPARQL,它提供了查询RDF 数据的标准语法、处理SPARQL查询的规则以及结果返回形式。 变量,RDF中的资源,以“?”或者“$”指示;…

【chatgpt】pytorch的全连接层FC

文章目录 创建全连接层全连接层(线性层)使用 PyTorch 定义全连接层1. 定义一个全连接层2. 查看层的参数3. 使用全连接层 示例:构建一个简单的神经网络总结 打印FC参数输出解释完整代码示例示例输出总结 线性层的参数和属性线性层的参数和属性…

抖音外卖服务商入驻流程及费用分别是什么?入驻官方平台的难度大吗?

随着抖音关于新增《【到家外卖】内容服务商开放准入公告》的意见征集通知(以下简称“通知”)的发布,抖音外卖服务商入驻流程及费用逐渐成为众多创业者所关注和热议的话题。不过,就当前的讨论情况来看,这个话题似乎没有…

软件测试中安全测试包含内容及安全测试怎么测

一、软件测试安全测试包含哪些 1. 漏洞扫描 漏洞扫描是软件测试安全测试的基础,它用于检测应用程序和系统中存在的已知漏洞。安全测试工具如AppScan、OWASP ZAP和Nessus等可以对应用程序进行自动化扫描,发现可能存在的漏洞,如跨站点脚本&am…

7.2、指针变量的定义和使用

代码 #include <iostream> using namespace std; #include <string>int main() {//定义指针int a 10;//指针定义语法&#xff1a;数据类型 * 指针变量名int * p;//让指针记录变量a的地址p &a;cout << "a的地址为&#xff1a;" << &am…

MySQL之应用层优化(二)

应用层优化 Web服务器问题 寻找最优并发度 每个Web服务器都有一个最佳并发度——就是说&#xff0c;让进程处理请求尽可能快&#xff0c;并且不超过系统负载的最优的并发连接数。这就是前面说的最大系统容量。进行一个简单的测量和建模&#xff0c;或者只是反复试验&#xf…

2024年湖南省各市科小申报时间(科技型中小企业申报流程、条件、好处)新政

湖南省各市科小申报时间流程 一、评价管理 省科技厅牵头负责科技型中小企业评价工作的组织和监督、实地核查、公示公告、入库登记及编号撤销和集中抽查工作&#xff0c;及时处理相关异议、投诉和举报信息。 各市州科技局负责科技型中小企业评价工作的具体实施&#xff0c;组…