Linux中web集群-nginx负载均衡及案例

概述

代理:外卖,中介,中间商,用户无法直接做事情,通过中介进行处理

用户–》代理–》节点,后面只有一个节点,一般使用的是nginx代理功能即可,如果是集群就需要使用nginx负载均衡

代理分类

本质:根据用户位置(定是否那个为正反向代理)

正向代理:用户(服务器)-》代理-》外部(网站)服务器通过代理实现共享上网/某一个网站

反向代理:用户(app/浏览器)-》代理-》网站服务器(WEB) 给网站设置一个统一的入口,可以进行使用负载均衡的功能进行使用

环境概述

代理:web lb01 10.0.0.5/172.16.1.5

web web01 10.0.0.7/172.16.1.7

域名proc.wulinlinux.cn

站点目录:/app/code/proxy/index.html

建议开启db01和nfs01

[root@web01 ~]#vim /etc/nginx/conf.d/proxy.wulinlinux.cn.conf

在这里插入图片描述
检查语法:
在这里插入图片描述
[root@web01 ~]#nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

systemctl reload nginx

[root@web01 ~]#mkdir -p /app/code/proxy/
[root@web01 ~]#echo proxy.wulinlinux.cn >/app/code/proxy/index.html

测试:
在这里插入图片描述

[root@lb01 ~]#vim /etc/nginx/conf.d/proxy.wulinlinux.cn.conf

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
测试负载:
在这里插入图片描述
保存

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

web集群-nginx-负载均衡

案例:部署nginxconf站点并进行访问

lb01 192.168.65.5/172.16.1.5
环境要求 说明
web01 192.168.65.7/172.16.1.7
web02 192.168.65.8/172.16.1.8
域名:conf.wulinlinux.cn
站点目录:/app/code/cfg/

web服务器准备

[root@web01 ~]#vim /etc/nginx/conf.d/cfg.wulinlinux.cn.conf

在这里插入图片描述
创建站点目录:

[root@web01 ~]#mkdir -p /app/code/cfg/

传输部署网站的代码
在这里插入图片描述
解压传输的部署网站代码(解压进行查看是否有嵌套的代码文件目录)
在这里插入图片描述
解压到站点目录

[root@web01 ~]#unzip  star-battle-master.zip -d /app/code/cfg/

把下面所有的东西移动到相对应的站点目录里面
在这里插入图片描述

[root@web01 /app/code/cfg]#nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
[root@web01 /app/code/cfg]#systemctl reload nginx
在这里插入代码片

打开web02发现没有nginx等源

进入web01服务器进行传输到web02服务器上
在这里插入图片描述
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
[root@web01 /etc/nginx/conf.d]#cd /app/
[root@web01 /app]#scp -r /app/ web02:/
ssh: connect to host web02 port 22: Connection timed out
lost connection
[root@web01 /app]#scp -r /app/ 192.168.65.8:/

[root@web02 ~]#systemctl enable nginx
Created symlink from /etc/systemd/system/multi-user.target.wants/nginx.service to /usr/lib/systemd/system/nginx.service.
[root@web02 ~]#systemctl start nginx

在这里插入图片描述
在这里插入图片描述

负载均衡配置

  • load balance(lb)
  • 创建池塘进行分组,存放主机
  • upstream 与server是并列的
  • 名字要进行保持一致
  • upstream创建池塘,proxy_pass将数据传给池塘
[root@lb01 /etc/nginx/conf.d]#cat cfg.wulinlinux.cn 
upstream cfg_pols {
   server 192.168.65.7:80;
   server 192.168.65.8:80;
}
server {
   listen 80;
   server_name cfg.wulinlinux.cn;

   error_blog /var/log/nginx/cfg-error.blog notice;
   access_blog /var/log/nginx/cfg-access.log main;

   location / {
     # proxy_pass http://?????;
      proxy_pass http://cfg_pols;
      proxy_set_header Host $http_host;
      proxy_set_header X-Real-Ip $remote_addr;
      proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
   }
}

在这里插入图片描述
[root@lb01 /etc/nginx/conf.d]#curl -H Host:cfg.wulinlinux.cn http://192.168.65.5/

会发现这里返回的结果是web01与web02服务器交换进行:(负载均衡—平均分配)

总结

  • upstream模块的upstream指令;

  • [root@lb01 /etc/nginx/conf.d]#cat cfg.wulinlinux.cn
    upstream cfg_pols {
    server 192.168.65.7:80;
    server 192.168.65.8:80;
    }
    server {
    listen 80;
    server_name cfg.wulinlinux.cn;

    error_blog /var/log/nginx/cfg-error.blog notice;
    access_blog /var/log/nginx/cfg-access.log main;

    location / {

    proxy_pass http://???;

    ​ proxy_pass http://cfg_pols;
    ​ proxy_set_header Host $http_host;
    ​ proxy_set_header X-Real-Ip $remote_addr;
    ​ proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
    }

  • lnmp深入原理及排查故障

  • 1.代理基础功能把请求通过代理转发到某一台web节点上

  • 2.转发的时候记录真实的ip

  • 3.负载均衡基本使用

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

世界名著精选,免费!精选了数百本世界名著,打包带走!

世界名著精选是一款汇集了全球经典文学作品的电子书阅读软件。是一个旨在让经典文学作品更易于接触和阅读的平台。它不仅收录了世界各地的经典名著,还通过现代技术手段,让阅读变得更加便捷和个性化。 软件链接:免费!几百种资源&a…

【数据结构与算法】图论 详解

何为完全图、稀疏图、稠密图。 完全图:完全图是一种简单的无向图,其中每对不同的顶点之间都恰好有一条边。对于有n个顶点的完全图,它包含n(n-1)/2条边。在有向图中,如果任意两个顶点之间都存在方向相反的两条边,包含n(…

OA流程节点超时功能

在OA系统中,节点超时功能是一个关键的技术特性,它能够确保流程的顺畅进行,避免任务因为个别环节的延误而影响整体进度。本文将探讨OA系统中节点超时功能的技术实现和优化策略。 参考泛微OA ecology E9 前台设置: 系统管理员在管…

2000年 - 2022年 Fama-French三因子模型数据+代码

Fama-French三因子模型是由著名经济学家尤金法玛(Eugene Fama)和肯尼斯法兰奇(Kenneth French)提出的,旨在改进资本资产定价模型(CAPM),更全面地解释资产收益率的变化。该模型认为&a…

pytest测试框架pytest-rerunfailures插件重试失败用例

Pytest提供了丰富的插件来扩展其功能,介绍下插件pytest-rerunfailures ,用于在测试用例失败时自动重新运行这些测试用例。 pytest-rerunfailures官方显示的python和pytest版本限制: Python 3.8pytest 7.2 或更新版本 此插件可以通过以下可…

CentOS 7 内核 3.10 升级 6.5.2 (RPM 直装 + 源码编译)

方案一 直接基于 RPM 在线升级(简单,速度快) rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org yum install https://www.elrepo.org/elrepo-release-7.el7.elrepo.noarch.rpm -y # (选项一)升级最新版内…

【GD32】从零开始学兆易创新32位微处理器——RTC实时时钟+日历例程

1 简介 RTC实时时钟顾名思义作用和墙上挂的时钟差不多,都是用于记录时间和日历,同时也有闹钟的功能。从硬件实现上来说,其实它就是一个特殊的计时器,它内部有一个32位的寄存器用于计时。RTC在低功耗应用中可以说相当重要&#xf…

Linux操作系统段式存储管理、 段页式存储管理

1、段式存储管理 1.1分段 进程的地址空间:按照程序自身的逻辑关系划分为若干个段,每个段都有一个段名(在低级语言中,程序员使用段名来编程),每段从0开始编址。内存分配规则:以段为单位进行分配…

Redis-事务-watch-unwatch

文章目录 1、监视key2、提交事务 1、监视key 打开两个窗口,第一个窗口先监视key,然后开始事务,然后再打开第二个窗口,修改balance为0 2、提交事务 此时事务被打断

分布式定时任务系列10:XXL-job源码分析之路由策略

传送门 分布式定时任务系列1:XXL-job安装 分布式定时任务系列2:XXL-job使用 分布式定时任务系列3:任务执行引擎设计 分布式定时任务系列4:任务执行引擎设计续 分布式定时任务系列5:XXL-job中blockingQueue的应用 …

【深度学习驱动流体力学】计算流体力学算例剖析与实现

目录 一.求解器分类汇总压缩性流动求解器(Compressible Flow Solvers):不可压缩流动求解器(Incompressible Flow Solvers):多相流动求解器(Multiphase Flow Solvers):热传递求解器(Heat Transfer Solvers):其他特殊求解器:其他常见求解器:求解器分类:二.求解器案…

黑马苍穹外卖6 清理redis缓存+Spring Cache+购物车的增删改查

缓存菜品 后端服务都去查询数据库,对数据库访问压力增大。 解决方式:使用redis来缓存菜品,用内存比磁盘性能更高。 key :dish_分类id String key “dish_” categoryId; RestController("userDishController") RequestMapping…

Android Studio 安卓手机上实现火柴人动画(Java源代码—Python)

android:layout_marginLeft“88dp” android:layout_marginTop“244dp” android:text“Python” android:textSize“25sp” app:layout_constraintStart_toStartOf“parent” app:layout_constraintTop_toTopOf“parent” /> </androidx.constraintlayout.widget.…

【尚庭公寓SpringBoot + Vue 项目实战】看房预约管理(十三)

【尚庭公寓SpringBoot Vue 项目实战】看房预约管理&#xff08;十三&#xff09; 文章目录 【尚庭公寓SpringBoot Vue 项目实战】看房预约管理&#xff08;十三&#xff09;1、业务说明2、代码开发2.1、根据条件分页查询预约信息2.2、根据ID更新预约状态 1、业务说明 看房预约…

Vue77-编程式路由

一、需求 不写<router-link>实行路由的跳转。 因为<router-link>的本质是<a>&#xff0c;但是&#xff0c;有时&#xff0c;导航不一定是a标签&#xff01;或者&#xff0c;有时需要等一段时间&#xff0c;页面才跳转。 二、代码实现 三、小结

macbook配置adb环境和用adb操作安卓手机

&#xff08;参考&#xff1a;ADB工具包的安装与使用_adb工具箱-CSDN博客&#xff09; 第一步&#xff1a;从Android开发者网站下载Android SDK&#xff08;软件开发工具包&#xff09;。下载地址为&#xff1a; 第二步&#xff1a;解压下载的SDK压缩文件到某个目录中。 进入解…

ubuntu 18.04 server源码编译安装freeswitch 1.10.11——筑梦之路

前言 这里主要编译支持语音通话、视频通话、短信、webrtc功能的PBX。 安装编译工具包和依赖包 sudo apt-get updatesudo apt-get install -y autoconf git libtool g zlib1g-dev libjpeg-dev libcurl4-openssl-dev libspeex-dev libldns-dev libedit-dev libssl-dev pkg-con…

pywebview打包本地的html

51.安装 pip install pywebview 2.新建start.py import webview import timeclass API:def say_hello(self, name):time.sleep(2) # 模拟一个耗时操作return fHello, {name}!def main():api API()webview.create_window(pywebview Example, index.html, js_apiapi)webview.…

Java 集合框架详谈及代码分析(Iterable->Collection->List、Set->各接口实现类、Map->各接口实现类)

目录 Java 集合框架详谈及代码分析&#xff08;Iterable->Collection->List、Set->各接口实现类、Map->各接口实现类&#xff09;1、集合概述1-1&#xff1a;Java 集合概述1-2&#xff1a;List、Set、Map 三者的区别&#xff1f;1-3&#xff1a;集合框架底层数据结…

卡尔曼滤波-剔除异常值的影响

二郎在看论文的时候&#xff0c;发现了一个针对卡尔曼滤波过程中&#xff0c;测量向量出现误差导致滤波发散的处理方法。 该方法也可以扩展到其他问题中使用&#xff0c;所以二郎在这里写一下。 论文原文&#xff1a;https://www.mdpi.com/1424-8220/20/17/4710 论文翻译对应…