LVS群集应用

  • 企业群集应用概述
  • 企业群集分类
  • 关于LVS虚拟服务器
  • 案例:LVS-NAT部署实战
  • 附加:


企业群集应用概述

群集的含义

  • Cluster,集群、群集
  • 由多台主机构成,但对外只表现为一个整体

面临问题

  • 互联网应用中,随着站点对硬件性能、响应速度、服务稳定性、数据可靠性等要求越来越高,单台服务器力不从心。

解决方法

  • 使用价格昂贵的小型机、大型机
  • 使用普通服务器构建服务群集

企业群集分类

根据群集所针对的目标差异,可分为三种类型

  • 负载均衡群集
  • 高可用群集
  • 高性能运算群集

负载均衡群集(Load Balance Cluster)

  • 提高应用系统的响应能力、尽可能处理更多的访问请求、减少延迟为目标,获得高并发、高负载(LB)的整体性能
  • LB的负载分配依赖于主节点的分流算法

高可用群集(High Availability Cluster)

  • 提高应用系统的可靠性、尽可能地减少中断时间为目标,确保服务的连续性,达到高可用(HA)的容错效果。
  • HA的工作方式包括双工和主从两种模式

高性能运算群集(High Performance Computer Cluster)

  • 提高应用系统的CPU运算速度、扩展硬件资源和分析能力为目标,获得相当于大型、超级计算机的高性能运算(HPC)能力。
  • 高性能依赖于“分布式运算”、“并行计算”,通过专用硬件和软件将多个服务器的CPU、内存等资源整合在一起,实现只有大型、超级计算机才具备的计算能力。

负载均衡的结构

  • 第一层,负载调度器(Load Balancer或Director)
  • 第二层,服务器池(Server Pool)
  • 第三层,共享存储(Share Storage)

群集的负载调度技术有三种工作模式

  • 地址转换
  • IP隧道
  • 直接路由

关于LVS虚拟服务器

LVS的负载调度算法

  • 轮询轮询 (Round Robin)
  • 将收到的访问请求按照顺序轮流分配给群集中的各节点(真实服务器),均等地对待每一台服务器,而不管服务器实际的连接数和系统负载。
  • 加权轮询 (Weighted Round Robin)
  • 根据调度器设置的权重值来分发请求,权重值高的节点优先获得任务,分配的请求数越多。
  • 保证性能强的服务器承担更多的访问流量。
  • 最少连接 (Least Connections)
  • 根据真实服务器已建立的连接数进行分配,将收到的访问请求优先分配给连接数最少的节点。
  • 加权最少连接 (Weighted Least Connections)
  • 在服务器节点的性能差异较大时,可以为真实服务器自动调整权重。
  • 性能较高的节点将承担更大比例的活动连接负载。

案例:LVS-NAT部署实战

环境

  • LVS调度器作为Web服务器池的网关,LVS两块网卡,分别连接内外网,使用轮询 (rr) 调度算法。

IP地址规划

名称

IP

网关

调度器

对外公网:20.0.0.21 (NAT)

/

调度器

私有网络:192.168.100.21 (VM1)

/

WE1

私有网络:192.168.100.22(VM1)

192.168.100.21

WE2

私有网络:192.168.100.23 (VM1 )

192.168.100.21

存储服务器

192.168.100.24(VM1)

192.168.100.21(可配可不配)

真机

20.0.0.1(VM8)

20.0.0.21

调度器配置 (192.168.100.21)

[root@localhost ~]# yum -y install ipvsadm
[root@localhost ~]# modprobe ip_vs 				##加载ip_vs模块
[root@localhost ~]# cat /proc/net/ip_vs 				##查看ip_vs模块是否加载成功

[root@localhost ~]# ipvsadm -A -t 20.0.0.21:80 -s rr 			##创建虚拟服务器
[root@localhost ~]# ipvsadm -a -t 20.0.0.21:80 -r 192.168.100.22:80 -m		##添加服务器节点
[root@localhost ~]# ipvsadm -a -t 20.0.0.21:80 -r 192.168.100.23:80 -m
[root@localhost ~]# ipvsadm -ln				##查看节点状态

[root@localhost ~]# ipvsadm-save > /opt/ipvsadm			##保存负载分配策略
[root@localhost ~]# cat /opt/ipvsadm					##确认保存结果

[root@localhost ~]# vi /etc/sysctl.conf 				##开启调度服务器路由转发功能
net.ipv4.ip_forward = 1
[root@localhost ~]# sysctl -p 						##让内核参数立即生效

存储服务器配置(192.168.100.24)

[root@localhost ~]# rpm -q nfs-utils   ##最小化安装需要yum -y install nfs-utils
[root@localhost ~]# rpm -q rpcbind     ##最小化安装需要yum -y install rpcbind
[root@localhost ~]# systemctl enable nfs
[root@localhost ~]# systemctl enable rpcbind

[root@localhost ~]# mkdir /opt/51xit /opt/52xit    ##创建两个目录
[root@localhost ~]# echo "this is www.51xit.top" >/opt/51xit/index.html
[root@localhost ~]# echo "this is www.52xit.top" >/opt/52xit/index.html

[root@localhost opt]# vi /etc/exports      ##配置NFS服务器的相关信息
/opt/51xit 192.168.100.0/24(rw,sync)
/opt/52xit 192.168.100.0/24(rw,sync)

[root@localhost opt]# systemctl restart nfs rpcbind    ##重启
[root@localhost opt]# systemctl enable nfs rpcbind    ##开机自启


[root@localhost opt]# showmount -e     ##查询NFS服务器的相关信息(仅显示被客户挂载的目录名)
Export list for localhost.localdomain:
/opt/52xit 192.168.100.0/24
/opt/51xit 192.168.100.0/24

WE1配置(192.168.100.22)

[root@localhost ~]# showmount -e 192.168.100.24
Export list for 192.168.100.24:
/opt/52xit 192.168.100.0/24
/opt/51xit 192.168.100.0/24

[root@localhost ~]# yum -y install httpd
[root@localhost ~]# systemctl start httpd
[root@localhost ~]# systemctl enable httpd

[root@localhost ~]# mount 192.168.100.24:/opt/51xit /var/www/html/			##临时挂载
[root@localhost ~]# vi /etc/fstab 				##永久挂载
192.168.100.24:/opt/51xit /var/www/html nfs defaults,_netdev 0 0 
[root@localhost ~]# init 6				##最好重启检测下

###登录192.168.100.22测试网站是否正常####

WE2配置 (192.168.100.23)

[root@localhost ~]# showmount -e 192.168.100.24
Export list for 192.168.100.24:
/opt/52xit 192.168.100.0/24
/opt/51xit 192.168.100.0/24

[root@localhost ~]# yum -y install httpd
[root@localhost ~]# systemctl start httpd
[root@localhost ~]# systemctl enable httpd

[root@localhost ~]# mount 192.168.100.24:/opt/52xit /var/www/html/  		 ##临时挂载
[root@localhost ~]# vi /etc/fstab      	  ##永久挂载
192.168.100.24:/opt/52xit /var/www/html nfs defaults,_netdev 0 0 
[root@localhost ~]# init 6      	  ##重启测试

###登录192.168.100.23测试网站是否正常####

附加:

添加一个新网卡(ens37):

[root@localhost ~]# cd /etc/sysconfig/network-scripts/
[root@localhost network-scripts]# cp ifcfg-ens33 ifcfg-ens37			#复制ens33到ens37

[root@localhost ~]# nmcli connection  		##查看UUID信息

[root@localhost ~]# route -n   ##查看路由条目 把地址以数字的形式显示

注释:
每一个UUID只能一个网卡使用!!

【可能遇到的问题】

[root@localhost ~]# showmount -e 192.168.100.24
clnt_create: RPC: Port mapper failure - Unable to receive: errno 113 (No route to host)
[root@localhost ~]# showmount -e
Export list for localhost.localdomain:

【解决方案】

(1)检查防火墙和核心防护

[root@localhost ~]# systemctl status firewalld
[root@localhost ~]# systemctl stop firewalld
[root@localhost ~]# setenforce 0

(2)检查共享列表有没有设置

[root@localhost ~]# cat /etc/exports
/opt/51xit 192.168.100.0/24(rw,sync)
/opt/52xit 192.168.100.0/24(rw,sync)
[root@localhost ~]# systemctl restart nfs
[root@localhost ~]# systemctl restart rpcbind
[root@localhost ~]# systemctl enable nfs
[root@localhost ~]# systemctl enable rpcbind