ラベル QoS の投稿を表示しています。 すべての投稿を表示
ラベル QoS の投稿を表示しています。 すべての投稿を表示

2011年11月25日金曜日

QOS 6.QOS設定 LLQ


■MQCによるQoSの設定(LLQ)


④LLQ(Low Latency queue)

PQとCBWFQの2つを組み合わせたキューイング方式。
絶対優先されたいパケット(VoIPなど)をPQ(FIFO)を使用して転送し、その他は、WFQを使用して転送されます。
又、PQの欠点であった優先度の高いキュー(完全優先キュー)が空にならない限り優先度の低いパケットを転送できない部分は、ポリシングを使用する事で回避しております。(完全優先キューで帯域幅の許容値を超えた場合は、ドロップされる。)



1.class-mapを使用して、トラフィッククラスを定義する。


Router(config)# class-map { クラス名 }
Router(config-cmap)# match access-group { アクセスリスト番号 } //上記のポリシーに分類するアクセスリスト


2.policy-mapを使用して、1で定義したトラフィッククラスに対してトラフィックポリシーを定義する。


Router(config)# policy-map { ポリシー名 }
Router(config-pmap)# class { クラス名 }

①完全優先キューを使用する場合はpriorityを使用する。
Router(config-pmap-c)# priority { 帯域幅(kbps) }
Router(config-pmap-c)# priority percent{ 割り当てる帯域幅の割合(%) }

②bandwidthを使用する場合
Router(config-pmap-c)# bandwidth { 帯域幅(kbps) }
Router(config-pmap-c)# bandwidth percent{ 割り当てる帯域幅の割合(%) }


3.service-policyを使用して、トラフィックポリシーを定義するインターフェースを定義する。


Router(config)# interface { インターフェース名 }
Router(config-if)# service-policy { output | input } {ポリシー名}




例>

1.class-mapを使用して、トラフィッククラスを定義する。



Router(config)# class-map rtp
Router(config-cmap)# match access-group 100
Router(config-cmap)# exit
Router(config)# class-map http
Router(config-cmap)# match access-group 110
Router(config-cmap)# exit
Router(config)# class-map com-traffic
Router(config-cmap)# match access-group 120
Router(config-cmap)# exit

※ACLでは各トラフィッククラスに分類するトラフィックを定義する
例>
Router(config)# access-list 110 permit tcp any any eq 80


2.policy-mapを使用して、1で定義したトラフィッククラスに対してトラフィックポリシーを定義する。

Router(config)# policy-map inter_net
Router(config-pmap)# class rtp
Router(config-pmap-c)# priority 100 //100kbpsを保証する
Router(config-pmap-c)#exit
Router(config-pmap)# class http
Router(config-pmap-c)# bandwidth 80
Router(config-pmap-c)#exit
Router(config-pmap)# class com-traffic
Router(config-pmap-c)# bandwidth 70
Router(config-pmap-c)#exit
Router(config-pmap)# class class-default
Router(config-pmap-c)#fair-queue 
Router(config-pmap-c)#exit



3.service-policyを使用して、トラフィックポリシーを定義するインターフェースを定義する。

Router(config)# interface serial0/0/0
Router(config-if)# service-policy input inter_net



・show run で一部内容確認

1.確認
class-map rtp
  match access-group 100
!
class-map http
  match access-group 110
!
class-map com-traffic
  match access-group 120
!

2.確認

policy-map inter_net
  class rtp
   priority 100
  class http
   bandwidth 80
  class com-traffic
   bandwidth 70
  class class-default
   fair-queue
!

3.確認

interface serial 0/0/1
  service-policy input inter_net


>>オススメ記事:CCIEが語る!ネットワークエンジニアにオススメな本・参考書!
>>オススメ記事:ITエンジニア必見!失敗しない転職エージェントの選び方はこれだ!


2011年11月23日水曜日

QOS 5.QOS設定 CBWFQ


■MQCによるQoSの設定(CBWFQ)



CBWFQ(Class-based Weighted Fair queue)

WFQに定義されたクラスというグループ(最大64個)を使用して優先制御する方式。又、CBWFQは各キューに最低保証帯域幅を指定する事が出来、それ以上の帯域幅を利用可能であれば、利用することも可能。
問題点 : WFQと同様に帯域などの保証がない。(上限に達した場合、VoIPなどの優先度が高いアプリケーションをテールドロップする可能性がある。)



1.class-mapを使用して、トラフィッククラスを定義する。


Router(config)# class-map { クラス名 }
Router(config-cmap)# match access-group { アクセスリスト番号 } //上記のポリシーに分類するアクセスリスト


2.policy-mapを使用して、1で定義したトラフィッククラスに対してトラフィックポリシーを定義する。


Router(config)# policy-map { ポリシー名 }
Router(config-pmap)# class { クラス名 }
Router(config-pmap-c)# bandwidth { 帯域幅(kbps) }
又は、
Router(config-pmap-c)# bandwidth percent{ 割り当てる帯域幅の割合(%) }
Router(config-pmap-c)# queue-limit { キューの上限 }
Router(config-pmap-c)#fair-queue [ ダイナミックキュー]


3.service-policyを使用して、トラフィックポリシーを定義するインターフェースを定義する。


Router(config)# interface { インターフェース名 }
Router(config-if)# service-policy { output | input } {ポリシー名}




例>

1.class-mapを使用して、トラフィッククラスを定義する。



Router(config)# class-map rtp
Router(config-cmap)# match access-group 100
Router(config-cmap)# exit
Router(config)# class-map http
Router(config-cmap)# match access-group 110
Router(config-cmap)# exit
Router(config)# class-map com-traffic
Router(config-cmap)# match access-group 120
Router(config-cmap)# exit




2.policy-mapを使用して、1で定義したトラフィッククラスに対してトラフィックポリシーを定義する。

Router(config)# policy-map inter_net
Router(config-pmap)# class rtp
Router(config-pmap-c)# bandwidth 40
Router(config-pmap-c)# queue-limit 40
Router(config-pmap-c)#exit
Router(config-pmap)# class http
Router(config-pmap-c)# bandwidth 30
Router(config-pmap-c)# queue-limit 50
Router(config-pmap-c)#exit
Router(config-pmap)# class com-traffic
Router(config-pmap-c)# bandwidth 20
Router(config-pmap-c)#exit
Router(config-pmap)# class class-default
Router(config-pmap-c)#fair-queue 
Router(config-pmap-c)#exit



3.service-policyを使用して、トラフィックポリシーを定義するインターフェースを定義する。

Router(config)# interface serial0/0/0
Router(config-if)# service-policy input inter_net



・show run で一部内容確認

1.確認
class-map rtp
  match access-group 100
!
class-map http
  match access-group 110
!
class-map com-traffic
  match access-group 120
!

2.確認

policy-map inter_net
  class rtp
   bandwidth  40
 queue-limit 40
  class http
   bandwidth  30
 queue-limit 50
  class com-traffic
   bandwidth  20
  class class-default
   fair-queue
!

3.確認

interface serial 0/0/1
  service-policy input inter_net


■確認コマンド
・show policy-map interface コマンド


2011年11月22日火曜日

QOS 4.ポリシングとシェーピング


帯域制御、輻輳制御、輻輳回避の設定をやっていきます。


■帯域制御


ポリシング(Policing)

リミット帯域を事前に設定しておき、その帯域以上のトラフィックが来た場合超過分のパケットを破棄する技術。ユーザが実際のアクセスルートより小さなアクセスルートが割り当てられている場合、各プロバイダーはポリシングを使用し小さいアクセスルート値(サブレート値)を強制される事が出来る。

シェーピング(Shaping)

リミット帯域を事前に設定しておき、常にその設定された帯域を超過しないようにする機能。又、リミット帯域以上のパケットを処理する場合、バッファに格納しておき再転送する。(破棄されない)。主に、FRやWAN接続の際に使用されたり、プロバイダーが顧客を契約したSLAに応じて契約したレートに制限する時に使用される。


ポリシングとシェーピングでは、トークンバケット方式を採用しております。
トークンバケット方式

CIR・・・・・平均レート
Bc・・・・・ 定期的に入ってくるトークンの量の事。
Be・・・・・ トークンバケットに貯蓄する事が出来る最大トークン量の事。
Tc・・・・・ 定期的にトークンバケットに入ってくる補充間隔。


基本的に帯域制御しているルータにパケットが到達すると、トークンバケット内に、そのトラフィックを転送可能分のトークンがあるか確認し、あればその分のトークンをバケットから取り除きます。


・シングルトークンパケット方式

シングルトークンバケット方式では、使用するトークンバケットはBcバケットの1つです。
パケットを転送するする際に、Bcバケット分のトークンで転送できるパケットの際は使用したBc分のトークンを差し引き転送する事が出来ます。
しかし、Bcバケット分のトークンではパケット転送できない場合は破棄(ポリシング)又は、キュー(シェーピング)に蓄積されます。


例> [Bc=1000バイト CIR= 10000bps の場合]
※パケットは0.8秒後に到着すると仮定します。
トークンの補充数・・・0.8秒×10000bps÷8= 1000バイト


①0.2秒目で800バイトのパケットが転送されてきた時、Bcトークンバケットから800バイト分のトークンを使用してパケットを転送する事が出来る。
残り[200バイト]

②1秒経ったので、Bc= 1000バイト分のトークンが補充されるが、Bcバケットには200バイト分のトークンが残っており残り200バイト分のトークンは溢れてしまい格納できない。
残り[1000バイト]  ※Bcバケット値以上は格納する事が出来ない

③1.2秒目で1200バイトのパケットが転送されてきた時、Bcバケット内は1000バイト分のトークンしかなく200バイト分の不足している為、パケットは破棄(ポリシング)又は、キュー(シェーピング)に蓄積されます。
残り[1000バイト]


・デュアルトークンバケット方式

デュアルトークンバケット方式ではBcとBeのトークンバケットを使用する事が可能です。

例> [Bc=1000バイト Be=3000バイト[現在は,1000バイト入っている] CIR= 10000bps の場合]
※パケットは0.8秒後に到着すると仮定します。
トークンの補充数・・・0.8秒×10000bps÷8= 1000バイト


①0.2秒目で800バイトのパケットが転送されてきた時、Bcトークンバケットから800バイト分のトークンを使用してパケットを転送する事が出来る。
残り Bcバケット[200バイト] Beバケット[1000バイト]

②1秒経ったので、Bc= 1000バイト分のトークンが補充されるが、Bcバケットには200バイト分のトークンが残っており残り200バイト分のトークンは溢れてしまい格納できないので、
溢れた200バイト分のトークンをBeバケットに格納する。
残りBcバケット[1000バイト] Beバケット[1200バイト]

③1.2秒目で1200バイトのパケットが転送されてきた時、Bcバケット内は1000バイト分のトークンしかなく200バイト分の不足している為、超過した200バイト分のトークンをBeバケットから使用する事が出来る。
残り Bcバケット[0バイト] Beバケット[1000バイト]


------  公式  ----------

・CIR = Bc(ビット) ÷ Tc(秒)
・補充するトークン量 = パケット到達時刻(秒) × CIR ÷ 8(バイト変換)


>>オススメ記事:CCIEが語る!ネットワークエンジニアにオススメな本・参考書!
>>オススメ記事:ITエンジニア必見!失敗しない転職エージェントの選び方はこれだ!

2011年11月20日日曜日

QOS 3.キューイング

QoSの機能は大きく分けて3つあります。
輻輳回避
②輻輳制御
帯域制御


■輻輳制御(キューリング)

他のパケットを処理している間、残りの待ちパケットを一時的に保管する方式

・キューイングの種類

①PQ(Priority queueing)

パケットに4つの優先度(high,medium,normal,low)を設定して、キューイングされた際、high > medium > normal > low の順に転送する方式。
基本的にhigh > medium > normal > low の関係を基に転送される為、常に優先度の高いキューから参照されます。その為、優先度の高いキューが空にならない限り低い優先度に格納されているキューは転送されない。
問題点:優先度の低いキューが枯渇状態になる可能性が高い。

②WFQ(Weighted Fair queue)

IP Precedenceを基に優先度を付加し、各トラフィックごとにキューを動的に作成する事でキューイングする仕組み。
又、全て優先度が同じ場合は帯域幅を分け合う事になります。

WFQアグレッシブドロッピング・・ホールドキューが占有状態になった際、到着パケットがドロップされる事。
WFQアーリードロッピング・・・・CDT(輻輳破棄しきい値)に達した際、到着パケットをドロップされる事。

WFQでは、設定が簡単でかつ枯渇状態を回避できる長所があるが、トラフィックフローに対する帯域幅などの保証がない事や高速リンクに対応していないなどの欠点がある。

③CBWFQ(Class-based Weighted Fair queue)

WFQに定義されたクラスというグループ(最大64個)を使用して優先制御する方式。又、CBWFQは各キューに最低保証帯域幅を指定する事が出来、それ以上の帯域幅を利用可能であれば、利用することも可能。
問題点 : WFQと同様に帯域などの保証がない。(上限に達した場合、VoIPなどの優先度が高いアプリケーションをテールドロップする可能性がある。)

④LLQ(Low Latency queue)

PQとCBWFQの2つを組み合わせたキューイング方式。
絶対優先されたいパケット(VoIPなど)をPQ(FIFO)を使用して転送し、その他は、WFQを使用して転送されます。
又、PQの欠点であった優先度の高いキュー(完全優先キュー)が空にならない限り優先度の低いパケットを転送できない部分は、ポリシングを使用する事で回避しております。(完全優先キューで帯域幅の許容値を超えた場合は、ドロップされる。)



■輻輳回避


過度な輻輳が発生すると、キューに格納できないパケットがテールドロップによりドロップされてしまいます。
又、TCP通信は破棄された事を確認すると、再送処理が実行される為転送レートを一時的に落として通信しようとします。
テールドロップを回避する為に、キューが占有状態になる為に、破棄する技術がREDやWREDです。

①RED(Random Early Detection)

キューが占有状態になる前に、ランダムにパケットを破棄する技術。
破棄モデルは3つあります。
no drop・・・・・平均キューサイズが最小しきい値より小さい場合は破棄しない。
random drop・・・平均キューサイズが採用しきい値~最大しきい値未満の場合はMP(破棄確率)によりランダムで破棄する。
tail drop・・・・平均キューサイズが最大しきい値以上に達成すると、以後届くパケットを破棄する。

②WRED(Weighted RED)

REDはパケットをランダムに破棄するのに対して、WREDではIP Precedence値やDSCP値によるパケットの優先度を考慮してパケットを破棄する方式。

③CBWRED (Class Based Weighted Random Early Detection)

CBWFQが使用されている場合、個々のキューは優先度の高いパケットもテールドロップしてしまう可能性があります。 その為、CBWFQにWREDを適用した技術でIP Precedence値やDSCP値を基に優先度に低いパケットから破棄する事が出来る。


>>オススメ記事:CCIEが語る!ネットワークエンジニアにオススメな本・参考書!
>>オススメ記事:ITエンジニア必見!失敗しない転職エージェントの選び方はこれだ!



2011年11月19日土曜日

QOS 2.DSCPについて


■diffservについて

・diffservの流れ


①トラフィックの種類や重要度を特定する。
②各ビジネス目標に合致するように、各トラフィックをトラフィッククラスに分類する。
③トラフィッククラスごとに、ポリシーを決定する。


IP Precedenceとは.......

QOSを提供する上で、各パケットを識別してどのように転送するか?優先度を与えるかを判断する為に使用されるマーカーの事。
IP Precedenceでは、3ビットを使用して、合計8クラス(0 ~7)に分けて優先度を設定します。



DSCP [Differentiated Services Code Point] とは.....

QOSを提供する上で、各パケットを識別してどのように転送するか?優先度を与えるかを判断する為に使用されるマーカーの事。
DSCPでは6ビットを使用します。その内、上位3ビットは優先度クラス、下位3ビットはパケット破棄度を設定します。又、IP Precedenceに比べて、より細かい優先度を付ける事が出来る。

各DSCPに応じた優先制御などの事をPHBと呼ぶ。

・PHBの種類


クラスセレクタPHB・・・・・・DSCPが非対応なデバイスと下位互換の為に使用する
 [xxx000] xxxには優先度が入る。 下位3ビットが 000 になるのが特徴。

デフォルトPHB・・・・・・・・BestEffortの為に使用される。
 [000000] DSCP値はすべて 0

AF (Assured Forwarding)・・・帯域保証に使用される。
 [001dd0 ~ 100dd0 ]DSCP値の上位が001~100(優先度)に設定され、ddは、01[低破棄] ~11[高破棄](破棄率)が設定される。


EF (Expedited Forwarding)・・最優先パケットに使用される。遅延を最小限に抑える事が出来ます。
 [101110]

2011年11月18日金曜日

QOS 1.基礎


QOSとは.....

ある特定の通信トラフィックに対して通信品質や信頼性を向上する為に、
優先度などをあげたりして、一定の通信速度を保証する技術。

なぜ、QOSが必要か?
最大の理由........輻湊
ネットワーク内は、日々音声通信やデータ通信、その他のアプリケーションの通信がやりとりされている。
その中でも音声や動画を扱う通信は非常に遅延に敏感なので、遅延を一定の範囲内に収める必要がある。


QOSは主に3つのステップを実行する。

①トラフィックの種類や重要度を特定する。
トラフィックが混雑する時間や各アプリケーションのトラフィックなど時間帯ごとの統計情報を
調査し、ビジネス目標を基にアプリケーションの優先度を決定する。

②各ビジネス目標に合致するように、各トラフィックをトラフィッククラスに分類する。
アプリケーションの優先度を把握した上で、各優先項目毎にトラフィックを分類する。

③トラフィッククラスごとに、ポリシーを決定する。

■QOSの種類


①IntServ (Intergrated Services)

RSVPというネットワーク資源予約プロトコルを使用し、送信元から宛先への帯域を予約して、優先制御する方式。


・問題点
RSVPの帯域予約が失敗した場合、アプリケーションの処理は実行されない。
送信元から宛先までの各ルータがRSVPをサポートしている必要がある。
場合によってはアプリケーションフローが膨大に増え、ルータの大きな負荷がかかる。

②DiffServ (Differentiated Services)

ネットワークを経由する際各ルータが、IPヘッダー内のTOS内のDSCPを再定義し、DSCP参照して輻輳制御や帯域制御を行う技術。
IntServに比べてスケーラビリティが高い。

※後日詳しくやります!!

③Best-effort 

全ての通信が同じ優先度で通信されます。ですので、基本的に先着順にキューイングされます。