<p>style_prompt
本記事は<strong>Geminiの出力をプロンプト工学で整理した業務ドラフト(未検証)</strong>です。</p>
<h1 class="wp-block-heading">令和5年度 秋期 ネットワークスペシャリスト 午前II 問1 OpenFlowの仕様</h1>
<p>本問はSDNの基盤技術であるOpenFlowの基本動作を問う。複数テーブルを用いたパイプライン処理の仕組みを理解しているかが合格の分かれ目となる。</p>
<blockquote class="wp-block-quote is-layout-flow wp-block-quote-is-layout-flow">
<p>【問題】
OpenFlow 1.1以降の仕様において、フローテーブルに関する記述のうち、適切なものはどれか。</p>
<p>ア 1台のスイッチ内に、単一のフローテーブルのみが存在する。
イ パケットがフローテーブルのエントリにマッチしたとき、別のフローテーブルへパイプライン処理を行うことができる。
ウ フローエントリの優先度は、常に登録した順序で決定される。
エ マッチング対象は、L2とL3のヘッダ情報に限定される。</p>
</blockquote>
<h3 class="wp-block-heading">【解説】</h3>
<p>OpenFlow 1.0では1台のスイッチに対して1つのフローテーブルしか持てませんでしたが、OpenFlow 1.1以降では複数のフローテーブルを保持し、それらを連携させる「パイプライン処理」が導入されました。</p>
<p><strong>理論背景</strong>
パケットがスイッチに到達すると、まず「テーブル0」から照合が始まります。エントリにマッチした際、その指示(Instruction)として「次のテーブルへ移動(Goto-Table)」を指定することで、複雑な条件分岐やアクションの組み合わせを効率的に実行できます。</p>
<div class="wp-block-merpress-mermaidjs diagram-source-mermaid"><pre class="mermaid">
graph TD
A["パケット着信"] --> B{"Table 0"}
B -- マッチ --> C["アクション実行 / Table変更"]
B -- ミスマッチ --> D["Table-Miss処理"]
C --> E{"Table n"}
E -- マッチ --> F["最終的なアクション実行"]
E -- ミスマッチ --> D
</pre></div>
<p>各フローエントリには「優先度(Priority)」が設定されており、同一テーブル内で複数のエントリにマッチした場合は、優先度の高い数値を持つエントリが適用されます。</p>
<h3 class="wp-block-heading">【選択肢の吟味】</h3>
<figure class="wp-block-table"><table>
<thead>
<tr>
<th style="text-align:left;">選択肢</th>
<th style="text-align:left;">判定</th>
<th style="text-align:left;">解説</th>
</tr>
</thead>
<tbody>
<tr>
<td style="text-align:left;">ア</td>
<td style="text-align:left;">×</td>
<td style="text-align:left;">OpenFlow 1.1以降では、複数のフローテーブル(マルチテーブル)を持つことが可能である。</td>
</tr>
<tr>
<td style="text-align:left;">イ</td>
<td style="text-align:left;"><strong>○</strong></td>
<td style="text-align:left;">「Goto-Table」インストラクションにより、パケットを後続のテーブルに渡すパイプライン処理が可能。</td>
</tr>
<tr>
<td style="text-align:left;">ウ</td>
<td style="text-align:left;">×</td>
<td style="text-align:left;">優先度はエントリごとに数値(Priorityフィールド)で明示的に指定され、登録順ではない。</td>
</tr>
<tr>
<td style="text-align:left;">エ</td>
<td style="text-align:left;">×</td>
<td style="text-align:left;">L4(ポート番号)やメタデータ、さらには独自定義のフィールドなどもマッチング対象に含めることができる。</td>
</tr>
</tbody>
</table></figure>
<h3 class="wp-block-heading">【ポイント】</h3>
<ul class="wp-block-list">
<li><p><strong>パイプライン処理</strong>:複数のテーブルを順次参照し、複雑なパケット制御を実現する仕組み。</p></li>
<li><p><strong>Goto-Table</strong>:パケットを番号の大きいテーブルへ転送する命令。逆方向(小さい番号)への転送は不可。</p></li>
<li><p><strong>優先度(Priority)</strong>:同一テーブル内でのマッチング順序を決定する数値。大きいほど優先される。</p></li>
</ul>
style_prompt
本記事はGeminiの出力をプロンプト工学で整理した業務ドラフト(未検証)です。
令和5年度 秋期 ネットワークスペシャリスト 午前II 問1 OpenFlowの仕様
本問はSDNの基盤技術であるOpenFlowの基本動作を問う。複数テーブルを用いたパイプライン処理の仕組みを理解しているかが合格の分かれ目となる。
【問題】
OpenFlow 1.1以降の仕様において、フローテーブルに関する記述のうち、適切なものはどれか。
ア 1台のスイッチ内に、単一のフローテーブルのみが存在する。
イ パケットがフローテーブルのエントリにマッチしたとき、別のフローテーブルへパイプライン処理を行うことができる。
ウ フローエントリの優先度は、常に登録した順序で決定される。
エ マッチング対象は、L2とL3のヘッダ情報に限定される。
【解説】
OpenFlow 1.0では1台のスイッチに対して1つのフローテーブルしか持てませんでしたが、OpenFlow 1.1以降では複数のフローテーブルを保持し、それらを連携させる「パイプライン処理」が導入されました。
理論背景
パケットがスイッチに到達すると、まず「テーブル0」から照合が始まります。エントリにマッチした際、その指示(Instruction)として「次のテーブルへ移動(Goto-Table)」を指定することで、複雑な条件分岐やアクションの組み合わせを効率的に実行できます。
graph TD
A["パケット着信"] --> B{"Table 0"}
B -- マッチ --> C["アクション実行 / Table変更"]
B -- ミスマッチ --> D["Table-Miss処理"]
C --> E{"Table n"}
E -- マッチ --> F["最終的なアクション実行"]
E -- ミスマッチ --> D
各フローエントリには「優先度(Priority)」が設定されており、同一テーブル内で複数のエントリにマッチした場合は、優先度の高い数値を持つエントリが適用されます。
【選択肢の吟味】
| 選択肢 |
判定 |
解説 |
| ア |
× |
OpenFlow 1.1以降では、複数のフローテーブル(マルチテーブル)を持つことが可能である。 |
| イ |
○ |
「Goto-Table」インストラクションにより、パケットを後続のテーブルに渡すパイプライン処理が可能。 |
| ウ |
× |
優先度はエントリごとに数値(Priorityフィールド)で明示的に指定され、登録順ではない。 |
| エ |
× |
L4(ポート番号)やメタデータ、さらには独自定義のフィールドなどもマッチング対象に含めることができる。 |
【ポイント】
パイプライン処理:複数のテーブルを順次参照し、複雑なパケット制御を実現する仕組み。
Goto-Table:パケットを番号の大きいテーブルへ転送する命令。逆方向(小さい番号)への転送は不可。
優先度(Priority):同一テーブル内でのマッチング順序を決定する数値。大きいほど優先される。
ライセンス:本記事のテキスト/コードは特記なき限り
CC BY 4.0 です。引用の際は出典URL(本ページ)を明記してください。
利用ポリシー もご参照ください。
コメント