downmovies 发表于 2019-1-3 10:31:33

CentOS7上部署LVS负载均衡群集之LVS

CentOS7中的LVS负载均衡群集之LVS-NAT(地址转换模式)

简介
  在当今各种互联网应用中,随着站点对硬件性能、响应速度、服务稳定性、数据可靠性等的要求越来越高,单台服务器将难以承担所有的访问。除了使用价格昂贵的大型机、专用负载分流设备以外,企业还有另外一种选择来解决难题,就是构建集群服务器——通过整合多台相对廉价的普通服务器,以同一个地址对外提供相同的服务。
  负载均衡群集:以提高应用系统的响应能力、尽可能处理更多的访问请求、减少延迟为目标,获得高并发、高负载的整体性能。

实验介绍
  环境
  四台CentOS7虚拟机:
  其中CentOS7-1作为调度服务器,需配置双网卡
  IP地址: 192.168.234.1(内网)12.0.0.1(外网)
  CentOS7-2、CentOS7-3作为web服务器(即节点服务器)
  CentOS7-2 IP地址:192.168.234.177
  CentOS7-3 IP地址:192.168.234.175
  CentOS7-4作为提供共享存储功能的服务器
  IP地址:192.168.234.176
  配置


[*]配置提供共享存储的服务器(CentOS7-4)

# systemctl start nfs.service    //开启网络文件共享服务
# systemctl start rpcbind.service//开启服务与对应端口绑定功能
注:rpcbind就是将不同服务与对应的端口进行绑定,以便支持机器间的互操作。
# vim /etc/exports
/usr/share *(ro,sync)
/opt/zyc 192.168.234.0/24(rw,sync)
/opt/hwj 192.168.234.0/24(rw,sync)
添加用来共享的文件夹,并且注明是允许192.168.234.0这个网段的用户能读取、写入,并且进行同步

  创建被共享的文件夹,并且给予满权限

# mkdir /opt/zyc
# mkdir /opt/hwj
# chmod 777 /opt/zyc /opt/hwj
# ls -l /opt
总用量 0
drwxrwxrwx. 2 root root 6 6月20 15:28 hwj
drwxr-xr-x. 2 root root 6 3月26 2015 rh
drwxrwxrwx. 2 root root 6 6月20 15:28 zyc
  发布共享

# exportfs -rv
exporting 192.168.234.0/24:/opt/hwj
exporting 192.168.234.0/24:/opt/zyc
exporting *:/usr/share

[*]部署web服务器
  用CentOS7-3扫描共享文件并且进行挂载

# showmount -e 192.168.234.176   //扫描共享出来的网络文件夹
Export list for 192.168.234.176:
/usr/share *
/opt/hwj   192.168.234.0/24
/opt/zyc   192.168.234.0/24
# mount.nfs 192.168.234.176:/opt/zyc /var/www/html/          //将共享出的文件挂载至本地的站点目录
  写入一个首页在站点目录下

# echo "this is zyc web" >index.html   
# ls
index.html
  并且这里写入的首页内容是写入在创建共享的服务器上的(即CentOS7-4),我们可以在CentOS7-4上查看到

# cd zyc/
# ls
index.html
  注:另一台web服务器(即CentOS7-2)同上部署,挂载/opt/hwj即可
  部署好之后,可以使用本地的火狐浏览器自测一下,检测是否可以进行访问
http://i2.运维网.com/images/blog/201806/23/4049b1ce94c521bbbcdc2630f18339b6.png
http://i2.运维网.com/images/blog/201806/23/d7e8c604dcc4d2cfae56b63414e50a68.png


[*]部署调度服务器(CentOS7-1)
  配置双网卡如图
http://i2.运维网.com/images/blog/201806/23/ebd45da2a26a5e455438567e42e6f171.png
  安装调度工具

  # yum install ipvsadm -y

  开启路由转发功能

# vim /etc/sysctl.conf
....   //省略
net.ipv4.ip_forward = 1    //末行添加
# sysctl -p
net.ipv4.ip_forward = 1

  做SNAT转换

# iptables -t nat -A POSTROUTING -s 192.168.234.0/24 -o ens36 -j SNAT --to-source 12.0.0.1

  此时先验证下看SNAT地址转换是否配置成功,使用web服务器ping外网的服务器
http://i2.运维网.com/images/blog/201806/23/3698175106c6406452793c3847b64cfe.png
  然后配置负载均衡策略

# modprobe ip_vs
# cat /proc/net/ip_vs
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
-> RemoteAddress:Port Forward Weight ActiveConn InActConn
# ipvsadm --save > /etc/sysconfig/ipvsadm
# systemctl start ipvsadm.service

  这里使用一个脚本来进行配置

vim nat.sh
#!/bin/bash
ipvsadm -C   
ipvsadm -A -t 12.0.0.1:80 -s rr
ipvsadm -a -t 12.0.0.1:80 -r 192.168.234.177:80 -m
ipvsadm -a -t 12.0.0.1:80 -r 192.168.234.175:80 -m
ipvsadm
# source nat.sh

  然后负载均衡的所有配置就完成了,接下来使用win7来访问
http://i2.运维网.com/images/blog/201806/23/550b17c26aac7160b4bc83e15b610ca6.png
  然后使用CentOS7-1的本地进行访问
http://i2.运维网.com/images/blog/201806/23/614d4e5d5e96f7e84a4f5da5e5d41261.png
  就会看到调度服务器根据相同的IP地址不同的访问节点提供的不同的网页信息了



页: [1]
查看完整版本: CentOS7上部署LVS负载均衡群集之LVS