企业架构LNMP学习笔记30

1、upstream 中server的关键字:语法:

upstream中的分发之后的几个关键字:

1)backup 备 其他的没有backup标识的都不可用了,才分发到backup;

2)down 此条配置,不会被分发到。

systemctl restart nginx

可以看到,server03能一直能正常使用,所以就不会再转发给server01。所以web页面一直显示server03这个页面。

如果server03服务器停掉,那么才会给server01 backup服务器。

Session一致性的问题:做集群的时候,这个是一定要关注的一个问题。

访问管理后端页面,登录发现验证码不通过。

分析原因:

1)比如分发到web1服务器,**生成验证码,存储在session中,**默认在服务器本地。

2)再次校验的时候,请求分发到web2服务器了,所以验证码一直校验不过。

session:会话机制。服务器本地。

解决方案思路:

1)生成和验证session都请求同一台服务器;ip_hash的配置方法。

2)共享session nfs mysql 内存缓存软件(memcached redis)

把session共享。

两个会话机制:Cookie是存浏览器的,容易被篡改的。用户登录和完成后的值,存在服务器的session中。

Nginx的负载均衡算法:

Nginx官方默认提供了3种负载均衡算法:

1)Round-Robin RR轮询(默认)一次一个的来(实际实验可能会有间隔。)

2)weight(权重)权重高多分发一些,服务器硬件更好的设置权重更高一些。

3)ip_hash 同一个IP,所有的访问都分发到同一个web服务器。

Tip:

第三方模块实现的调度算法 需要编译安装第三方模块

④fair 根据后端服务器的繁忙程度 将请求发到非繁忙的后端服务器

⑤url_hash 如果客户端访问的url是同一个,将转发到同一台后端服务器

验证一:验证加权轮询算法:

示例配置:

8次中,server01分发5次,server03分发3次。

验证二:ip_hash ip一致性的问题:

ip_hash:不够平均了,这个方式有争议。

相关推荐
周壮15 小时前
01 一探究竟:从架构的演变看微服务化架构
微服务·云原生·架构
周壮15 小时前
04 服务治理:Nacos 如何实现微服务服务治理
微服务·云原生·架构
小程故事多_8016 小时前
攻克RAG系统最后一公里 图文混排PDF解析的挑战与实战方案
人工智能·架构·pdf·aigc
王然-HUDDM18 小时前
HUDDM:首个基于认知结构的AI系统设计的AI模型
功能测试·神经网络·架构·系统架构·agi
2301_8153577018 小时前
Java项目架构从单体架构到微服务架构的发展演变
java·微服务·架构
代码游侠21 小时前
复习——ARM Cortex-A 裸机开发深度解析
arm开发·笔记·嵌入式硬件·学习·架构
努力搬砖的咸鱼1 天前
Kubernetes 核心对象详解:Pod、Deployment、Service
微服务·云原生·容器·架构·kubernetes
套码汉子1 天前
从 “重复造轮子” 到 “搭积木式开发”:活动系统架构如何支撑业务高效迭代
架构·系统架构·游戏开发·组件化
Chan161 天前
【 微服务SpringCloud | 方案设计 】
java·spring boot·微服务·云原生·架构·intellij-idea
哈__1 天前
2026 年国产时序数据库技术深度解析:多模态融合架构与工程实践
数据库·架构·时序数据库