NGINX七层负载均衡配置方案

NGINX

一、准备

  • 准备5台CentOS7服务器,IP地址如下:
    • HAproxy 192.168.152.71
    • web1 192.168.152.72
    • web2 192.168.152.73
    • php1 192.168.152.74
    • php2 192.168.152.75

二、配置NGINX服务器

1. 下载NGINX

bash 复制代码
yum install -y nginx

2. 编写配置文件

bash 复制代码
vim /etc/nginx/nginx.conf

编写内容如下:

  • 在 http 块中

    bash 复制代码
    # 定义处理 .html 文件的上游服务器组
    upstream htmlservers {
        # 权重 1 (可选,默认 1),失败 2 次后标记为不可用(可选,默认 1),故障检测时间为 10 秒(可选,默认 10 秒)
        server 192.168.152.72:80 weight=1 max_fails=2 fail_timeout=2;
    
        # 权重 2 (可选,默认 1),失败 2 次后标记为不可用(可选,默认 1),故障检测时间为 10 秒(可选,默认 10 秒)
        server 192.168.152.73:80 weight=2 max_fails=2 fail_timeout=2;
    }
    
    # 定义处理 .php 文件的上游服务器组
    upstream phpservers {
        # 权重 1 (可选,默认 1),失败 2 次后标记为不可用(可选,默认 1),故障检测时间为 10 秒(可选,默认 10 秒)
        server 192.168.152.74:80 weight=1 max_fails=2 fail_timeout=2;
    
        # 权重 2 (可选,默认 1),失败 2 次后标记为不可用(可选,默认 1),故障检测时间为 10 秒(可选,默认 10 秒)
        server 192.168.152.75:80 weight=2 max_fails=2 fail_timeout=2;
    }
  • 在server块中

    bash 复制代码
    # 匹配所有请求,默认请求,没有定义的请求全部走这个服务器
    location / {
    	proxy_pass http://htmlservers;
    }
    
    # 对所有以 .html 结尾的请求进行处理
    location ~* \.html$ {
        # 将请求转发到 htmlservers 服务器组
        proxy_pass http://htmlservers;
    }
        
    # 对所有以 .php 结尾的请求进行处理
    location ~* \.php$ {
        # 将请求转发到 phpservers 服务器组
        proxy_pass http://phpservers;
    }
  • 关于权重 weight

    • 权重相同时采用 轮询算法:请求会按顺序依次分配到服务器组中的每台服务器。
    • 权重不同时采用 加权轮询算法:根据各个服务器的权重值来分配请求。权重越高的服务器会处理更多的请求。

3. 启动NGINX服务

bash 复制代码
systemctl start nginx && systemctl enable nginx

三、配置后端服务

①配置web服务器

测试用简单配置,web1 和 web2 都要配置

  1. 安装http服务

    bash 复制代码
    yum install -y httpd
  2. 编写主页
    web1:

    bash 复制代码
    echo web1 > /var/www/html/index.html

    web2:

    bash 复制代码
    echo web2 > /var/www/html/index.html
  3. 启动http服务

    bash 复制代码
    systemctl start httpd && systemctl enable httpd

②配置php服务器

测试用简单配置,php1 和 php2 都要配置

  1. 安装 php 和 http 服务

    bash 复制代码
    yum install -y httpd php
  2. 编写主页
    php1:

    bash 复制代码
    echo php1 > /var/www/html/index.php

    php2:

    bash 复制代码
    echo php2 > /var/www/html/index.php
  3. 启动服务

    bash 复制代码
    systemctl start httpd && systemctl enable httpd

四、测试

多次刷新,查看结果,前两个的结果为 web1,web2;最后一个结果为 php1,php2。

如果配置没有问题,但多次刷新无果,可能是浏览器缓存,可以用命令 elinks

下载 yum insdall -y elinks

bash 复制代码
elinks --dump http://192.168.152.71
elinks --dump http://192.168.152.71/index.html
elinks --dump http://192.168.152.71/index.php
相关推荐
Waay21 分钟前
面试口述版:个人对 Prometheus 完整理解
运维·学习·云原生·面试·职场和发展·kubernetes·prometheus
三84443 分钟前
文件查找/文件压缩/解压缩
linux·运维·服务器
小猪写代码1 小时前
Linux 管道(Pipeline)作业
linux·运维·服务器
桌面运维家1 小时前
如何用半缓存云桌面将服务器硬盘容量扩展至本地终端?
运维·服务器·缓存
Jurio.1 小时前
Codex App SSH 远程开发教程:本地连接远程服务器项目
服务器·ssh·远程工作·codex
激情的学姐1 小时前
【大型网站技术实践】初级篇:借助Nginx搭建反向代理服务器
运维·nginx
ai_coder_ai2 小时前
编写自动化脚本,在自己后端服务中使用Open Api进行设备相关操作
java·运维·自动化
会周易的程序员3 小时前
microLog 的本地日志读取接口 log_reader — 本地日志文件读取工具开发指南
linux·物联网·架构·嵌入式·日志·iot·aiot
spider_xcxc3 小时前
Redis 数据库高质量实践指南(一)
运维·数据库·redis·oracle·云计算
我是一颗柠檬3 小时前
【Java项目技术亮点】加权轮询负载均衡算法
java·算法·负载均衡