加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 服务器 > 搭建环境 > Linux > 正文

如何使用lvs构建fpt的负载均衡服务器?

发布时间:2023-07-13 15:41:58 所属栏目:Linux 来源:
导读:在这篇文章中,我们来学习一下“如何使用lvs搭建fpt的负载均衡服务器?”的相关知识,下文有详细的讲解,易于大家学习和理解,有需要的朋友可以借鉴参考,下面就请大家跟着小编的思路一起来学习一下吧。
在这篇文章中,我们来学习一下“如何使用lvs搭建fpt的负载均衡服务器?”的相关知识,下文有详细的讲解,易于大家学习和理解,有需要的朋友可以借鉴参考,下面就请大家跟着小编的思路一起来学习一下吧。
 
操作系统:CentOS6.5_x64
 
问题描述
 
使用lvs实现ftp的负载均衡
 
为了使模型足够简单,这里只实现了loadblance,HA并未实现,可以借助keepalived实现。

具体实现
 
hostA : 192.168.1.21
 
hostB : 192.168.1.22
 
hostC : 192.168.1.23
 
虚拟ip地址: 192.168.1.20
 
hostA为负载均衡器
 
hostB和hostC为ftp服务器
 
转发模式:DR
 
调度算法:rr

hostA配置
 
安装ipvsadm:
 
yum install ipvsadm -y
 
从源码安装:

yum install -y gcc gcc-c++ make pcre pcre-devel kernel-devel openssl-devel
 
yum install libnl* popt*
 
wget http://www.linuxvirtualserver.org/software/kernel-2.6/ipvsadm-1.26.tar.gz
 
tar zxvf ipvsadm-1.26.tar.gz
 
cd ipvsadm-1.26
 
make && make install
 
开启ip转发功能:
 
 
vim /etc/sysctl.conf
 
net.ipv4.ip_forward = 1
 
sysctl -p
 
关闭防火墙:
 
/etc/init.d/iptables stop
 
配置ipvs(start.sh) :
 
 
#! /bin/sh
 
# DR Mode
 
ipvsadm -C
 
ipvsadm -A -t 192.168.1.20:21 -s rr -p
 
ipvsadm -a -t 192.168.1.20:21 -r 192.168.1.22:21 -g
 
ipvsadm -a -t 192.168.1.20:21 -r 192.168.1.23:21 -g
 
ipvsadm save
 
ipvsadm -ln
 
ifconfig eth0:0 192.168.1.20 netmask 255.255.255.0
 
hostB配置
 
 
 
配置虚拟ip:
 
[root@host22 test]# cat /etc/init.d/realserver.sh
 
#!/bin/bash
 
SNS_VIP=192.168.1.20
 
. /etc/rc.d/init.d/functions
 
case "$1" in
 
start)
 
 ifconfig lo:0 $SNS_VIP netmask 255.255.255.255 broadcast $SNS_VIP
 
 /sbin/route add -host $SNS_VIP dev lo:0
 
 echo "1" >/proc/sys/net/ipv4/conf/lo/arp_ignore
 
 echo "2" >/proc/sys/net/ipv4/conf/lo/arp_announce
 
 echo "1" >/proc/sys/net/ipv4/conf/all/arp_ignore
 
 echo "2" >/proc/sys/net/ipv4/conf/all/arp_announce
 
 sysctl -p >/dev/null 2>&1
 
 echo "RealServer Start OK"
 
 ;;
 
stop)
 
 ifconfig lo:0 down
 
 route del $SNS_VIP >/dev/null 2>&1
 
 echo "0" >/proc/sys/net/ipv4/conf/lo/arp_ignore
 
 echo "0" >/proc/sys/net/ipv4/conf/lo/arp_announce
 
 echo "0" >/proc/sys/net/ipv4/conf/all/arp_ignore
 
 echo "0" >/proc/sys/net/ipv4/conf/all/arp_announce
 
 echo "RealServer Stoped"
 
 ;;
 
 *)
 
 echo "Usage: $0 {start|stop}"
 
 exit 1
 
esac
 
exit 0
 
[root@host22 test]# sh /etc/init.d/realserver.sh start
 
SIOCADDRT: File exists
 
RealServer Start OK
 
开启ftp服务
 
安装vsftpd :
 
yum install vsftpd
 
修改配置:
 
为了方便开启匿名用户操作ftp的各种权限。
 
 
chmod a+w /var/ftp/pub/ # 开启文件夹写权限
 
vim /etc/vsftpd/vsftpd.conf
 
anon_upload_enable=YES
 
anon_mkdir_write_enable=YES
 
anon_other_write_enable=YES # 开启匿名用户删除功能
 
配置selinux:
 
getsebool -a | grep ftp
 
setsebool -P allow_ftpd_anon_write 1
 
setsebool -P allow_ftpd_full_access 1
 
启动ftp:
 
/etc/init.d/vsftpd start
 
配置开机启动:
 
chkconfig vsftpd on
 
关闭防火墙:
 
/etc/init.d/iptables stop
 
chkconfig iptables off
 
hostC配置
 
配置同hostB
 
 
 
讨论
 
这里只是用lvs实现了ftp负载均衡的模型,其它具体问题请参考lvs相关文档。
 
这里附上测试脚本,ftp写文件脚本:
 
 
#! /usr/bin/env python
 
#-*- coding:utf-8 -*-
 
import ftplib,os,time
 
ftp = ftplib.FTP("192.168.1.20")
 
ftp.login()
 
ftp.cwd("/pub")
 
i = 0
 
while True :
 
    filename = "ftptest1_%d.txt" % i
 
    print filename
 
    i += 1
 
    with open(filename,"w") as fout :
 
        fout.write(str(time.time()))
 
    myfile = open(filename, 'r')
 
    try :
 
        ftp.storlines('STOR ' + filename, myfile)
 
    except :
 
        ftp.login()
 
        ftp.cwd("/pub")
 
    myfile.close()
 
    os.remove(filename)
 
    time.sleep(10)
 
好,就这些了,希望对你有帮助。
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!