Nginx-负载均衡-动静分离-虚拟主机

负载均衡

负载均衡基本使用

1 配置上游服务器

upstream myserver { #是server外层server  ip1:8080;server  ip1:8080;       
}

2 配置代理

server {location  / {         proxy_pass  http://myserver;#请求转向myserver 定义的服务器列表  注意这个http不能丢       proxy_redirect off;proxy_set_header X-Real-IP $remote_addr;#后端的Web服务器可以通过X-Forwarded-For获取用户真实IPproxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}

负载均衡的策略

轮询

1 轮询
默认的权重都是1,则访问顺序为ABABAB

upstream myserver { server  ip1:8080;server  ip1:8080;       
}

2 加权轮询 则访问顺序为ABBABB

upstream myserver { server  ip1 weight=1;server  ip2 weight=2;
}

3 热备
当我们第一台服务器能够正常提供服务的时候,服务器2是不会参与服务的,当我们的服务1 有问题了则会切换至服务器2

upstream myserver { server  ip1:8080;server  ip2:8080; backup;  #热备     
}

4 复杂轮询

upstream myserver { server ip1:8080 weight=2 max_fails=1 fail_timeout=10; #这里的fail_timeout有两层意思,第一层意思是在10s内允许的失败菜蔬为1 第二层意思是 当10内失败过一次服务器暂停服务10s后继续服务。server ip2:8080 weight=1 max_fails=3 fail_timeout=20;  server ip3:8080 backup; #热备 server ip4:8080 down;
}upstream myserver { server ip1:8080 max_fails=1 fail_timeout=10;server ip1:8080 max_fails=1 fail_timeout=10;  
}
  • down:表示当前的server暂时不参与负载均衡,该状态一般会对需要停机维护的服务器进行设置。
  • backup:预留的备份机器。当其他所有的非backup机器出现故障或者忙的时候,才会请求backup机器,因此这台机器的压力最轻。
  • max_fails:表示在 fail_timeout 时间内最多允许的失败次数,默认为1。当超过最大次数时,返回proxy_next_upstream 模块定义的错误。
  • fail_timeout:经历了max_fails次失败后,暂停服务的时间,默认为 10 秒。max_fails可以和fail_timeout一起使用。
  • weight:默认为1。weight越大,负载的权重就越大。
IP HASH

nginx会让相同的客户端ip请求相同的服务器。如果是有状态的服务则应该采用ip_hash 比如登录功能,在第一台服务器记录了登录的状态,第二次邀请求同一台服务器才能读取到这个登录态。当然了会有其它的方式来解决这些问题,这里不做讨论。
1 普通hash

upstream myserver { ip_hash ;server  ip1:8080 ;server  ip2:8080 ;
}

2 复杂hash

upstream myserver { ip_hash ;server ip1:8080 weight=2 max_fails=3 fail_timeout=20;server ip2:8080 weight=1 max_fails=3 fail_timeout=20;
}

对于该策略需要注意以下几点:

  • 在 nginx1.3.1 版本之前,该策略中不能指定 weight 属性。
  • 该策略不能与 backup 同时使用。
  • 此策略适合有状态服务,比如 session。
  • 当有服务器宕机,必须手动指定 down 属性,否则请求仍是会落到该服务器。

3 least_conn
把请求转发给连接数最少的服务器。

upstream myserver { least_conn ;server ip1:8080 weight=2 max_fails=3 fail_timeout=20;server ip2 weight=1 max_fails=3 fail_timeout=20;  server ip3:8080 backup; #热备 server ip4:8080 down;    
}

动静分离

upstream static.liyong.com{ #两台静态资源服务器,两台静态资源要一致server ip1:80;server ip2:80;
}upstream dynamic.liyong.com{ #两台动态资源服务器server ip3:8081;server ip4:8082;
}server {listen 80;server_name localhost;location ~* .*(css|js|html|images).+ {proxy_pass http://static.liyong.com;}location / {proxy_pass http://dynamic.liyong.com;}
}

静态资源服务器:

location / { #可以只用一个/拦截所有的请求根据目录来分类 也可以再分类root statics;}

虚拟主机

一个server就是一个虚拟主机

server {listen 80;server_name www.68.com;location / {proxy_pass http://www.68.com;}
}
server {listen 80;server_name bj.68.com;location / {proxy_pass http://bj.68.com;}
}
server {listen 80;server_name sh.68.com;location / {proxy_pass http://sh.68.com;}
}

每个虚拟主机负载均衡


upstream  www.68.com {127.0.0.1:9081 weight=1;127.0.0.1:9082 weight=2;
}upstream  bj.68.com {127.0.0.1:9083 weight=1;127.0.0.1:9084 weight=2;
}upstream  bj.68.com {127.0.0.1:9085 weight=1;127.0.0.1:9086 weight=2;
}

这样就实现了访问不同域名,就负载到不同的服务器,分地区也相当于分流

http://sh.68.com/path
在这里插入图片描述
在这里插入图片描述
http://bj.68.com/path
在这里插入图片描述
在这里插入图片描述

参考资料 极客时间 nginx

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

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

相关文章

Git 分支设计规范

开篇 这篇文章分享 Git 分支设计规范,目的是提供给研发人员做参考。 规范是死的,人是活的,希望自己定的规范,不要被打脸。 在说 Git 分支规范之前,先说下在系统开发过程中常用的环境。 DEV 环境:用于开发…

属性的加密算法CP-ABE

目录 CP-ABE 属性的加密算法CP-ABE 应用 CP-ABE 传统的ABE系统是由属性来描述密文,并将策略嵌入到用户的密钥中。而CP-ABE使用属性刻画用户的资格,并且由数据的加密方来制定密文访问策略,以决定谁可以解密密文。CP-ABE中,用户的私钥与一系列属性相关,只有用户的属性符…

数电实验-----实现74LS153芯片扩展为8选1数据选择器以及应用(Quartus II )

目录 一、74LS153芯片介绍 管脚图 功能表 二、4选1选择器扩展为8选1选择器 1.扩展原理 2.电路图连接(Quartus II ) 3.仿真结果 三、8选1选择器的应用 1.三变量表决器 2.奇偶校验电路 一、74LS153芯片介绍 74ls153芯片是属于四选一选择器的芯片。…

Android13版本新特性介绍

以下以围绕使用样例的方式来介绍Android13带来的版本新特性。 1、支持设置带主题的应用图标: 其实使用很简单,就是在应用图标xml中新增 monochrome属性,应用就支持了变换带主题的图标 2、各应用语言偏好设定 启用方式有两种: …

系列五、GC垃圾回收【四大垃圾算法-复制算法】

一、堆的内存组成 二、复制算法 2.1、发生位置 复制算法主要发生在新生代,发生在新生代的垃圾回收也被叫做Minor GC。 2.2、 Minor GC的过程 复制>清空》交换 1、eden、from区中的对象复制到to区,年龄1 首先,当eden区满的时候会触发第一…

【数据结构初阶】双链表

双链表 1.双链表的实现1.1结口实现1.2申请结点1.3初始化双链表1.4打印双链表1.5尾插1.6尾删1.7头插1.8头删1.9计算大小1.10查找1.11pos位置插入1.12删除pos位置1.12删除双链表 全部码源 1.双链表的实现 1.1结口实现 #include<stdio.h> #include<stdlib.h> #inclu…

STM32F4系列单片机GPIO概述和寄存器分析

第2章 STM32-GPIO口 2.1 GPIO口概述 通用输入/输出口 2.1.1 GPIO口作用 GPIO是单片机与外界进行数据交流的窗口。 2.1.2 STM32的GPIO口 在51单片机中&#xff0c;IO口&#xff0c;以数字进行分组&#xff08;P0~P3&#xff09;&#xff0c;每一组里面又有8个IO口。 在ST…

AcWing 717. 简单斐波那契

原题链接 题目 以下数列 0 1 1 2 3 5 8 13 21 … 被称为斐波纳契数列。 这个数列从第 3 项开始&#xff0c;每一项都等于前两项之和。 输入一个整数 N &#xff0c;请你输出这个序列的前 N 项。 输入格式 一个整数 N 。 输出格式 在一行中输出斐波那契数列的前 N 项&…

共享内存和信号量的配合机制

进程之间共享内存的机制&#xff0c;有了这个机制&#xff0c;两个进程可以像访问自己内存中的变量一样&#xff0c;访问共享内存的变量。但是同时问题也来了&#xff0c;当两个进程共享内存了&#xff0c;就会存在同时读写的问题&#xff0c;就需要对于共享的内存进行保护&…

Java shp 转 GeoJson

文章目录 1. 依赖安装1.1 配置软件源1.2 引入依赖 2. 功能实现3. 参考链接 1. 依赖安装 1.1 配置软件源 在项目 pom.xml 添加, maven 的 settings.xml 配置的源&#xff0c;mirrorOf 不能是 *,不然安装不上 <project>...<repositories><repository><id…

linux rm 删除找回的几种方法 工具介绍3之testdisk以及Photorec xfs文件系统格式的

使用“dd”的经典方法 dd 非常强大&#xff0c;可用于从磁盘写入文件以及将文件写入分区或卷。但是&#xff0c;建议您首先尝试使用 ddrescue 或 dd_rescue&#xff0c;因为 dd 不适合处理损坏的数据&#xff0c;并且可能会使用次优方法来恢复数据&#xff0c;如果可能的话&am…

【LeetCode】160. 相交链表

160. 相交链表 难度&#xff1a;简单 题目 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点&#xff0c;返回 null 。 图示两个链表在节点 c1 开始相交&#xff1a; 题目数据 保证 整个链式结构中…

快速集成Skywalking 9(Windows系统、JavaAgent、Logback)

目录 一、Skywalking简介二、下载Skywalking服务端三、安装Skywalking服务端3.1 解压安装包3.2 启动Skywalking 四、关于Skywalking服务端更多配置五、Java应用集成skywalking-agent.jar5.1 下载SkyWalking Java Agent5.2 集成JavaAgent5.3 Logback集成Skywalking5.4 集成效果 …

Hafnium之PE MMU配置

启用了安全虚拟化(HCR_EL2.VM = 1),对于S-EL1分区,从安全EL1&0 Stage-1转换中输出两个IPA空间(安全和非安全)。EL1&0 Stage-2转换硬件由: 1)SP EL1&0 Stage-1 MMU被禁用时的安全IPA。 2)当启用安全EL1&0 Stage-1 MMU时,安全或非安全IPA之一。 VTC…

数据库的三范式(Normalization)

数据库的三范式&#xff08;Normalization&#xff09;是关系数据库设计中的基本理论原则&#xff0c;旨在减少数据冗余和提高数据库的数据组织结构。三范式通过将数据分解为更小的表&#xff0c;并通过关系建立连接&#xff0c;使得数据库设计更加灵活、规范和容易维护。在这篇…

【Redis】RedisTemplate最全的常用方法

文章目录 前言1.RedisTemplate常用方法2.String类型3.Hash类型4.List类型5.Set类型6.zSet类型 前言 RedisTemplate常用方法String类型Hash类型List类型Set类型zSet类型 Redis常用的数据类型&#xff1a;String、Hash、List、Set、zSet 1.RedisTemplate常用方法 redisTempla…

C语言——函数的嵌套调用

#define _CRT_SECURE_NO_WARNINGS 1#include<stdio.h>void new_line() {printf("Hello\n"); }void three_line() {int i0;for(i0;i<3;i){new_line();} }int main() {three_line();return 0; }

FPGA实现双向电平转换

网上搜了一圈&#xff0c;好像没看到的类似的中文资料&#xff0c;不过MicroSemi有个文档AC349上给出了完整的解决方案&#xff0c;还有参考代码。 话不多说&#xff0c;看图&#xff1a; 欲知详情的朋友&#xff0c;请参考 AC349

异步爬取+多线程+redis构建一个运转丝滑且免费http-ip代理池 (二)

继上一章: CSDN 本次需要做的是进行有效ip的验证! 我们知道,从网页上爬取上千上万个ip之后,因为是免费的代理,所以,对这上千上万个ip进行验证有效性就需要考虑效率上的问题了; 而验证ip有效性的唯一办法,就是通过对网络发起请求;如果state=200,就是有效,否则就是无效; 而上…

你听说过“消费多少返利多少的”模式吗?

今天分享一个新的销售套路&#xff0c;看懂套路奋斗节约3年&#xff0c;你听说过“消费多少返利多少的”模式吗&#xff1f; 消费报销模式就是消费者在平台的消费&#xff0c;根据贡献度和活跃度平台去把之前消费的模式&#xff0c;给你返本了甚至还额外给你补贴奖励&#xff…