Nginx编译安装 实现反向代理-负载均衡

编译安装

源码编译安装详细步骤此处不在赘述,一般步骤为:

  1. 确保系统安装了编译工具,如gcc、make。及一些库文件,如PCRE、openSSL。
  2. 下载nginx源代码。
  3. 配置编译选择,运行 ./configure 指定安装路径以及需要的模块和选项。
  4. 编译
  5. 安装

反向代理

使用 Nginx 作为反向代理是将客户端请求转发给一个或多个后端服务器的过程。反向代理隐藏了后端服务器的实际地址和细节,使得客户端无法直接访问后端服务器。nginx在做反向代理服务器的前提下,可以使用负载均衡来缓解单个服务器的压力,避免宕机的情况。

nginx反向代理的写法 在nginx.conf文件中 http中的server下 ,使用location。

下面的配置就是反向代理 ,只要我们访问http://a 就会指向http://192.168.84.135/a

访问http://t 则会指向http://192.168.84.135/

复制代码
http {

    include       mime.types;

    default_type  application/octet-stream;



    server {

    listen       443 ssl;

    server_name  localhost;

        

    location /a {
        
        #将请求转到了 192.168.84.135 ,80端口,是一个vms中的apache服务 
         proxy_pass http://192.168.84.135:80;

        }
    location /t {
        
        #将请求转到了 192.168.84.135 ,81端口,是一个vms中的tomcat服务 
         proxy_pass http://192.168.84.135:81;

        }

}

负载均衡

写负载均衡,使用upstream,还是在nginx.conf文件中的http下,与serve平级

复制代码
http {

    include       mime.types;

    default_type  application/octet-stream;

    upstream loadbalancing{
              #访问load balancing的请求会被随机分配到下面的服务器的IP  weight表权重
           sever  192.168.84.135:80   weight= 1;
           server 192.168.84.135:81   weight= ;     
        }

    server {

    listen       443 ssl;

    server_name  localhost;

        

    location /a {
        
        #将请求转到了 192.168.84.135 ,80端口,是一个vms中的apache服务 
         
    proxy_pass http://loadbalancing;

        }
 

}

常见的负载均衡算法

补充一下nginx常用的一些负载均衡的算法

  1. 轮询(Round Robin):

    • 这是最简单的算法,将请求依次分配给每个后端服务器,循环进行。每个请求都会被发送到下一个服务器,直到所有服务器都收到了相同数量的请求。
  2. IP Hash:

    • 根据客户端的 IP 地址计算一个 hash 值,然后使用该值来确定将请求发送到哪个后端服务器。这确保了相同的客户端 IP 总是被分配到同一台后端服务器,有助于维护会话状态。
  3. Least Connections:

    • 请求将被发送到当前连接数最少的服务器。这有助于避免将请求发送到负载较高的服务器,以确保更平均地分配负载。
  4. 权重轮询(Weighted Round Robin):

    • 每个服务器被分配一个权重值,根据权重来决定分配请求的频率。具有更高权重的服务器将收到更多的请求,实现更灵活的负载均衡。
  5. 权重最小连接数(Weighted Least Connections):

    • 类似于Least Connections,但是每个服务器的连接数会乘以一个权重值,从而影响负载均衡的决策。
  6. 基于响应时间的负载均衡:

    • 根据后端服务器的响应时间动态地调整权重,以确保响应时间较短的服务器获得更多的请求。
相关推荐
好好学操作系统6 分钟前
autodl 保存 数据 跨区
linux·运维·服务器
dbitc8 分钟前
WIN11把WSL2移动安装目录
linux·运维·ubuntu·wsl
KingRumn8 分钟前
Linux同步机制之信号量
linux·服务器·网络
嵌入式学习菌9 分钟前
SPIFFS文件系统
服务器·物联网
旺仔Sec9 分钟前
2026年度河北省职业院校技能竞赛“Web技术”(高职组)赛项竞赛任务
运维·服务器·前端
BullSmall30 分钟前
linux 根据端口查看进程
linux·运维·服务器
herinspace34 分钟前
管家婆软件年结存后快马商城操作注意事项
服务器·数据库·windows
weixin_462446231 小时前
Kali/ubuntu Linux 中彻底删除 Cursor 编辑器(含 dpkg 非空目录警告解决)
linux·ubuntu·cursor
Hard but lovely1 小时前
linux:----进程守护化(Daemon)&&会话的原理
linux·运维·服务器
芝麻馅汤圆儿1 小时前
sockperf 工具
linux·服务器·数据库