使用lvs實現ftp的負載均衡

来源:http://www.cnblogs.com/MikeZhang/archive/2017/12/02/lvsFtpLoadBlance20170623.html
-Advertisement-
Play Games

操作系統:CentOS6.5_x64 問題描述 使用lvs實現ftp的負載均衡 為了使模型足夠簡單,這裡只實現了loadblance,HA並未實現,可以藉助keepalived實現。 具體實現 hostA : 192.168.1.21 hostB : 192.168.1.22 hostC : 192 ...


操作系統: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)

好,就這些了,希望對你有幫助。

本文github地址:

https://github.com/mike-zhang/mikeBlogEssays/blob/master/2017/20170623_使用lvs實現ftp的負載均衡.rst

歡迎補充


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天在寫代碼的時候,我犯了一個很low的錯誤,廢話不多說,直接上代碼: 大家看到之後,第一反應肯定會認為是個語法錯誤,可是自己仔細想想,這是什麼原因?似乎還不能解釋清楚,好奇寶寶模式立即啟動,經過查閱相關資料得到了答案,接下來我們一起來探討下其中的原理。 疑惑解答 大家有沒有考慮過為什麼上面這種寫法 ...
  • 使用XHR發送一個json請求一般是這樣: 使用fetch的實例: Fetch參數 fetch(input [,init]) input(必須) 定義要獲取的資源(請求地址) init(可選) 參數 | 描述 method 請求使用的方法,如GET、POST headers http請求頭(user ...
  • js導出Excel的方法 利用html的table表格的格式書寫想要的excel格式 獲取table的內容並組裝成一個xls格式的字元串 利用Blob對象生成一個xls格式的文件 利用a標簽的download屬性創建文件名,並下載到本地 例子: "js導出Excel" table表格內容 先寫一個正 ...
  • <form action="" method="get/post"> 表單<form></form>的提交方式有兩種:post,get post 方式 指交互信息 放入到請求體裡面 get 方式 指交互信息 放入到請求頭裡面 區別: 1.發送請求的空間大小不一致: get請求存放的數據不能超過500 ...
  • 首先說一下背景,在雙十一的時候,我們系統接受X寶的訂單推送,同事原先的實現方式是使用redis的List作為推送數據的承載,在非大促的場景下, 一切運行正常,記憶體占用大概3-4G,機器是16G記憶體。由於提前預計不足,在雙十一來臨的時候,訂單瞬時量達到了平時的10X倍,記憶體非常吃緊,情況算 是非常緊急 ...
  • Redis 高可用集群 Redis 的集群主從模型是一種高可用的集群架構。本章主要內容有:高可用集群的搭建,Jedis連接集群,新增集群節點,刪除集群節點,其他配置補充說明。 高可用集群搭建 集群(cluster)技術是一種較新的技術,通過集群技術,可以在付出較低成本的情況下獲得在性能、可靠性、靈活 ...
  • 這兩天在MyEclipse中開發Web項目時,連接MYSQL資料庫,出現問題:Access denied for user 'root'@'localhost' (using password:YES)。 經查找資料發現是root帳戶預設不開放遠程訪問許可權,所以需要修改一下相關許可權。 解決方案: 打 ...
  • elasticsearch,IDEA,Gradle,源碼編譯,本地調測 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...