當前位置:首頁 » 編程軟體 » iproute2編譯

iproute2編譯

發布時間: 2024-10-04 03:38:29

❶ 什麼是ECMPECMP的實現原理是什麼

linux 平台上之 Multipath Routing 應用

--------------------------------------------------------------------------------
撰稿/整理: Rex Tsai <[email protected]>

HTML 版本:
http://kalug.linux.org.tw/sections.php?op=viewarticle&artid=4

TEXT 版本:
[Tips] Linux 平台上之 Multipath Routing 應用.

$Date: 2001/10/22 09:25:41 $

警告:
*****************************************************************************

您因使用或不能使用本文之教學而產生之任何軟體、硬體損害(包括但不限
於直接或間接個人損害、營業利潤之喪失、業務中斷、營業資訊之遺失、或
任何其他金錢損失),概不負任何損害賠償責任。

The author has taken care in the preparation of this paper, but
make no expressed or implied warranty of any kind and assume no
responsibility for errors or omissions. No liability is assumed for
incidental or consequential damages in connection with or arising
out of the use of the information or programs contained herein.

Linux is a registered trademark of Linus Torvalds. Other proct
and company names mentioned herein may be the trademarks of their
respective owners.
*****************************************************************************

撰稿/整理: Rex Tsai <[email protected]>
此文件應有許多技術上得問題. 請熟悉的朋友來信指教.

[Introction]

許多中小企業或是 Soho 甚至家庭, 會在家中裝有一條以上寬頻/寬頻線路.
這篇 Tips 將介紹如何在 Linux 上, 好好的應用這些資源.

在你使用兩家不同的 ISP 的時候, destination address-based load
balancing 將會是最好的解決方案. 你的封包可以即時透過不同的 ISP 線路
走出去. 當然這里所提的是從內部到外部, 如果你的專線提供不同的網路服
務提供給網路上得人存取, 那麼接下來所說明的方式不適合您.
此篇文章只能提供內部網路對外的 load sharing.

以下文章以 GNU/Debian, Linux kernel 2.4.12, iproute-20001007-1 為
環境, 所有動作請在主機前面執行.

假設你有兩條以上的網際網路數據線路 (xDSL, ISDN, Cable, whatever..),
想充分使用這些線路, 概觀來看有三種方式

1. Multiplexing
2. Packet-wise load balancing
3. Destination address-based load balancing,
或稱 Equal-Cost MultiPath Routing (ECMP)

稍微解釋一下三種方式的不同

1. Multiplexing

Multiplexing, 這個方式提供某些路由器提供 offer-load balancing 或叫
做 load sharing. 這個方式可以讓路由器將流量分給不同的外流 ports.
但是會造成每個 port 的傳送上約有 30 % 的 overhead. 此外, 每家廠商的
實作都是獨一的, 因次你會被鎖在特定的解決方案上.

類似的技術是 "bonding" 或是 "multi-link". 這里所提得 Bonding 是一
個標准, 是由 Bandwidth on Demand Interoperability Group (一個大
概有四十個製造商的協會)所提. 已經提交給 American National Standards
Institute TR41.4 group. 這個通常的在於兩條數據線路都是接在同一個
點(ISP)上的時候, 因此如果是兩條不同 ISP 所提供的線路, 那麼就沒辦法
達到這個目的. 當然, 如果你的 ISP 不提供此項技術服務, 那麼也是沒轍.
舉個例子, 像是 stick multiple ISDN channels. 將幾個慢速的線路合成為
快速的一條. 像是 ISDN H.221 規格即用到 inverse multiplexing. 但通常
用於視訊傳輸而不是電子資料.

2. Packet-wise load balancing:

這個在你可以得到所有的 ISP 協助的時候是可行的, 如果兩家 ISP 都願意
協助將其不同的路由器皆設定到同一個 IP 位址. 那麼便可以這麼作.

在這個方式中, 你會用到像是 sch_teql (the TEQL scheler) 來創造一個
virtual device 將你的封包分散在不同的網路介面上.

一般來講, 如果你是使用兩家不同 ISP , 那麼你不可以使用這個解決方案.
但, 你 "可以" 將所有的網路封包透過 IPIP or CIPE (Crypto IP Encapsu-
lation) 的方式來解決這個問題. 看看 Linux Kernel 中的 IP: tunneling.

3. Equal-Cost MultiPath:

在 Linux 核心中叫做 equal cost multipath (CONFIG_IP_ROUTE_MULTIPATH)
比較正確的說法應該是 "destination address-based load balancing". 一
般 Linux 想要為某個 IP 位址找到路由, 會因為效能的問題去查驗暫存(cache)
中的資料, 如果目標 IP 並沒有在暫存空間中, 那麼他便會去查 routing table
來決定該 IP 位址的路由, 並將該路由放進 cache 中.

一般來講核心中的路由功能只能為某個封包決定唯一的方向. 如果使用 ECMP 並
有機會讓某個 package pattern 具有好幾種不同的方向, 可以讓某個符合路由條
件的封包透過 "equal" cost 或是自訂的權重來選擇該走的路由.

[Howto]

如果你有數台電腦想使用外部網路, 一條 ADSL 不夠你使用(例如某人抓檔太凶)
那麼這是你正在找的解決方案. 你所能做的作好的方式就是每個 connection 可以
以 "non-deterministic fashion" 的方式選擇路由, 將 connection 分散到不同的
Router 上, 注意: 這里所說的不是 packets, 這樣 TCP/IP session 將無法連續.

但是這整個路由程序有兩個部份四個問題要解決.

1a. How to get your packets to the outside world,

1b. How the outside world replies to you,

2a. How the outside world sends packets to you,

2b. How you reply to the outside world.

Multipath 可以解決 1a 出去的問題. 一般的路由設定可以解決 1b 與 2a. 而 2b
則必須使用 policy routing (multiple tables)才能解決, Multiple Tables 可以
讓你加入以封包來源位址為依據來決定路由.

以下的範例, 在核心中, 務必加入編譯以下選項

必備:

CONFIG_NETLINK=y
這個選項是 Kernel/User netlink socket

CONFIG_RTNETLINK=y
Routing messages

CONFIG_INET=y
TCP/IP networking

CONFIG_IP_ADVANCED_ROUTER=y
IP: advanced router

CONFIG_IP_MULTIPLE_TABLES=y
IP: policy routing

CONFIG_IP_ROUTE_MULTIPATH=y
IP: equal cost multipath

選用:

CONFIG_IP_ROUTE_LARGE_TABLES=y
一般來講 IP: large routing tables 也會勾選, 一方面 routing
zones 可以大於 64 筆, 這些資料存在 hash 資料結構中, 也可以
加速 "the routing process".

而 iproute 套件也是必須的軟體. 這個軟體的安裝方式與位置請洽詢提供
您所使用套件之廠商/組織. (Red Hat, Debian, Mandrake, SuSE, etc...)

重頭戲來了, 這里假設你有三塊網路卡, 分別給內部網路與兩家 ISP. eth0
是內部網路, eth1 與 eth2 是其他兩家 ISP 線路.

eth0 是內部網路, 范圍是 10.0.0.0/255.255.255.0

eth1 其中一家 ISP, IP 是 1.1.1.1, 閘道器(gateway)是 1.1.1.253

eth2 另外一家 ISP, IP 是 2.2.2.2, 閘道器(gateway)是 2.2.2.253

# 列出所有的 rule
ip rule list

# table 後的 "10" 是 table identifer, 為數字.
# 注: 可用英文代稱取代請看 /etc/iproute2/rt_tables
#
# table 10 是給在 gateway 後面的內部網路使用, 10.0.0.x 是 LAN 使用的 IP.
#
# pref 後面指定的 "10" 是 priority. 為 policy routing database 搜尋的次序

ip rule add pref 10 to 10.0.0.0/24 table 10
ip route add 10.0.0.0/24 table 10 dev eth1

# table 20 給 ISP #1, IP 1.1.1.1, gateway 1.1.1.253
# pref 後面指定的 "20" 是 priority. 為 policy routing database 搜尋的次序
ip rule add pref 20 from 1.1.1.1 table 20
ip route add default table 20 via 1.1.1.253

# table 30 is for ISP #2, IP 2.2.2.2, gateway 2.2.2.253
ip rule add pref 20 from 2.2.2.2 table 30
ip route add default table 30 via 2.2.2.253

# 列出所有的 rule
ip rule list
# 列出 table 10 的 rule
ip route list table 10
# 列出 table 20 的 rule
ip route list table 20

# If your ISP's have servers that authenticate by originating IP address,
# (e.g. SMTP or NNTP servers) you will want to explicitly list them here.

# 這里是靜態的 routing table 設定. 如果你的 ISP 有提供某些網路服務, 必須該
# ISP 的 IP 才能使用, 那麼你會想將它設定在這里
# (e.g. Proxy, SMTP or NNTP Server)
ip route add 1.1.1.0/24 dev eth1
ip route add 2.2.2.0/24 dev eth2

# 如果上面所有的 routing table 都沒有吻合, 那麼封包會走 default route
# 這里使用 "ECMP" 來選擇上游路由器.

# "ip route repleace" 是用來取代原本的 default routi.
ip route replace default nexthop via 1.1.1.253 dev eth1 \
nexthop via 2.2.253 dev eth2

# 如果你想加上權重, 是這樣使用的. 請依據你的線路網路頻寬
# 頻寬越大, 請把 weight 加大.
#ip route replace default nexthop via 1.1.1.253 dev eth1 weight 1 \
# nexthop via 2.2.253 dev eth2 weight 3

# Make it all happen. IMPORTANT! The above commands do NOT
# flush the route cache!
ip route flush cache
<-- 結束 -->

Linux 上得 ECMP implementation 的實作有一個特色, 當你的上游網路介面
使用 ARP (e.g. 使用傳統 IP-over-Ethernet)時, 如果其中一個網路介面陣
亡時, Linux kernel 會自動把該介面 "shutdown", 並停止那些需要經過該
介面的 "nexthops". 但是要附註一提的是, 如果你使用的是 "網路型" ADSL
服務, 你會取得一個 ADSL 路由器, 你可能會架設一個 NAT 伺服器與 ADSL
路由器放在同一個 Ethernet Hub 上, 如果這個時候 ADSL 斷線, 但是 Hub
並未斷線, Linux 會認為該網路卡仍在 on-line 狀態. 除非是該 hub 或是網
路卡故障, kernel 才會 shutdown 該網路介面.

因此如果你需要確實的 "failover", 請動手寫一個小 script, 定時用 ping
或稱 "icmp echo request" 來詢問 ISP 端的閘道器是否正常的運作, 並用
"ip route replace" 來置換那些確定可通的路由. 這里就請您自行處理了.

Enjoy it, Rex.

[Reference]
[1] Linux-Net mailing list. http://www.uwsg.iu.e/hypermail/linux/net/
原文 http://www.uwsg.iu.e/hypermail/linux/net/0107.3/0028.html

[2] Alexey N. Kuznetsov, April 14, 1999, IP Command Reference

[Futrher reading]
[1] Jack Coates , Load-Balancing on LRP HOWTO

[2] Netherlabs BV (bert hubert ),
Gregory Maxwell ,
Remco van Mook ,
Martijn van Oosterhout ,
Paul B Schroeder ,
Jasper Spaans , [email protected],
Linux 2.4 Advanced Routing Howto

[3] Horacio J. Pe?a, [email protected], 05/Apr/2000
Policy based routing MICRO-HOWTO,
http://www.compendium.com.ar/policy-routing.txt

[Keywords]
Linux, Routeing, 路由, ADSL, 寬頻, 寬頻, 頻寬, 合並, 分流, 共用

[Acknowledgements]
Zygo Blaxell ([email protected]) 在 Linux-net 的說明
Digital Sesame, Inc - http://www.d11e.com 提供環境測試.

--
Best Regards.
Rex Tsai <chihchun_at_kalug.linux.org.tw>
--

❷ 電信華為光貓Hg8245C破解過程中出現WAP(Dopra Linux)#後面輸什麼

很簡單,這個嵌入式系統是華為官方定製的。有沒有這個命令無非就看/bin目錄下有沒有相應的可執行程序。按照上圖看,很明顯你的光貓沒有grep命令。你可以ls一下bin目錄就知道這個光貓支持哪些命令。其他人回答基本抄別人。。也是很尷尬。。這是我光貓的可執行程序如下。如果牛逼的話,可以掛在U盤,編譯對應的可執行程序跑。沒問題的。這個命令不可以,你完全可以找個替代的。騷微變通一下下就好了
WAP(Dopra Linux) # ls bin/
Bbspcmd httpc
Broadband hush
ConvertLog2Dst hw_ldsp_cfg
Customize hw_ldsp_xpon_adpt
Equip.sh hw_restore_manufactory.sh
EquipMode.sh id
LdspCmd.sh igmp
LdspCmdA.sh ip
OntMaintain.sh ipaddr
Wifi2GSsidSet.sh ipcrm
Wifi5GSsidSet.sh ipcs
WifiChipInit2G5G.sh iplink
WifiRXInit.sh iproute
WifiRxTestModeSet2G.sh iprule
WifiRxTestModeSet5G.sh iptables-xml
WifiSsidSet.sh iptunnel
WifiTXInit.sh iwconfig
WifiTxTestModeSet2G.sh iwpriv
WifiTxTestModeSet5G.sh jbpara.sh
[ kill
[[ killall
addgroup killall.sh
adser killall5
aescrypt2 kmsgread
aging ldspcli
amp ln
ampcmd logger
ampcmdClrEmacStat.sh login
ampcmdClrLog.sh ls
ampcmdDebugOff.sh lsusb
ampcmdDebugOn.sh lzop
ampcmdSelfTest.sh lzopcat
ampcmdSetEmacDbg.sh maintain
ampcmdShowCarAll.sh md
ampcmdShowCarIndex.sh mid
ampcmdShowDopeFlow.sh mkdir
ampcmdShowEmacCfg.sh mknod
ampcmdShowEmacStat.sh mktemp
ampcmdShowEthStatAll.sh more
ampcmdShowEthStatIndex.sh mount
ampcmdShowEthStatsCfgAll.sh mu
ampcmdShowFlowAll.sh mv
ampcmdShowFlowIndex.sh mw
ampcmdShowGemStatAll.sh netstat
ampcmdShowGemStatIndex.sh nmbd
ampcmdShowGemStatsCfgAll.sh ntfs-3g
ampcmdShowLog.sh oam
ampcmdShowQueAll.sh oamcmd
ampcmdShowQueIndex.sh oamcmdPdtClrLog.sh
ampcmdTrace.sh oamcmdPdtShowLog.sh
ampcmdTraceAll.sh omci
ampcmdTraceCli.sh omcicmd
ampcmdTraceDpoe.sh omcicmdPdtClrLog.sh
ampcmdTraceDrv.sh omcicmdPdtShowLog.sh
ampcmdTraceEmac.sh

❸ 編譯移植busybox出錯,arm-linux-gcc版本4.3.3 busybox版本1.16.0 錯誤代碼如下:

找不到鏈接庫,不這些都是數學庫,加參數 -lm 應該就能解決。
但編譯過程這個東西應該是自己加。

busybox 一般都是靜態的,編譯靜態程序,很多時候需要他以來的函數庫也是靜態的。你這個問題應該是編譯環境不匹配。你編譯了 uclibc 並且正確安裝了沒?

不過話說,不過是個編譯,人家本來就支持 arm ,「移植」這兩個字應該是不需要用了。

❹ 運維工程師必須掌握的基礎技能有哪些

運維工程師必須掌握的基礎技能有:基礎命令、基礎服務、自動化技能、安全。

1、基礎命令:

這個基礎就包括:用戶管理命令,文件管理命令,許可權管理命令,軟體包管理命令,vim命令,網路管理命令等。這些命令好學,因為每個命令都有相應的help幫助文檔,而且很多網站都集成了命令幫助,把這些站點進行收藏,時不時的查下就記住了。

2、基礎服務:

企業常用的基礎服務就包括DHCP,NTP,DNS,Nginx,Apache,Mysql,Redis,Vsftpd,Nfs。基礎服務的掌握,相比命令稍微的難一點,但是同樣有很多技巧。比如可以去各大視頻站獲取優質的免費視頻學習。

3、自動化技能:

這個自動化就包括腳本自動化,需要熟悉掌握shell腳本或者Python腳本;包括監控自動化,不能靠傳統的點擊頁面,查看進程來判斷服務是否在線,需要熟悉掌握zabbix,Prometheus等主流監控軟體;還包括工具自動化,需要掌握向ansible,puppet,Jenkins等自動化軟體,實現服務的批量部署與業務的自動化。

4、安全:

作為運維工程師,首先就要時刻保障公司業務系統,伺服器安全穩定運行。所以安全至關重要,主流的iptables,firewalld防火牆技術要熟練掌握,有必要的話常見的挖礦病毒,ddos等攻擊有段也要有所了解。

運維工程師(Operations),負責維護並確保整個服務的高可用性,同時不斷優化系統架構提升部署效率、優化資源利用率提高整體的ROI。

運維工程師面對的最大挑戰是大規模集群的管理問題,如何管理好幾十萬台伺服器上的服務,同時保障服務的高可用性,是運維工程師面臨的最大挑戰。

❺ 構建一個Linux最小系統,能從U盤啟動Linux,把Linux原碼編譯後放入U盤,並可從U盤啟

你下載一個linux的發行版的iso文件,如ubuntu.
再在你的windows電腦上安裝utlraiso,版本必須9.12及以上。
1、 運行UltraISO

2、 在主菜單選「文件」-〉「打開」,出現「打開ISO文件對話框」

3、 選擇鏡像文件(ubuntu-8.04-desktop-i386.iso)點擊「打開」按鈕

4、 在主菜單選「啟動光碟」-〉「寫入硬碟映像」,出現「寫入硬碟映像」對話框

5、 出現上面界面的時候,在「硬碟驅動器」選項里,要選擇U盤的盤符,在「寫入方式」里,選擇USB-HDD+或USB-ZIP+模式,並點擊「便捷啟動」按鈕——寫入新的硬碟主引導記錄——USB-HDD+或USB-ZIP+。

6、 再點擊寫入,開始ISO文件寫入到U盤。

7、 製作完成後拔出U盤

8、 設置電腦啟動為usb-hdd或usb-zip啟動即可。
另外,站長團上有產品團購,便宜有保證

熱點內容
u盤加密啟動電腦 發布:2024-11-24 13:30:44 瀏覽:905
宣片腳本詞 發布:2024-11-24 13:30:33 瀏覽:493
pythonforif一行 發布:2024-11-24 13:28:19 瀏覽:393
伺服器集群怎麼實現 發布:2024-11-24 13:26:51 瀏覽:598
秒評源碼 發布:2024-11-24 13:24:30 瀏覽:125
聯想筆記本e450c怎麼看配置 發布:2024-11-24 13:22:23 瀏覽:86
c語言如何運行程序 發布:2024-11-24 13:20:03 瀏覽:448
訪問oracle其他用戶 發布:2024-11-24 13:18:32 瀏覽:68
年青人的游戲密碼一般是什麼 發布:2024-11-24 13:17:01 瀏覽:785
培訓室密碼是多少 發布:2024-11-24 13:16:21 瀏覽:76