Nginx安装及配置负载均衡
文章目录
- 官网下载Nginx
- 解压安装
- 常用命令
- 配置负载均衡
- 七层负载均衡
- nginx的负载均衡语法
- nginx的负载均衡策略
- 故障下线和备份服务设置
- proxy_pass参数
官网下载Nginx
http://nginx.org/en/download.html
注:下载稳定版,即Stateable Version的,选择对应操作系统,我这里是Linux,就选择了 nginx-1.24.0
解压安装
tar -xvf nginx-1.24.0.tar
- 安装C++库和openssl等
yum -y install gcc-c++
yum -y install pcre pcre-devel
yum -y install zlib zlib-devel
yum -y install openssl openssl-devel
- 安装
顺序执行下列命令
./configure
make
make install
常用命令
./nginx -s stop #停止nginx
./nginx -s quit #安全退出
./nginx -s reload #修改了文件之后重新加载该程序文件
ps aux|grep nginx #查看nginx进程
sbin/nginx -c /conf/nginx.vonf #指定配置文件启动
配置负载均衡
七层负载均衡
nginx的负载均衡语法
http {upstream [你的负载均衡机制名称,随便设置一个就好] {server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];}server {listen [nginx监听端口];server_name [head中的host对应的值]location / {proxy_pass http:// [你的负载均衡机制名称,对应上面upstream的值];}}
}
nginx的负载均衡策略
- 轮询(Round Robin默认)
轮询是最常见的一种负载均衡策略。Nginx默认使用轮询策略,将请求按照顺序分配到每个服务器,当请求到达最后一个服务器后,再从第一个服务器继续轮询。,如果后端服务器挂了,则自动剔除。
upstream backend {server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];
}server {listen 80;server_name example.com;location / {proxy_pass http://backend;}
}
- 权重(Weighted Load Balancing)
指定轮询的频率,weight和访问率成正比,用于后端服务器性能不均匀的情况
upstream backend {server [ip地址]:[端口值] weight=3;server [ip地址]:[端口值] weight=2;server [ip地址]:[端口值] weight=1;
}server {listen 80;server_name example.com;location / {proxy_pass http://backend;}
}
- IP Hash
IP Hash是一种漂亮的负载均衡策略,具有Session保持的优点。算法的基本思路是通过对客户端的IP地址取Hash值,将此Hash值与服务器列表中的IP地址的Hash值进行比较,找到具有匹配Hash值的服务器。这样相同IP的请求总是被转发到同一台后端服务器处理,保证Session信息在同一台服务器上处理。
upstream backend {ip_hash; #使用IP hash策略server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];
}server {listen 80;server_name example.com;location / {proxy_pass http://backend;}
}
- 最少连接(Least Connections)
nginx会尽量不让负载繁忙的应用服务器上负载过多的请求,相反的,会把新的请求发送到比较不繁忙的服务器。
upstream backend {least_conn; #使用Least Connections策略server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];
}server {listen 80;server_name example.com;location / {proxy_pass http://backend;}
}
- 随机(Random)
Random会将请求随机发送到后端服务器上,这种策略比较简单,但是不保证对后端服务器的负载均衡性。
upstream backend {random; #使用Random策略server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];
}server {listen 80;server_name example.com;location / {proxy_pass http://backend;}
}
- URL Hash
URL Hash会根据请求的URL的Hash值来将请求发送到后端服务器。相同URL的请求总是被转发到同一台后端服务器处理,从而保证Session信息在同一台服务器上处理。
upstream backend {hash $request_uri; #使用URL Hash策略server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];server [ip地址]:[端口值];
}server {listen 80;server_name example.com;location / {proxy_pass http://backend;}
}
故障下线和备份服务设置
1.down
假如有一台主机是出了故障,或者下线了,要暂时移出,那可以把它标为down,表示请求是会略过这台主机的。
upstream downServer {server www.address1.com; # 或者ip+端口 , 不需要加入http/https前缀server www.address2.com down;
}
2.backup
backup是指备份的机器,相对于备份的机器来说,其他的机器就相当于主要服务器,只要当主要服务器不可用的时候,才会用到备用服务器。
upstream backupServer {server www.address1.com; # 或者ip+端口 , 不需要加入http/https前缀server www.address2.com backup;
}
3.max_fails和fail_timeout
默认情况下,max_fails的值为1,表示的是请求失败的次数,请求1次失败就换到下台主机。另外还有一个参数是fail_timeout,表示的是请求失败的超时时间,在设定的时间内没有成功,那作为失败处理。
upstream backupServer {server www.address1.com max_fails=2; # 或者ip+端口 , 不需要加入http/https前缀server www.address2.com backup;
}
proxy_pass参数
- proxy_set_header:设置反向代理向后端发送的http请求头信息,如添加host主机头部字段,让后端服务器能够获取到真实客户端的IP信息等
- client_body_buffer_size:指定客户端请求主体缓冲区大小
- proxy_connect_timeout:反向代理和后端节点连接的超时时间,也是建立握手后等待响应的时间
- proxy_send_timeout:表示代理后端服务器的数据回传时间,在规定时间内后端若数据未传完,nginx会断开连接
- proxy_read_timeout:设置Nginx从代理服务器获取数据的超时时间
- proxy_buffer:设置缓冲区的数量大小
相关文章:
Nginx安装及配置负载均衡
文章目录 官网下载Nginx解压安装常用命令配置负载均衡七层负载均衡nginx的负载均衡语法nginx的负载均衡策略故障下线和备份服务设置proxy_pass参数 官网下载Nginx http://nginx.org/en/download.html 注:下载稳定版,即Stateable Version的,…...
C# OpenCvSharp 通道分离
效果 项目 代码 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using OpenCvSharp; using OpenCvSharp.Extensions;namespac…...
oracle 自定义存储过程(非常简单明了)
语法说明 CREATE OR REPLACE PROCEDURE 存储过程名字 ( 参数1 IN %TYPE, 参数2 IN %TYPE, 参数3 OUT %TYPE) IS 变量1 %TYPE; 变量2 %TYPE; BEGIN存储过程执行语句块 END 存储过程名字;举例说明 1.举一个简单的例子 定义存储过程 easyProcedure 入参为 两个数 出参为 他们的…...
layui--记录
layui 行点击事件:点了没反应? //监听行工具事件layui.table.on(tool(demo), function (obj) {//alert(222) });原因:检查下id与lay-filter是否一致;id与lay-filter必须一致。 <table id"demo" lay-filter"dem…...
【校招VIP】测试技术考点之单元测试集成测试
考点介绍: 单元测试,集成测试的区别是:方式不同、粒度不同、内容不同。单元测试用用于验证编码单元的正确性。集成测试用于验证详细设计。体现了测试由小到大、又内至外、循序渐进的测试过程和分而治之的思想。 测试技术考点之单元测试&集成测试-相…...
【Redis专题】Redis核心数据结构实战与高性能原理解析
目录 前言课程内容一、redis数据类型1.1 字符串(string)类型:比较简单的一种使用存储模型常用命令:(截取自【菜鸟教程】)部分演示应用场景 1.2 哈希(hash)类型:同类数据归…...
常见的几种排序算法
目录 一、插入排序 1、直接插入排序 1.1、排序方法 1.2、图解分析 1.3、代码实现 2、希尔排序 2.1、排序方法 2.2、图解分析 2.3、代码实现 二、选择排序 1、直接选择排序 1.1、排序方法 1.2、图解分析 1.3、代码实现 2、堆排序 2.1、排序方法 2.2、图解分析 …...
动态贴纸、美颜SDK与AR:创造独特的互动体验
目前,动态贴纸、美颜SDK、增强现实(AR)等技术是比较热门的话题,它们所结合的新兴玩法更是收到大家推崇,正潜移默化的改变我们与数字世界互动的方式。 一、动态贴纸:个性化互动的开始 动态贴纸,…...
〔021〕Stable Diffusion 之 提示词反推、自动补全、中文输入 篇
✨ 目录 🎈 反推提示词 / Tagger🎈 反推提示词 Tagger 使用🎈 英文提示词自动补全 / Booru tag🎈 英文提示词自动补全 Booru tag 使用🎈 中文提示词自动补全 / tagcomplete🎈 中文提示词自动补全 tagcomple…...
如何实现响应式布局
要实现响应式布局,您可以采用以下方法: 视口设置: 在HTML的<head>部分中使用meta标签设置视口: <meta name"viewport" content"widthdevice-width, initial-scale1.0">使用百分比: 使…...
HTML <tr> 标签
实例 一个简单的 HTML 表格,包含两行两列: <table border="1"><tr><th>Month</th><th>Savings</th></tr><tr><td>January</td><td>$100</td></tr> </table>定义和用法 &l…...
点云从入门到精通技术详解100篇-点云多尺度分类网络
目录 前言 研究现状与发展趋势 国内外研究现状 点云处理应用研究现状...
电脑怎么设置定时关机,2个简单的操作
电脑作为现代生活中不可或缺的工具,我们通常会在工作或娱乐过程中使用它。但有时候,我们可能需要在一段时间后自动关机,例如在下载完成后或在睡觉前。那么电脑怎么设置定时关机呢?为了满足这种需求,电脑提供了多种定时…...
Uboot指令与烧录
目录 1 NAND Flash: 1)地址空间说明 2)烧写u-boot 3)烧写内核 4)烧写文件系统 5)设置启动参数 2 SPI Flash: 1)地址空间说明 2)烧写u-boot 3)烧写内…...
Visual Studio中使用预编译头文件
预编译头文件(Precompiled Header,PCH)是一种C/C编译优化技术,用于提高大型项目的编译速度。PCH 文件包含了常用的头文件的预编译结果,它可以在编译其他源文件之前被加载到内存中,从而减少了重复的头文件解…...
C语言:选择+编程(每日一练Day15)
目录 选择题: 题一: 题二: 题三: 题四: 题五: 编程题: 题一:寻找奇数 思路一: 题二:寻找峰值 思路一: 本人实力有限可能对一些地方解…...
确定Mac\Linux系统的架构类型是 x86-64(amd64),还是 arm64 架构
我们在下载软件或镜像时会有很多版本,那需要根据我们的系统架构选择正确的软件或镜像版本。 要确定你的系统使用的是 x86-64(amd64) 还是 arm64 架构,可以使用以下方法之一: 使用 uname 命令: 打开终端&am…...
Python脚本
update_format.py 批量转视频格式,超级慢,没什么卵用 import os import asyncio import subprocess import concurrent.futures import tracemalloctracemalloc.start()# 创建日志文件 log_file open(conversion_log.txt, w)async def convert_mkv_t…...
Kotlin的遍历方法
for循环 在下面代码中1…10表示的是1到10,两边都是闭包,输出12345678910 for (i in 1..10) println(i)加上花括号也支持 for (i: Int in 1..10) {println(i)}另外,当对整数进行for循环时,Kotlin还提供了一个step函数来定义迭代的…...
AskIt: Unified Programming Interface for Programming with Large Language Models
本文是LLM系列文章,针对《AskIt: Unified Programming Interface for Programming with Large Language Models》的翻译。 AskIt:用于大型语言模型编程的统一编程接口 摘要1 引言2 动机例子3 设计与实现4 实验评估5 相关工作6 结论 摘要 在不断发展的软…...
ccmusic-database快速部署:Conda环境隔离安装torch+gradio无冲突指南
ccmusic-database快速部署:Conda环境隔离安装torchgradio无冲突指南 1. 项目简介与环境准备 ccmusic-database是一个基于深度学习的音乐流派分类系统,能够自动识别16种不同的音乐风格。这个系统结合了计算机视觉领域的VGG19_BN预训练模型和音频处理技术…...
嵌入式 AI 助手的三层意图识别架构:如何在“快、准、稳“之间取得平衡
背景 我在开发一个项目协同平台的嵌入式 AI 助手。它不是独立的 chatbot,而是嵌在业务页面里的——用户可以在首页、项目详情页、任务抽屉等不同位置唤起它,用自然语言完成任务查询、创建、删除等操作。 和通用对话 AI 不同,这个助手有两个硬…...
从宿主机(Windows)通过 NAT 模式连接虚拟机(Ubuntu)中的 MySQL
宿主机(NAT 模式)连接虚拟机 MySQL 完整记录环境:Windows 宿主机 VMware Workstation(Ubuntu 虚拟机,NAT 网络) 目标:从宿主机通过本地网络连接虚拟机内的 MySQL,并允许 Java 等程序…...
Dify Agent实战:手把手教你用思维链(CoT)模式打造一个能“思考”的AI助手
Dify Agent实战:用思维链(CoT)构建会思考的AI助手 在当今AI技术快速发展的背景下,如何让AI助手不仅能回答问题,还能像人类一样"思考"并解决复杂问题?这正是思维链(Chain of Thought, CoT)技术要解…...
别再死记硬背DH参数表了!用Python从零推导PUMA560机器人正运动学(附完整代码)
用Python实战解析PUMA560机器人运动学:从DH参数到三维可视化 在机器人学领域,正运动学分析是理解机械臂运动原理的基础。许多初学者面对抽象的Denavit-Hartenberg(DH)参数和复杂的坐标系变换时,常常陷入死记硬背的困境…...
Simulink仿真避坑指南:三相异步电机调压调速,你的转速波形为什么震荡不稳?
Simulink三相异步电机调压调速实战:从波形异常到稳定输出的深度调优 当你在Simulink中搭建完三相异步电机调压调速模型,满心期待地点击"运行"按钮,却发现转速波形像过山车一样上下震荡——这种挫败感我深有体会。作为一名经历过无数…...
OpenCV直线检测避坑指南:HoughLinesP参数调优实战(Python版)
OpenCV直线检测避坑指南:HoughLinesP参数调优实战(Python版) 在计算机视觉项目中,直线检测往往是基础却关键的一环。无论是自动驾驶中的车道线识别,还是工业质检中的零件尺寸测量,亦或是文档扫描应用中的表…...
零基础快速入门前端蓝桥杯真题速刷2451.灯的颜色变化(助力保底拿奖不捐款)深入掌握 DOM 选择器与定时器:从交通灯案例到蓝桥杯 Web 考点全解 将原题目扩展成交通灯
2451.灯的颜色变化深入掌握 DOM 选择器与定时器:从交通灯案例到蓝桥杯 Web 考点全解在蓝桥杯 Web 方向竞赛中,DOM 操作与定时器控制是高频考点。本文以一个经典的交通灯控制案例为切入点,全面解析 document.querySelector 的 ID/Class 选择语…...
Roots and the Stars[1]
Roots and the Stars,a english novel. 本故事纯属虚构声明 本故事纯属虚构,如有雷同,纯属巧合。 故事中涉及的所有公司、组织、机构名称,所有人名、地名、事件、产品、技术概念、商业行为、故事情节等均为虚构创作,不指向任何现实…...
Tesseract安装遇阻:Download error与Send Request Error的终极解决方案#附语言包下载
1. 遇到Tesseract安装错误的真实场景 上周帮同事配置OCR开发环境时,又遇到了熟悉的红色错误弹窗:"Download error Status of equ: Send Request Error"。这个报错我见过太多次了——无论是三年前第一次用Tesseract,还是后来在不同公…...
