當前位置:首頁 » 操作系統 » 網橋的自學習演算法

網橋的自學習演算法

發布時間: 2022-07-28 22:27:54

㈠ 透明網橋的逆向學習法

透明網橋採用的演算法是逆向學習法(backward learning)。網橋按混雜的方式工作,故它能看見所連接的任一LAN上傳送的幀。查看源地址即可知道在哪個LAN上可訪問哪台機器,於是在散列表中添上一項。
當計算機和網橋加電、斷電或遷移時,網路的拓撲結構會隨之改變。為了處理動態拓撲問題,每當增加散列表項時,均在該項中註明幀的到達時間。每當目的地已在表中的幀到達時,將以當前時間更新該項。這樣,從表中每項的時間即可知道該機器最後幀到來的時間。網橋中有一個進程定期地掃描散列表,清除時間早於當前時間若干分鍾的全部表項。於是,如果從LAN上取下一台計算機,並在別處重新連到LAN上的話,那麼在幾分鍾內,它即可重新開始正常工作而無須人工干預。這個演算法同時也意味著,如果機器在幾分鍾內無動作,那麼發給它的幀將不得不散發,一直到它自己發送出一幀為止。
到達幀的路由選擇過程取決於發送的LAN(源LAN)和目的地所在的LAN(目的LAN),如下所示:
1、如果源LAN和目的LAN相同,則丟棄該幀。
2、如果源LAN和目的LAN不同,則轉發該幀。
3、如果目的LAN未知,則進行擴散。
為了提高可靠性,有人在LAN之間設置了並行的兩個或多個網橋,但是,這種配置引起了另外一些問題,因為在拓撲結構中產生了迴路,可能引發無限循環。

㈡ 什麼叫網橋有什麼作用

網橋(Bridge)是早期的兩埠二層網路設備,用來連接不同網段。網橋的兩個埠分別有一條獨立的交換信道,不是共享一條背板匯流排,可隔離沖突域。網橋比集線器(Hub)性能更好,集線器上各埠都是共享同一條背板匯流排的。

作用:

1、能擴展網路的距離或范圍,而且可提高網路的性能、可靠性和安全性。

2、網橋納入存儲和轉發功能可使其適應於連接使用不同MAC 協議的兩個LAN,因而構成一個不同LAN 混連在一起的混合網路環境。

3、使用網橋進行互連克服了物理限制,這意味著構成LAN 的數據站總數和網段數很容易擴充。

4、網橋的中繼功能僅僅依賴於MAC 幀的地址,因而對高層協議完全透明。

(2)網橋的自學習演算法擴展閱讀:

網橋的缺點:

1、由於網橋對接收的幀要先存儲和查找站表,然後轉發,這就增加了時延。

2、在MAC子層並沒有流量控制功能。當網路上負荷很重時,可能因網橋緩沖區的存儲空間不夠而發生溢出,以致產生幀丟失的現象。

3、具有不同MAC子層的網段橋接在一起時,網橋在轉發一個幀之前,必須修改幀的某些欄位的內容,以適合另一個MAC子層的要求,增加時延。

4、網橋只適合於用戶數不太多(不超過幾百個)和信息量不太大的區域網,否則有時會產生較大的廣播風暴。

網橋的基本特徵:

1、網橋在數據鏈路層上實現區域網互連;

2、網橋能夠互連兩個採用不同數據鏈路層協議、不同傳輸介質與不同傳輸速率的網路

3、網橋以接收、存儲、地址過濾與轉發的方式實現互連的網路之間的通信;

4、網橋需要互連的網路在數據鏈路層以上採用相同的協議

5、網橋可以分隔兩個網路之間的通信量,有利於改善互連網路的性能與安全性。

㈢ 簡述交換機自學習演算法

自學習演算法??
你說的是地址學習嘛???
就是交換機的各個埠獲取與之相連設備的MAC地址,形成MAC地址表。這個就是交換機的地址學習。

㈣ 舉例說明網橋的自學習演算法.求幫助

#include<stdio.h>
void main()
{
char arr1[3]={'A','B','C'};
char arr2[2]={'D','E'};
char arr3[3]={'F','G','H'};
int a[][2]={0,0,0,0,0,0,0,0,0,0,0,0};
int b[][2]={0,0,0,0,0,0,0,0,0,0,0,0};
int i,j,m,n,k1 = 0,k2 = 0,t;
char s,d,k;

while(1)
{
printf("請輸入源地址和目的地址:");
scanf("%c%c",&s,&d);
printf("\n");
for(i=0;i<3;i++){
if(arr1[i]==s)
m=1;
}
for(i=0;i<2;i++){
if(arr2[i]==s)
m=2;
}
for(i=0;i<3;i++){
if(arr3[i]==s)
m=3;
}
switch(m)
{
case 1:
{
for(i=0;i<k1;i++){
if(a[i][0]==s)
{break;}
}
if(i==k1) {a[k1][0]=s;a[k1][1]=m;k1++;}//沒有記錄,在網橋數組中插入源地址

for(i=0;i<k1;i++)//查找網橋數組中是否有目的地址
{
if(a[i][0]==d)
{
n=a[i][1]; break;
}
}

if(i==k1) printf("網橋1中沒有目的記錄%c,向右轉發\n",d);//不含有,轉發
else
{
if(m==n){
printf("網橋1丟棄\n");t=1;
}//含有且在同在網段丟棄
else
printf("不在同一網段,網橋1向右轉發\n");//含有不在同一網段轉發
}

if(t!=1) //不在同一網段時
{
for(i=0;i<k1;i++)
if(b[i][0]==s) {break;}
if(i==k1) {b[k2][0]=s;b[k2][1]=m;k2++;}//沒有記錄,在網橋數組中插入源地址
for(i=0;i<k1;i++)//查找網橋數組中是否有目的地址
{if(b[i][0]==d) {n=b[i][1]; break;}}
if(i==k2) printf("網橋2中沒有目的記錄%c,向右轉發\n",d);//不含有,轉發
else
{
if(m==n) printf("網橋2丟棄\n");//含有且在同在網段丟棄
else printf("不在同一網段,網橋2向右轉發\n");//含有不在同一網段轉發
}
}
break;
}
case 2:
{
//向左轉發
for(i=0;i<k1;i++)
if(a[i][0]==s) {break;}
if(i==k1) {a[k1][0]=s;a[k1][1]=m;k1++;}//沒有記錄,在網橋數組中插入源地址

for(i=0;i<k1;i++)//查找網橋數組中是否有目的地址
{if(a[i][0]==d) {n=a[i][1]; break;}}

if(i==k1) printf("網橋1中沒有目的記錄%c,向左轉發\n",d);//不含有,轉發
else
{
if(m==n) printf("網橋1丟棄\n");//含有且在同在網段丟棄
else printf("不在同一網段,網橋1向左轉發\n");//含有不在同一網段轉發
}
//向右轉發
for(i=0;i<k2;i++)
if(b[i][0]==s) {break;}
if(i==k2) {b[k2][0]=s;b[k2][1]=m-1;k2++;}//沒有記錄,在網橋數組中插入源地址

for(i=0;i<k2;i++)//查找網橋數組中是否有目的地址
{if(b[i][0]==d) {n=b[i][1]; break;}}
if(i==k2) printf("網橋2中沒有目的記錄%c,向右轉發\n",d);//不含有,轉發
else
{
if(1==n) printf("網橋2丟棄\n");//含有且在同在網段丟棄
else printf("不在同一網段,網橋2向右轉發\n");//含有不在同一網段轉發
}
break;
}
case 3:
{
for(i=0;i<k2;i++)
if(b[i][0]==s) {break;}
if(i==k2) {b[k2][0]=s;b[k2][1]=m-1;k2++;}//沒有記錄,在網橋數組中插入源地址
for(i=0;i<k2;i++)//查找網橋數組中是否有目的地址
{if(b[i][0]==d) {n=b[i][1]; break;}}
if(i==k2) printf("網橋2中沒有目的記錄,向左轉發\n");//不含有,轉發
else
{
if(2==n) {printf("網橋2丟棄\n");t=1;}//含有且在同在網段丟棄
else printf("不在同一網段,網橋2向左轉發\n");//含有不在同一網段轉發
}

if(t!=1)//不在同一網段時
{

for(i=0;i<k1;i++)
if(a[i][0]==s) {break;}
if(i==k1) {a[k1][0]=s;a[k1][1]=m-1;k1++;}//木有記錄,在網橋數組中插入源地址
for(i=0;i<k1;i++)//查找網橋數組中是否有目的地址
{if(a[i][0]==d) {n=a[i][1]; break;}}
if(i==k1) printf("網橋1中沒有目的記錄%c,向左轉發\n",d);//不含有,轉發
else
{
if(2==n) printf("網橋1丟棄\n");//含有且在同在網段丟棄
else printf("不在同一網段,網橋1向左轉發\n");//含有不在同一網段轉發
}
}
break;

}
default: ;
}

putchar('\n');
printf("網橋1\n");
printf("--------\n");
for(i=0;i<k1;i++)
{printf(" %c ",a[i][0]);
printf("%d ",a[i][1]);
putchar('\n');
}
printf("--------\n");
printf("網橋2\n");
printf("--------\n");
for(i=0;i<k2;i++)
{printf(" %c ",b[i][0]);
printf("%d ",b[i][1]);
putchar('\n');
}
printf("-------\n");
scanf("%c",&k);

㈤ 當交換機或網橋進行「自學習」時,使用幀頭的哪個欄位做出轉發決定的時候又是使用幀頭的哪個欄位

自學習是根據數據幀的源mac地址,轉發的時候是根據目的mac地址查找cam表來轉發數據的,希望能幫助你。

㈥ 簡述網橋的工作原理

網橋工作在數據鏈路層,將兩個LAN連起來,根據MAC地址來轉發幀,可以看作一個「低層的路由器」(路由器工作在網路層,根據網路地址如IP地址進行轉發)。

遠程網橋通過一個通常較慢的鏈路(如電話線)連接兩個遠程LAN,對本地網橋而言,性能比較重要,而對遠程網橋而言,在長距離上可正常運行是更重要的。

網橋與路由器的比較

網橋並不了解其轉發幀中高層協議的信息,這使它可以同時以同種凡是處理IP、IPX等協議,它還提供了將無路由協議的網路(如NetBEUI)分段的功能。

由於路由器處理網路層的數據,因此它們更容易互連不同的數據鏈路層,如令牌環網段和乙太網段。網橋通常比路由器難控制。象IP等協議有復雜的路由協議,使網管易於管理路由;IP等協議還提供了較多的網路如何分段的信息(即使其地址也提供了此類信息)。而網橋則只用MAC地址和物理拓撲進行工作。因此網橋一般適於小型較簡單的網路。

二、使用原因

許多單位都有多個區域網,並且希望能夠將它們連接起來。之所以一個單位有多個區域網,有以下6個原因:

首先,許多大學的系或公司的部門都有各自的區域網,主要用於連接他們自己的個人計算機、工作站以及伺服器。由於各系(或部門)的工作性質不同,因此選用了不同的區域網,這些系(或部門)之間早晚需相互交往,因而需要網橋。

其次,一個單位在地理位置上較分散,並且相距較遠,與其安裝一個遍布所有地點的同軸電纜網,不如在各個地點建立一個區域網,並用網橋和紅外鏈路連接起來,這樣費用可能會低一些。

第3,可能有必要將一個邏輯上單一的LAN分成多個區域網,以調節載荷。例如採用由網橋連接的多個區域網,每個區域網有一組工作站,並且有自己的文件伺服器,因此大部分通信限於單個區域網內,減輕了主幹網的負擔。

第4,在有些情況下,從載荷上看單個區域網是毫無問題的,但是相距最遠的機器之間的物理距離太遠(比如超過802.3所規定的2.5km)。即使電纜鋪設不成問題,但由於來回時延過長,網路仍將不能正常工作。唯一的辦法是將區域網分段,在各段之間放置網橋。通過使用網橋,可以增加工作的總物理距離。

第5,可靠性問題。在一個單獨的區域網中,一個有缺陷的節點不斷地輸出無用的信息流會嚴重地破壞區域網的運行。網橋可以設置在區域網中的關鍵部位,就像建築物內的放火門一樣,防止因單個節點失常而破壞整個系統。

第6,網橋有助於安全保密。大多數LAN介面都有一種混雜工作方式(promiscuousmode),在這種方式下,計算機接收所有的幀,包括那些並不是編址發送給它的幀。如果網中多處設置網橋並謹慎地攔截無須轉發的重要信息,那麼就可以把網路分隔以防止信息被竊。

三、兼容性問題

有人可能會天真地認為從一個802區域網到另一個802區域網的網橋非常簡單,但實際上並非如此。在802.x到802.y的九種組合中,每一種都有它自己的特殊問題要解決。在討論這些特殊問題之前,先來看一看這些網橋共同面臨的一般性問題。

首先,各種區域網採用了不同的幀格式。這種不兼容性並不是由技術上的原因造成的,而僅僅是由於支持三種標準的公司(Xerox,GM和IBM),沒有一家願意改變自己所支持的標准。其結果是:在不同的區域網間復制幀要重排格式,這需要佔用CPU時間,重新計算校驗和,而且還有可能產生因網橋存儲錯誤而造成的無法檢測的錯誤。

第二個問題是互聯的區域網並非必須按相同的數據傳輸速率運行。當快速的區域網向慢速的區域網發送一長串連續幀時,網橋處理幀的速度要比幀進入的速度慢。網橋必須用緩沖區存儲來不及處理的幀,同時還得提防耗盡存儲器。即使是10Mb/s的802.4到10Mb/s的802.3的網橋,在某種程度上也存在這樣的問題。因為802.3的部分帶寬耗費於沖突。802.3實際上並不是真的10Mb/s,而802.4(幾乎)確實為10Mb/s。

與網橋瓶頸問題相關的一個細微而重要的問題是其上各層的計時器值。假如802.4區域網上的網路層想發送一段很長的報文(幀序列)。在發出最後一幀之後,它開啟一個計時器,等待確認。如果此報文必須通過網橋轉到慢速的802.5網路,那麼在最後一幀被轉發到低速區域網之前,計時器就有可能時間到。網路層可能會以為幀丟失而重新發送整個報文。幾次傳送失敗後,網路層就會放棄傳輸並告訴傳輸層目的站點已經關機。

第三,在所有的問題中,可能最為嚴重的問題是三種802LAN有不同的最大幀長度。對於802.3,最大幀長度取決於配置參數,但對標準的10M/bs系統最大有效載荷為1500位元組。802.4的最大幀長度固定為8191位元組。802.5沒有上限,只要站點的傳輸時間不超過令牌持有時間。如果令牌時間預設為10ms,則最大幀長度為5000位元組。一個顯而易見的問題出現了:當必須把一個長幀轉發給不能接收長幀的區域網時,將會怎麼樣?在本層中不考慮把幀分成小段。所有的協議都假定幀要麼到達要麼沒有到達,沒有條款規定把更小的單位重組成幀。這並不是說不能設計這樣的協議,可以設計並已有這種協議,只是802不提供這種功能。這個問題基本上無法解決,必須丟棄因太長而無法轉發的幀。其透明程度也就這樣了。

四、兩種網橋

1、透明網橋

第一種802網橋是透明網橋(transparentbridge)或生成樹網橋(spanningtreebridge)。支持這種設計的人首要關心的是完全透明。按照他們的觀點,裝有多個LAN的單位在買回IEEE標准網橋之後,只需把連接插頭插入網橋,就萬事大吉。不需要改動硬體和軟體,無需設置地址開關,無需裝入路由表或參數。總之什麼也不幹,只須插入電纜就完事,現有LAN的運行完全不受網橋的任何影響。這真是不可思議,他們最終成功了。

透明網橋以混雜方式工作,它接收與之連接的所有LAN傳送的每一幀。當一幀到達時,網橋必須決定將其丟棄還是轉發。如果要轉發,則必須決定發往哪個LAN。這需要通過查詢網橋中一張大型散列表裡的目的地址而作出決定。該表可列出每個可能的目的地,以及它屬於哪一條輸出線路(LAN)。在插入網橋之初,所有的散列表均為空。由於網橋不知道任何目的地的位置,因而採用擴散演算法(floodingalgorithm):把每個到來的、目的地不明的幀輸出到連在此網橋的所有LAN中(除了發送該幀的LAN)。隨著時間的推移,網橋將了解每個目的地的位置。一旦知道了目的地位置,發往該處的幀就只放到適當的LAN上,而不再散發。

透明網橋採用的演算法是逆向學習法(backwardlearning)。網橋按混雜的方式工作,故它能看見所連接的任一LAN上傳送的幀。查看源地址即可知道在哪個LAN上可訪問哪台機器,於是在散列表中添上一項。

當計算機和網橋加電、斷電或遷移時,網路的拓撲結構會隨之改變。為了處理動態拓撲問題,每當增加散列表項時,均在該項中註明幀的到達時間。每當目的地已在表中的幀到達時,將以當前時間更新該項。這樣,從表中每項的時間即可知道該機器最後幀到來的時間。網橋中有一個進程定期地掃描散列表,清除時間早於當前時間若干分鍾的全部表項。於是,如果從LAN上取下一台計算機,並在別處重新連到LAN上的話,那麼在幾分鍾內,它即可重新開始正常工作而無須人工干預。這個演算法同時也意味著,如果機器在幾分鍾內無動作,那麼發給它的幀將不得不散發,一直到它自己發送出一幀為止。

到達幀的路由選擇過程取決於發送的LAN(源LAN)和目的地所在的LAN(目的LAN),如下所示:

1、如果源LAN和目的LAN相同,則丟棄該幀。

2、如果源LAN和目的LAN不同,則轉發該幀。

3、如果目的LAN未知,則進行擴散。

為了提高可靠性,有人在LAN之間設置了並行的兩個或多個網橋,但是,這種配置引起了另外一些問題,因為在拓撲結構中產生了迴路,可能引發無限循環。其解決方法就是下面要講的生成樹(spanningtree)演算法。

生成樹網橋

解決上面所說的無限循環問題的方法是讓網橋相互通信,並用一棵到達每個LAN的生成樹覆蓋實際的拓撲結構。使用生成樹,可以確保任兩個LAN之間只有唯一一條路徑。一旦網橋商定好生成樹,LAN間的所有傳送都遵從此生成樹。由於從每個源到每個目的地只有唯一的路徑,故不可能再有循環。

為了建造生成樹,首先必須選出一個網橋作為生成樹的根。實現的方法是每個網橋廣播其序列號(該序列號由廠家設置並保證全球唯一),選序列號最小的網橋作為根。接著,按根到每個網橋的最短路徑來構造生成樹。如果某個網橋或LAN故障,則重新計算。

網橋通過BPDU(BridgeProtocolDataUnit)互相通信,在網橋做出配置自己的決定前,每個網橋和每個埠需要下列配置數據:

網橋:網橋ID(唯一的標識)

埠:埠ID(唯一的標識)

埠相對優先權

各埠的花費(高帶寬=低花費)

配置好各個網橋後,網橋將根據配置參數自動確定生成樹,這一過程有三個階段:

1、選擇根網橋

具有最小網橋ID的網橋被選作根網橋。網橋ID應為唯一的,但若兩個網橋具有相同的最小ID,則MAC地址小的網橋被選作根。

2、在其它所有網橋上選擇根埠

除根網橋外的各個網橋需要選一個根埠,這應該是最適合與根網橋通信的埠。通過計算各個埠到根網橋的花費,取最小者作為根埠。

3、選擇每個LAN的「指定(designated)網橋」和「指定埠」

如果只有一個網橋連到某LAN,它必然是該LAN的指定網橋,如果多於一個,則到根網橋花費最小的被選為該LAN的指定網橋。指定埠連接指定網橋和相應的LAN(如果這樣的埠多於一個,則低優先權的被選)。

一個埠必須為下列之一:

1、根埠

2、某LAN的指定埠

3、阻塞埠

當一個網橋加電後,它假定自己是根網橋,發送出一個CBPDU(),告知它認為的根網橋ID。一個網橋收到一個根網橋ID小於其所知ID的CBPDU,它將更新自己的表,如果該幀從根埠(上傳)到達,則向所有指定埠(下傳)分發。當一個網橋收到一個根網橋ID大於其所知ID的CBPDU,該信息被丟棄,如果該幀從指定埠到達,則回送一個幀告知真實根網橋的較低ID。

當有意地或由於線路故障引起網路重新配置,上述過程將重復,產生一個新的生成樹。

2、源路由選擇網橋

透明網橋的優點是易於安裝,只需插進電纜即大功告成。但是從另一方面來說,這種網橋並沒有最佳地利用帶寬,因為它們僅僅用到了拓撲結構的一個子集(生成樹)。這兩個(或其他)因素的相對重要性導致了802委員會內部的分裂。支持CSMA/CD和令牌匯流排的人選擇了透明網橋,而令牌環的支持者則偏愛一種稱為源路由選擇(sourcerouting)的網橋(受到IBM的鼓勵)。

源路由選擇的核心思想是假定每個幀的發送者都知道接收者是否在同一LAN上。當發送一幀到另外的LAN時,源機器將目的地址的高位設置成1作為標記。另外,它還在幀頭加進此幀應走的實際路徑。

源路由選擇網橋只關心那些目的地址高位為1的幀,當見到這樣的幀時,它掃描幀頭中的路由,尋找發來此幀的那個LAN的編號。如果發來此幀的那個LAN編號後跟的是本網橋的編號,則將此幀轉發到路由表中自己後面的那個LAN。如果該LAN編號後跟的不是本網橋,則不轉發此幀。這一演算法有3種可能的具體實現:軟體、硬體、混合。這三種具體實現的價格和性能各不相同。第一種沒有介面硬體開銷,但需要速度很快的CPU處理所有到來的幀。最後一種實現需要特殊的VLSI晶元,該晶元分擔了網橋的許多工作,因此,網橋可以採用速度較慢的CPU,或者可以連接更多的LAN。

源路由選擇的前提是互聯網中的每台機器都知道所有其他機器的最佳路徑。如何得到這些路由是源路由選擇演算法的重要部分。獲取路由演算法的基本思想是:如果不知道目的地地址的位置,源機器就發布一廣播幀,詢問它在哪裡。每個網橋都轉發該查找幀(discoveryframe),這樣該幀就可到達互聯網中的每一個LAN。當答復回來時,途經的網橋將它們自己的標識記錄在答復幀中,於是,廣播幀的發送者就可以得到確切的路由,並可從中選取最佳路由。

雖然此演算法可以找到最佳路由(它找到了所有的路由),但同時也面臨著幀爆炸的問題。透明網橋也會發生有點類似的狀況,但是沒有這么嚴重。其擴散是按生成樹進行,所以傳送的總幀數是網路大小的線性函數,而不象源路由選擇是指數函數。一旦主機找到至某目的地的一條路由,它就將其存入到高速緩沖器之中,無需再作查找。雖然這種方法大大遏制了幀爆炸,但它給所有的主機增加了事務性負擔,而且整個演算法肯定是不透明的。

3、兩種網橋的比較

透明網橋一般用於連接乙太網段,而源路由選擇網橋則一般用於連接令牌環網段。

五、遠程網橋

網橋有時也被用來連接兩個或多個相距較遠的LAN。比如,某個公司分布在多個城市中,該公司在每個城市中均有一個本地的LAN,最理想的情況就是所有的LAN均連接起來,整個系統就像一個大型的LAN一樣。

該目標可通過下述方法實現:每個LAN中均設置一個網橋,並且用點到點的連接(比如租用電話公司的電話線)將它們兩個兩個地連接起來。點到點連線可採用各種不同的協議。辦法之一就是選用某種標準的點到點數據鏈路協議,將完整的MAC幀加到有效載荷中。如果所有的LAN均相同,這種辦法的效果最好,它的唯一問題就是必須將幀送到正確的LAN中。另一種辦法是在源網橋中去掉MAC的頭部和尾部,並把剩下的部分加到點到點協議的有效載荷中,然後在目的網橋中產生新的頭部和尾部。它的缺點是到達目的主機的校驗和並非是源主機所計算的校驗和,因此網橋存儲器中某位損壞所產生的錯誤可能不會被檢測到。

網橋的基本工作原理
數據鏈路層互聯的設備是網橋(bridge),在網路互聯中它起到數據接收、地址過濾與數據轉發的作用,用來實現多個網路系統之間的數據交換。
網橋的基本特徵
1.網橋在數據鏈路層上實現區域網互連;
2.網橋能夠互連兩個採用不同數據鏈路層協議、不同傳輸介質與不同傳輸速率的網路;
3.網橋以接收、存儲、地址過濾與轉發的方式實現互連的網路之間的通信;
4.網橋需要互連的網路在數據鏈路層以上採用相同的協議;
5.網橋可以分隔兩個網路之間的廣播通信量,有利於改善互連網路的性能與安全性。

參考資料
http://www.9iseo.cn
可以來我的Blog http://sc2starcraft.cn找我 咨詢免費

㈦ 透明網橋的自學習和轉發幀

透明網橋以混雜方式工作,它接收與之連接的所有LAN傳送的每一幀。當一幀到達時,網橋必須決定將其丟棄還是轉發。如果要轉發,則必須決定發往哪個LAN。這需要通過查詢網橋中一張大型散列表裡的目的地址而作出決定。該表可列出每個可能的目的地,以及它屬於哪一條輸出線路(LAN)。在插入網橋之初,所有的散列表均為空。這時若網橋受到一個幀,會採用自學習(self-learning)演算法處理收到的幀(這樣就逐漸建立起轉發表),並且按照轉發表把幀轉發出去。這種自學習演算法的原理並不復雜,若從某個站A發出的幀從介面x進入了某網橋,那麼從這個介面出發沿相反方向一定可把一個幀傳送到A。所以網橋只要每收到一個幀,就記下其源地址和進入網橋的介面,作為轉發表中的一個項目。在建立轉發表時是把幀首部中的源地址寫在「地址」這一欄的下面。在轉發幀時,則是根據收到的幀首部中的目的地址來轉發的。這時就把在「地址」欄下面已經記下的源地址當作目的地址,而把記下的進入介面當作轉發介面。
如果網路上的每一個站都發送過幀,那麼每一個幀的地址最終都會記錄在兩個網橋的轉發表上。
實際上,在網橋的轉發表中寫入的信息除了地址和介面外,還有幀進入該網橋的時間要登記進入網橋的時間是因為乙太網的拓撲可能會經常發生變化,站點也會更換適配器。另外,乙太網上的工作站並非總是接通電源的。把每個幀到達網橋的時間登記下來,就可以在轉發表中只保留網路拓撲的最新狀態信息。具體方法是,網橋中的介面管理軟體周期性地掃描轉發表中的項目。只要在一定時間以前登記的都要刪除。這樣就使得網橋中的轉發表能反映當前網路的最新拓撲狀態。
由此可見,網橋中的轉發信息表並非總是包含所有站點的信息。只要某個站點從來都不發送數據,那麼在網橋的轉發表中就沒有這個站點的項目。如果站點A在一段時間內不發送數據,那麼在轉發表中地址為A的項目就被刪除了。
下面是網橋的自學習和轉發幀的一般步驟。 網橋收到一幀後先進行自學習。查找轉發表中與收到幀的源地址有無相匹配的項目。如果沒有,就在轉發表中增加一個項目。如果有,則把原有的項目進行更新。 轉發幀。查找轉發表中與收到幀的源地址有無相匹配的項目。如果沒有,則通過所有其他介面進行轉發。如果有,則按轉發表中給出的介面進行轉發。但應注意,若轉發表中給出的介面就是該幀進入網橋的介面,則應丟棄這個幀。

㈧ 什麼是網橋的向後學習法

向後學習法就是逆向學習法,透明網橋採用的演算法是逆向學習法(backward learning)。網橋按混雜的方式工作,故它能看見所連接的任一LAN上傳送的幀。查看源地址即可知道在哪個LAN上可訪問哪台機器,於是在散列表中添上一項。
當計算機和網橋加電、斷電或遷移時,網路的拓撲結構會隨之改變。為了處理動態拓撲問題,每當增加散列表項時,均在該項中註明幀的到達時間。每當目的地已在表中的幀到達時,將以當前時間更新該項。這樣,從表中每項的時間即可知道該機器最後幀到來的時間。網橋中有一個進程定期地掃描散列表,清除時間早於當前時間若干分鍾的全部表項。於是,如果從LAN上取下一台計算機,並在別處重新連到LAN上的話,那麼在幾分鍾內,它即可重新開始正常工作而無須人工干預。這個演算法同時也意味著,如果機器在幾分鍾內無動作,那麼發給它的幀將不得不散發,一直到它自己發送出一幀為止。

熱點內容
phptiny 發布:2025-01-18 20:54:03 瀏覽:987
怎麼給漢字加密 發布:2025-01-18 20:49:44 瀏覽:865
遍歷javamap 發布:2025-01-18 20:39:05 瀏覽:624
我的世界租伺服器哪裡最便宜 發布:2025-01-18 20:38:50 瀏覽:564
dhcp伺服器地址租期時間怎麼調整 發布:2025-01-18 20:28:02 瀏覽:267
加密區的圖片 發布:2025-01-18 20:22:17 瀏覽:474
key文件加密 發布:2025-01-18 20:12:07 瀏覽:736
etl伺服器怎麼用 發布:2025-01-18 20:08:18 瀏覽:281
硫酸鎂演算法 發布:2025-01-18 19:53:00 瀏覽:670
華為什麼時候做安卓 發布:2025-01-18 19:44:23 瀏覽:713