一、群集的含义:

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

二、存在的问题:

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

三、解决方法:

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

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

1.负载均衡群集
2.高可用群集
3.高性能运算群集
1.1负载均衡群集(Load Balance Cluster)
提高应用系统的响应能力、尽可能处理更多的访问请求、
减少延迟为目标,获得高并发、高负载(LB)的整体性能
LB的负载分配依赖于主节点的分流算法
2.1高可用群集(High Availability Cluster)
提高应用系统的可靠性、尽可能地减少中断时间为目标,确保服务的连续性,达到高可用(HA)的容错效果
HA的工作方式包括双工和主从两种模式
3.1高性能运算群集(High Performance Computer Cluster)
提高应用系统的CPU运算速度、扩展硬件资源和分析能力为目标,获得相当于大型、超级计算机的高性能运算(HPC)能力
高性能依赖于“分布式运算”、“并行计算”,通过专用硬件和软件将多个服务器的CPU、内存等资源整合在一起,实现只有大型、超级计算机才具备的计算能力

五、负载均衡的结构

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

六、负载均衡的网络架构,有三种常见的

1.NAT模式:
地址转换Network Address Translation,简称NAT模式
类似于防火墙的私有网络结构,负载调度器作为所有服务器节点的网关,即作为客户机的访问入口,也是各节点回应客户机的访问出口
服务器节点使用私有IP地址,与负载调度器位于同一个物理网络,安全性要优于其他两种方式

  1. TUN模式:
    IP隧道lPTunnel,简称TUN模式
    采用开放式的网络结构,负载调度器仅作为客户机的访问入口,各节点通过各自的Internet连接直接回应客户机,而不再经过负载调度器
    服务器节点分散在互联网中的不同位置,具有独立的公网IP地址,通过专用IP隧道与负载调度器相互通信
    3.DR模式
    直接路由Direct Routing,简称DR模式
    采用半开放式的网络结构,与TUN模式的结构类似,但各节点并不是分散在各地,而是与调度器位于同一个物理网络
    负载调度器与各节点服务器通过本地网络连接,不需要建立专用的IP隧道

七、关于LVS虚拟服务器

Linux Virtual Server
针对Linux内核的负载均衡解决方案
1998年5月,由我国的章文嵩博士创建
官方网站: http://www.linuxvirtualserver.org/

八、LVS的负载调度算法(4种)

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

九、LVS群集创建与管理办法

1.创建虚拟服务器
2.添加、删除服务器节点
3.查看群集及节点状况
4.保存分配的策略

十、实验设计

  1. 加载ip_vs模块,安装ipvsadm工具
  2. 开启路由转发
  3. 新建LVS虚拟服务器并添加节点服务器
  4. 搭建NFS共享存储服务
    4.1 介绍nfs
    ① Network File System,网络文件系统依赖于RPC(远端过程调用)
    ② 需安装nfs-utils、rpcbind软件包
    ③ 系统服务: nfs、rpcbind
    ④ 共享配置文件:/etc/exports
    4.2 使用NFS发布共享资源
    ① 安装nfs-utils、rpcbind软件包
    ② 设置共享目录
    ③ 启动NFS服务程序
    ④ 查看本机发布的NFS共享目录
    4.3.在客户机中访问NFS共享资源
    ① 安装rpcbind软件包,并启动rpcbind服务
    ② 手动挂载NFS共享目录
    ③ fstab自动挂载设置
  5. 配置节点服务器
    5.1 建立测试网站
    5.2 挂载NFS共享存储
    5.3 建立测试网页
  6. 保存规则并测试

实验环境
一台调速器 ,拥有俩张网卡,一张网卡定义为外网地址,ip地址为:20.0.0.25,NAT模式。还有一张网卡网卡地址为192.168.30.100,选择vm1 仅主机模式
俩台web主机,主机ip分别是:192.168.30.101和192.168.30.102 均是vm1网卡
还有一台存储虚拟机,IP地址为:192.168.30.103

首先在调度服务器上加一块网卡
(注释:添加网卡首先要在虚拟器手动添加一块网络设备器,之前已经讲过很多,这边不在重复,如果还有小伙伴不是太清楚,可以看下小编之前的博客)

[root@localhost ~]# cd /etc/sysconfig/network-scripts/
[root@localhost network-scripts]# nmcli connection    //这是获取网卡信息

pg数据库负载均衡工具_pg数据库负载均衡工具


我们看到网卡ens36箭头指出的UUID的值复制下来

[root@localhost network-scripts]# cp ifcfg-ens33 ifcfg-ens36  //复制ens33的配置文件到ens36里面
[root@localhost network-scripts]# vi ifcfg-ens36    //进入配置文件进行修改
如下图所示,我们要把文件中UUID值删了,把之前赋值的UUID值复制进去,把所有ens33都改成ens36,其次改下ip地址,这张网卡因为是vm1,所有不需要用到网关

pg数据库负载均衡工具_数据库_02

[root@localhost network-scripts]# systemctl restart network
[root@localhost network-scripts]# ping 192.168.30.100    //ping一下自己的ip可以通,那证明没有网络配的没有任何问题

pg数据库负载均衡工具_服务器_03

[root@localhost ~]# modprobe ip_vs               //加载ip_vs 模块
[root@localhost ~]# cat /proc/net/ip_vs            //查看ip_vs 版本信息
1.创建虚拟服务器
[root@localhost network-scripts]# yum -y install ipvsadm  //ipvsadm是在负载调度器上使用的LVS群集管理工具,通过调用ip_vs模块来添加,删除服务器节点
[root@localhost network-scripts]# ipvsadm -v    查看版本信息
[root@localhost network-scripts]# ipvsadm -A -t 20.0.0.25:80 -s rr
注释:-A表示添加虚拟服务器,-t用来指定VIP地址及tcp端口,
-s 用来指定负载调度算法—轮询(rr),加权轮训(wrr),最少连接(lc),加权最少连接
(wlc)
2.添加服务节点
ipvsadm -a -t 20.0.0.25:80 -r 192.168.30.101:80 -m -w
ipvsadm -a -t 20.0.0.25:80 -r 192.168.30.102:80 -m -w
注释:-a表示添加真实服务器,-t用来指定vip地址及tcp端口,-r用来指定RIP
地址及TCP端口,-m表示使用NAT群集模式,-w表示用来设置权重
3.保存LVS策略
ipvsadm-save > /opt/ipvsadm
cat /opt/ipvsadm

pg数据库负载均衡工具_mysql_04

4.开启调度服务器路由转发功能

vi /etc/sysctl.conf
如图所示在文件最下面添加一条ip转发命令

pg数据库负载均衡工具_mysql_05

[root@localhost network-scripts]# sysctl -p 用这条命令检验一下语法格式是否正确

pg数据库负载均衡工具_负载均衡_06

在主机192.168.30.103存储服务器进行配置
[root@localhost ~]# yum-y install nfs-utils
[root@localhost ~]# yum -y install rpcbind
[root@localhost ~]# systemctl start nfs
[root@localhost ~]# systemctl start 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 ~]# vi /etc/exports
添加一下俩条命令,意思是该俩个共享目录允许192.168.30网段读写,及其同步

pg数据库负载均衡工具_pg数据库负载均衡工具_07

[root@localhost ~]# systemctl restart nfs
[root@localhost ~]# systemctl restart rpcbind
[root@localhost ~]# systemctl enable nfs
[root@localhost ~]# systemctl enable rpcbind
[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 ~]# showmount -e   展示信息,如果展示不出来就有问题了

pg数据库负载均衡工具_mysql_08

登录192.168.30.101 web服务器
[root@localhost ~]# yum-y install nfs-utils    必须要装,否则mount不识别nfs格式,最小化安装要装

[root@localhost ~]# showmount -e 192.168.30.103  展示配置文件的信息

pg数据库负载均衡工具_负载均衡_09

做临时挂载,把192.168.30.103主机下/opt/51xit目录里的index.html 挂载到/var/w[root@localhost ~]# yum -y install httpd   安装httpd服务

[root@localhost ~]# mount 192.168.30.103:/opt/51xit /var/www/htmlww/html目录下
[root@localhost ~]# vi /etc/fstab      做永久挂载

pg数据库负载均衡工具_mysql_10

[root@localhost ~]# systemctl restart httpd
[root@localhost ~]# systemctl enable httpd
在登录192.168.30.102 web主机上
[root@localhost ~]# yum-y install nfs-utils    必须要装,否则mount不识别nfs格式,最小化安装要装

[root@localhost ~]# showmount -e 192.168.30.103 
[root@localhost ~]# yum -y install httpd   安装httpd服务

[root@localhost ~]# mount 192.168.30.103:/opt/51xit /var/www/html
[root@localhost ~]# vi /etc/fstab      做永久挂载

pg数据库负载均衡工具_mysql_11

[root@localhost ~]# systemctl restart httpd
[root@localhost ~]# systemctl enable httpd
先在浏览器上输入web服务器的ip地址,看下服务器是否是正常的

pg数据库负载均衡工具_服务器_12


pg数据库负载均衡工具_mysql_13

测试正常之后,再输入外网口ip地址20.0.0.25,测试下是否正常

pg数据库负载均衡工具_mysql_14

轮询是有一个响应时间的,所有我们再次输入ip20.0.0.25时,一定要等待一会,才会跳转到this is www.52xit.top

pg数据库负载均衡工具_服务器_15