Linux環(huán)境使用TC進行服務器流量控制方法
公司目前有一臺服務器,網(wǎng)絡環(huán)境太高,那臺服務器和源服務器連接下載,就跑到400M-500M,為了控制一下,所以研究了一下TC,來做流量控制。給他控制到小點,不要讓這一臺占了所有的網(wǎng)絡。TC很強大,很多所謂的硬件路由器,都是基于這個做的。
一、Linux下使用TC進行服務器流量控制方法
1)假設eth0位是服務器的外網(wǎng)網(wǎng)絡接口,首先在eth0的qdiscA,qdiscA控制通過本機到外網(wǎng)的速度,因此可用來控制服務器對外數(shù)據(jù)傳輸速度。
#tc qdisc add dev eth1 root handle 1:htb default 1
添加 設置接口 最上層 句柄(做標記用) 標記 默認使用1的class
解釋如下:無論是隊列,還是class和filter都有ID之類的標志符,一般都有parent(父,上層的),注意ID具有接口本地性,不同的網(wǎng)絡接口可以有相同的ID.對于這里因為qdisc在頂部,所以parent無,用‘root’字樣來標識,ID用1:來標志
‘default 91′表示當某個ip流不滿足任何已設定的filter規(guī)則時,將自動歸入class 1中。更詳細的指令規(guī)則說明請參考手冊。
2)然后在qdisc下建立兩個class,來指定eth0控制通過本機到外網(wǎng)的速度
#tc class add dev eth0 parent 1:0 classid1:30 htb rate 2mbit ceil 4mbit prio 2
注:以上就是我們控制輸出服務器的速度,為2M,最大可以到4M
rate: 是一個類保證得到的帶寬值。如果有不只一個類,請保證所有子類總和是小于或等于父類。
prio:用來指示借用帶寬時的競爭力,prio越小,優(yōu)先級越高,競爭力越強。
ceil: ceil是一個類最大能得到的帶寬值。
3)接著針對不同的應用在各root class下設置不同的類,示例如下。(如果只有一個類,這個就沒有必要了)
#tc class add dev eth0 parent 1:30 classid 1:31 htbrate 0.5mbit ceil 2mbit prio 3
同時為了不使一個會話永占帶寬,在節(jié)點(即本文的各應用結點)添加隨即公平隊列sfq.(多IP)
#tc qdisc add dev eth0 parent 1:31 handle 31:sfq perturb 10
4)接著添加過濾器。
#tc filter add dev eth0 parent 1: protocol ipprio 31 handle 31 fw flowid 1:31
5)用iptable打標,也可以使用u32之類
#iptables -t mangle -I FORWARD -i !eth1 -p tcp –sport 80 -s xxx.xxx.xxx.xxx –j MARK –set-mark 31
二、TC對最對高速度的控制 | Rate ceiling 速率限度
參數(shù)ceil指定了一個類可以用的最大帶寬, 用來限制類可以借用多少帶寬。缺省的ceil是和速率一樣,這個特性對于ISP是很有用的, 因為他們一般限制被服務的用戶的總量即使其他用戶沒有請求服務。(ISPS 很想用戶付更多的錢得到更好的服務) ,注根類是不允許被借用的, 所以沒有指定ceil。
(注: ceil的數(shù)值應該至少和它所在的類的速率一樣高, 也就是說ceil應該至少和它的任何一個子類一樣高。)
Burst 突發(fā)
網(wǎng)絡硬件只能在一個時間發(fā)送一個包這僅僅取決于一個硬件的速率。 鏈路共享軟件可以利用這個能力動態(tài)產(chǎn)生多個連接運行在不同的速度。所以速率和ceil不是一個即時度量只是一個在一個時間里發(fā)送包的平均值。實際的情況是怎樣使一個流量很小的類在某個時間類以最大的速率提供給其他類。 burst 和cburst 參數(shù)控制多少數(shù)據(jù)可以以硬件最大的速度不費力的發(fā)送給需要的其他類。
如果cburst 小于一個理論上的數(shù)據(jù)包他形成的突發(fā)不會超過ceil 速率, 同樣的方法TBF的最高速率也是這樣。
你可能會問, 為什么需要bursts . 因為它可以很容易的提高向應速度在一個很擁擠的鏈路上。 比如WWW 流量是突發(fā)的。 你訪問主頁。 突發(fā)的獲得并閱讀。 在空閑的時間burst將再”charge”一次。
(注: burst 和cburst至少要和其子類的值一樣大。)
三、TC命令格式:
加入
tc qdisc [ add | change | replace | link ] dev DEV [ parent qdisc-id | root ] [ handle qdisc-id ] qdisc [ qdisc specific parameters ]
tc class [ add | change | replace ] dev DEV parent qdisc-id [ classid class-id ] qdisc [ qdisc specific parameters ]
tc filter [ add | change | replace ] dev DEV [ parent qdisc-id | root ] protocol protocol prio priority filtertype [ filtertype specific parameters ] flowid flow-id
顯示
tc [-s | -d ] qdisc show [ dev DEV ]
tc [-s | -d ] class show dev DEV tc filter show dev DEV
查看TC的狀態(tài)
tc -s -d qdisc show dev eth0
tc -s -d class show dev eth0
刪除tc規(guī)則
tc qdisc del dev eth0 root
實例
一、下載
下載限制單個IP
tc qdisc add dev eth0 root handle 1: htb r2q 1
tc class add dev eth0 parent 1: classid 1:1 htb rate 30mbit ceil 60mbit
tc filter add dev eth0 parent 1: protocol ip prio 16 u32 match ip dst 192.168.1.2 flowid 1:1
就可以限制192.168.1.2的下載速度為30Mbit最高可以60Mbit
r2q,是指沒有default的root,使整個網(wǎng)絡的帶寬沒有限制
下載整段IP
tc qdisc add dev eth0 root handle 1: htb r2q 1
tc class add dev eth0 parent 1: classid 1:1 htb rate 50mbit ceil 1000mbit
tc filter add dev eth0 parent 1: protocol ip prio 16 u32 match ip dst 192.168.111.0/24 flowid 1:1
就可以限制192.168.111.0 到255 的帶寬為3000k了,實際下載速度為200k左右。
這種情況下,這個網(wǎng)段所有機器共享這200k的帶寬。
還可以加入一個sfq(隨機公平隊列)
tc qdisc add dev eth0 root handle 1: htb r2q 1
tc class add dev eth0 parent 1: classid 1:1 htb rate 3000kbit burst 10k
tc qdisc add dev eth0 parent 1:1 handle 10: sfq perturb 10
tc filter add dev eth0 parent 1: protocol ip prio 16 u32 match ip dst 192.168.111.168 flowid 1:1
sfq,他可以防止一個段內的一個ip占用整個帶寬。
TC簡介
在Linux中,TC有二種控制方法CBQ和HTB.HTB是設計用來替換CBQ的。它是一個層次式的過濾框架。TC包括三個基本的構成塊: 隊列規(guī)定qdisc(queueing discipline )、類(class)和分類器(Classifiers)。
隊列(queueing discipline):用來實現(xiàn)控制網(wǎng)絡的收發(fā)速度。通過隊列,Linux可以將網(wǎng)絡數(shù)據(jù)包緩存起來,然后根據(jù)用戶的設置,在盡量不中斷連接(如 TCP)的前提下來平滑網(wǎng)絡流量。需要注意的是,linux對接收隊列的控制不夠好,所以我們一般只用發(fā)送隊列,即“控發(fā)不控收”。它封裝了其他兩個主要 TC組件(類和分類器)。內核如果需要通過某個網(wǎng)絡接口發(fā)送數(shù)據(jù)包,它都需要按照為這個接口配置的qdisc(排隊規(guī)則)把數(shù)據(jù)包加入隊列。然后,內核會 盡可能多地從qdisc里面取出數(shù)據(jù)包,把它們交給網(wǎng)絡適配器驅動模塊。
最簡單的QDisc是pfifo它不對進入的數(shù)據(jù)包做任何的處理,數(shù)據(jù)包采用先入先出的方式通過隊列。不過,它會保存網(wǎng)絡接口一時無法處理的數(shù)據(jù)包。
隊列規(guī)則包括FIFO(先進先出),RED(隨機早期探測),SFQ(隨機公平隊列)和令牌桶(Token Bucket),類基隊列(CBQ),CBQ 是一種超級隊列,即它能夠包含其它隊列(甚至其它CBQ)。
class用來表示控制策略。很顯然,很多時候,我們很可能要對不同的IP實行不同的流量控制策略,這時候我們就得用不同的class來表示不同的控制策略了。
filter用來將用戶劃入到具體的控制策略中(即不同的class中)。比如,現(xiàn)在,我們想對xxa,xxb兩個IP實行不同的控制策略 (A,B),這時,我們可用filter將xxa劃入到控制策略A,將xxb劃入到控制策略B,filter劃分的標志位可用u32打標功能或 IPtables的 set-mark(大多使用iptables來做標記)功能來實現(xiàn)。
目前,TC可以使用的過濾器有:fwmark分類器,u32分類器,基于路由的分類器和RSVP分類器(分別用于IPV6、IPV4)等;其 中,fwmark分類器允許我們使用 Linux netfilter 代碼選擇流量,而u32分類器允許我們選擇基于 ANY 頭的流量 .需要注意的是,filter(過濾器)是在QDisc內部,它們不能作為主體。
數(shù)據(jù)包->iptables(在通過iptables時,iptables根據(jù)不同的ip來設置不同的mark)->TC(class)->TC(queue)。
關鍵詞:Linux,服務器
閱讀本文后您有什么感想? 已有 人給出評價!
- 1
- 1
- 1
- 1
- 1
- 1