• 検索結果がありません。

NAT 越え技術を応用したリモートアクセス方式の提案と設計

N/A
N/A
Protected

Academic year: 2021

シェア "NAT 越え技術を応用したリモートアクセス方式の提案と設計"

Copied!
23
0
0

読み込み中.... (全文を見る)

全文

(1)

NAT

越え技術を応用したリモートアクセス方式の提案と設計

060427330 鈴木 健太

渡邊研究室

1. はじめに

近年のモバイルブロードバンドの普及や,モバイル端末の 高性能化に伴い,リモートアクセスのニーズが増加してい る.リモートアクセスを実現するための既存の方式として,

IPsec-VPNSSL-VPNがある.しかし,IPsec-VPN 設定項目が複雑であり,利用するためには相応の知識が必要 となる.SSL-VPNは専門的な知識は必要ないものの,使用 できるアプリケーションが限定されるという課題がある.

本稿では,NAT越え技術に基づいたリモートアクセス方 GSRAGroup-based Secure Remote Access)を提案 し,Windowsクライアントへの実装方法を検討する.

2. 提案方式の概要

GSRAは,我々が提案したNAT越え技術NAT-fNAT- free Protocol[1]を利用し,通信グループを設定すること により,アクセス制御とサービス制御を行う.インターネッ ト上のトラフィックはPCCOM[2]により暗号化する.

GSRA 使 用 時 の ネ ッ ト ワ ー ク 構 成 例 を 図 1 に 示 す . GSRAの機能を実装したルータをGSRAルータと呼び,リ モート先のネットワークにGSRA専用のゲートウェイとし て設置する.リモートアクセスを行う端末をENExternal Node,アクセス先の端末をINInternal Node)と表記す る.ENは同一グループに所属しているIN1と通信可能で あるが,異なるグループのIN2とは通信できない.INのグ ループ情報はGSRAルータに登録されている.

1: ネットワーク構成例

3. 提案方式の実装

GSRANAT-fPCCOMを利用するが,これらは FreeBSDに実装されている.そのため,これらを用いて GSRAFreeBSDでの実装を完了させたが,FreeBSD クライアントOSとして一般的ではなく,今後のGSRA 普及のためにはWindowsへの実装が不可決である.

現在のFreeBSDにおけるGSRAの実装は,IP層を直接 改造することで実現されている.しかし,Windows OS ブラックボックスであり,直接改造することはできない.そ の代わりに,機能を拡張するためのインタフェースがいくつ か公開されている.本稿ではTCP/IPスタックに干渉でき APIとしてWFPWindows Filtering Platform)に着

2: WindowsにおけるGSRAシステム設計 目し,WindowsGSRAを実装する方法を検討する.

3. 1 WFPの概要

WFPでは,ネットワークスタック中の特定のポイントに,

パケットをフィルタリングエンジンへ渡すためのフィルタリ ングレイヤが定義されている.このレイヤIDを指定して任 意のフィルタやコールアウトを登録することで,トラフィッ クの監視やパケットの書き換え等を行うことができる.

3. 2 WFPを利用した実装

2に設計概要を示す.パケット送信時は,ネットワーク 層最上部に登録したフィルタによってパケットをフックし,

GSRAモジュールへ渡す.GSRAモジュールでは,アドレ ス変換等,必要な処理を行った上で,フィルタリングエンジ ンを通してパケットを元の流れへと返す.GSRA制御用パ ケットは,RAWソケットを使用して送信する.

パケット受信時は,ネットワーク層最下部に登録したフィ ルタによりパケットをフックする.これはPCCOMが独自 TCP/UDPチェックサム計算を行っており,TCP/IP タックにおけるチェックサム検証時にパケットが破棄される ことを防ぐためである.

以上の設定により,WindowsGSRAを実装すること ができると考えられる.

4. まとめ

NAT越え技術に基づいたリモートアクセス方式GSRA を提案し,Windowsクライアントへの実装方法を検討した.

今後は検討した設計に従い実装を行い,性能を評価する.

参考文献

[1] 鈴木秀和,宇佐見庄五,渡邊晃.外部動的マッピングによ NAT越えを実現するNAT-fの提案と実装. 情報処 理学会論文誌, Vol. 48, No. 12, pp. 3949–3961, Dec.

2007.

[2] 増田真也, 鈴木秀和, 岡崎直宣, 渡邊晃. NATやファ イアウォールと共存できる暗号通信方式PCCOM 提案と実装. 情報処理学会論文誌, Vol. 47, No. 7, pp.

2258–2266, July. 2006.

(2)

NAT 越え技術を応用した

リモートアクセス方式の提案と設計

渡邊研究室

060427330 鈴木 健太

(3)

のニーズが増加

– 遠隔地から社内や家庭のネットワークに接続し,

資源を利用する技術

• 用途:ファイルの参照,アプリケーションの実行など

• 利用例: FirePass

リモートアクセスとは

• 研究背景

– モバイル端末の高性能化

– モバイルブロードバンドの普及

1

Proposal and Design of Remote Access Method using NAT Traversal Technology

リモートアクセス

外出先

⾃宅

(4)

既存のリモートアクセス

• インターネット VPN を利用したリモートアクセス

– インターネット VPN

• インターネット上に VPN を構築する

• 複数箇所の拠点を低コストで接続できる

– インターネット上の脅威

• 盗聴,改ざん,なりすまし ...

Proposal and Design of Remote Access Method using NAT Traversal Technology 2

VPN(Virtual Private Network) :仮想プライベートネットワーク

暗号化技術に基づいた VPN

既存方式: IPsec-VPN , SSL-VPN

(5)

既存方式: IPsec-VPN

3

Proposal and Design of Remote Access Method using NAT Traversal Technology

• IPsec トンネルを利用して VPN を構築する

• IP レベルで暗号化:アプリケーションに依存しない

• 運用に専門知識が必要で管理負荷が大きい

アクセス先LAN

EN(External Node):外部ノード IN(Internal Node):内部ノード

暗号通信 平文通信

EN

IN1

IN2

インターネット

IPsecトンネル

IPsec-VPN 装置 IPsec

(6)

既存方式: SSL-VPN

4 DMZ

SSL-VPNサーバ

Proposal and Design of Remote Access Method using NAT Traversal Technology

• DMZ 上の SSL-VPN サーバがプロキシの役割

• EN 側には Web ブラウザさえあれば使用できる

• アプリケーションが限定される

DMZ(DeMilitarized Zone) : 非武装地帯

暗号通信 平文通信

EN

IN1

IN2

アクセス先LAN

インターネット

GW

(7)

提案方式

• GSRA( Group-based Secure Remote Access )

– NAT 越え 技術を基盤とする

• NAT-f ( NAT-free protocol )

– 既存の GW には改造を加えない

• GSRA ルータ:専用の GW

Proposal and Design of Remote Access Method using NAT Traversal Technology 5

課題 ・セキュリティ

・通信の戻り道

※ NAT

越え問題

NAT(Network Address Translation)

の外側から通信を開始できない

GSRA

GW 平文通信

GSRA GSRAルータ

リモートアクセス 通常の通信

EN

IN1

IN2

アクセス先 LAN

インターネット

(8)

GSRA :概要

• IN からは GSRA ルータが通信相手に見える

• パケットは PCCOM により暗号化

• 通信グループを定義してアクセス制御

– 端末ごとの制御に比べ管理負荷を軽減

• アプリケーションに依存しない

Proposal and Design of Remote Access Method using NAT Traversal Technology 6

GSRA

GW 暗号通信

平文通信

GSRA GSRAルータ

グループ1

リモートアクセス 通常の通信

EN

IN1

IN2

アクセス先 LAN

インターネット

グループ1

グループ2

PCCOMPractical Cipher Communication Protocol

(9)

GSRA 通信シーケンス1

① 名前解決処理

9 応答内容 (G

GR

) を仮想 IP アドレス (V

IN

) に書き換え 9 仮想 IP アドレスで内部ノードを識別

② グループ認証処理

9 EN と IN が同一グループかどうか認証

同グループ

アクセス許可

異グループ

アクセス拒否

Proposal and Design of Remote Access Method using NAT Traversal Technology 7

EN

AliceとGGR

DDNSサーバ GSRAルータ

の関係

IP:G

GR

IP:P

GR

IP:G

EN

IP:P

IN

Group:1

Group:1

IN(Alice)

アプリケーション カーネル

グループ認証処理 名前解決処理

Alice=VIN

(10)

GSRA 通信シーケンス2

③ マッピング処理

9 GSRA ルータにアドレス変換テーブルを生成 9 EN に VAT テーブルを生成

④ 生成したテーブルに従ってアドレス変換しながら通信

9 GSRA ルータは送信元を自身に書き換える 9 IN は GSRA ルータが通信相手に見える

Proposal and Design of Remote Access Method using NAT Traversal Technology 8

G

EN

→G

GR

P

GR

→P

IN

アプリケーション カーネル

EN DDNS

サーバ

GSRA

ルータ

G

EN

←G

GR

G

EN

←V

IN

P

GR

←P

IN

IP:G

GR

IP:P

GR

IP:P

IN

Group:1

IN(Alice)

G

EN

→V

IN

IP:G

EN

Group:1

: TCP/UDP

パケット

マッピング処理

VAT(Virtual Address Translation):仮想アドレス変換

(11)

Windows への実装

• Windows へ実装する

– Windows OS はブラックボックス

– 機能拡張のためのインターフェースが存在

• WFP ( Windows Filtering Platform )

– ネットワークスタックに干渉できる API

– トラフィックの監視やパケットの書き換え等

Proposal and Design of Remote Access Method using NAT Traversal Technology 9

(12)

WFP を用いた実装

• パケット送信時

– ネットワーク層最上部でパケットをフック

• パケット受信時

– ネットワーク層最下部でパケットをフック

• GSRA 制御パケット

– 送信時には RAW ソケットを使用

Proposal and Design of Remote Access Method using NAT Traversal Technology 10

トランスポート層 ネットワーク層 データリンク層

WFP フィルタ エンジン

ユーザランド カーネル

送信路 受信路 RAWソケット

物理伝送路

GSRA モジュールで処理後 差し戻し

アドレス変換,暗号化

/

復号

(13)

まとめ

• リモートアクセス方式 GSRA の提案を行った

– NAT 越え技術に基づいたリモートアクセス方式 – 既存方式の課題を解決

• 提案方式の Windows への実装方法を検討した

– OS がブラックボックスであり直接改造できない – ネットワーク機能を拡張できる WFP を利用する

• 今後は実装と性能評価を行う

11

Proposal and Design of Remote Access Method using NAT Traversal Technology

(14)

補足資料

12

Proposal and Design of Remote Access Method using NAT Traversal Technology

(15)

要素技術: NAT-f

• NAT- f (NAT-free protocol)

① EN は IN を仮想 IP アドレスで認識する

② EN から NAT にマッピングテーブルを生成させる

③ NAT のマッピング内容に対応する VAT テーブルを EN に 生成する

④ 生成したテーブルに従いアドレスを変換しながら通信を 行う

Proposal and Design of Remote Access Method using NAT Traversal Technology 13

EN NAT-fルータ IN

NAT-f

NAT-f

VAT(Virtual Address Translation):仮想アドレス変換

VAT テーブル NAT マッピングテーブル

DDNS

サーバ

1 2

INと通信したい

(16)

要素技術: PCCOM

• 独自の TCP/UDP チェックサム計算

– 本人性確認とパケットの完全性保証

• 暗号化範囲= TCP ペイロード部

– NAT をまたがった暗号通信が可能

• パケットフォーマットに変更を加えない

– 高スループットを実現

Proposal and Design of Remote Access Method using NAT Traversal Technology 14

・TCP/UDPヘッダ

・ TCP/UDP 疑似ヘッダ

・暗号化後のデータ

・ Checksum Base

・転送中に変化しない値

・共通鍵

・疑似データ

独自

チェックサム計算

(17)

IN の名前解決処理

① GSRA ルータの IP アドレス G GR を応答

② G GR を IP アドレス V IN 書き換え

③ EN は IN を仮想的に認識⇒仮想 IP アドレスで IN を識別

GSRA 通信シーケンス1:名前解決

Proposal and Design of Remote Access Method using NAT Traversal Technology 15

DNS 要求

DNS 応答 DNS 応答 G

GR

V

IN

1 3

2

EN DDNS

サーバ

GSRA

ルータ

INHN(Alice) とGSRAルータ のIPアドレス (GGR)の関係

IP:G

GR

IP:P

GR

IP:G

EN

IP:P

IN

Alice

Group:1

Group:1

IN(Alice)

アプリケーション カーネル

(18)

GSRA 通信シーケンス2:グループ認証

アクセス制御のためのグループ認証処理

① 自身のグループ情報と通信したい IN を提示

② EN と IN が同一の通信グループかどうか照合

③ ○: EN と IN の通信に使用するポート番号を予約して応答

×:アクセス拒否

Proposal and Design of Remote Access Method using NAT Traversal Technology 16

グループ認証要求

グループ認証応答 port: t

3 2 1

EN DDNS

サーバ

GSRA

ルータ

IN(Alice)

IP:G

GR

IP:P

GR

IP:P

IN

Group1,Alice

Group:1

IP:G

EN

Group:1

アプリケーション カーネル

(19)

GSRA 通信シーケンス3:バインディング

HR で変換されたアドレスに対してマッピングするための準備

① EN の送信元情報を記載⇔メッセージの送信元は HR

② ホームルータの IP アドレス,ポート番号を取得

③ 取得した HR の情報を EN へ通知

Proposal and Design of Remote Access Method using NAT Traversal Technology 17

2 アプリケーション カーネル

EN GSRA

ルータ

IN

IP:G

GR

IP:P

GR

IP:G

HR

P

EN

s

バインディング要求 G

HR

:m→G

GR

:t 1

G

HR

m

3 バインディング応答

HR

HR

Home Router

グループ認証

マッピング

IP:P

IN

Group:1 Group:1

IP:G

EN

(20)

GSRA 通信シーケンス4:マッピング処理

アドレス変換テーブルを生成するためのマッピング処理

① 割り当てられたポート番号に対しマッピング要求を行う

② GSRA ルータ:アドレス変換テーブルを生成

③ EN : VAT テーブルを生成

Proposal and Design of Remote Access Method using NAT Traversal Technology 18

マッピング要求

マッピング応答

IP:G

GR

IP:P

GR

IP:P

IN

EN DDNS

サーバ

GSRA

ルータ

3

2 1

アドレス変換テーブル

{G

EN

:s↔G

GR

:t }⇔{P

GR

:t↔P

IN

:d } VAT テーブル

{G

EN

:s↔V

IN

:d } ⇔ {G

EN

:s↔G

GR

:t }

Group:1

↔:両辺の通信

⇔:両辺の変換

IN(Alice)

Group:1

アプリケーション カーネル

IP:G

EN

(21)

GSRA 通信シーケンス5:アドレス変換

生成したテーブルに従ってアドレス変換通信

① VAT テーブルに従ってアドレス変換

② アドレス変換テーブルに従ってアドレス変換

Proposal and Design of Remote Access Method using NAT Traversal Technology 19

G

EN

:s→G

GR

:t P

GR

:t→P

IN

:d 1

EN DDNS

サーバ

GSRA

ルータ

G

EN

:s←G

GR

:t

G

EN

:s←V

IN

:d P

GR

:t←P

IN

:d

IP:G

GR

IP:P

GR

IP:P

IN

Group:1

↔:両辺の通信

⇔:両辺の変換

2 2

IN(Alice)

1 G

EN

:s→V

IN

:d

IP:G

EN

Group:1

アドレス変換テーブル

{G

EN

:s↔G

GR

:t }⇔{P

GR

:t↔P

IN

:d } VAT テーブル

{G

EN

:s↔V

IN

:d } ⇔ {G

EN

:s↔G

GR

:t }

: TCP/UDP 通信

アプリケーション カーネル

(22)

NAT-f の動作

Proposal and Design of Remote Access Method using NAT Traversal Technology 20

VATテーブル

GEN:s↔VIN:d⇔GEN:s↔GNR:m

マッピングテーブル

GEN:s↔GNR:m⇔GEN:s↔PIN:d

INのHN(Alice) とNAT-fルータ のIPアドレス (GNR)の関係

INのIPアドレ スを仮想IPア ドレスVINと認 識する

パケット を待避

VATテーブル

マッピングテーブル

VATVirtual Address Translation:仮想アドレス変換

(23)

GSRA の動作

Proposal and Design of Remote Access Method using NAT Traversal Technology 21

VATテーブル

{GEN:s↔VIN:d}⇔{GEN:s↔GGR:m}

アドレス変換テーブル

{GEN:s↔GGR:m}⇔{PGR:m↔PIN:d}

INHN(Alice) とGSRAルータ のIPアドレス (GGR)の関係

INのIPアドレ スを仮想IP アドレスVIN と認識する

パケット を待避

マッピングテーブル

VATテーブル

VAT(Virtual Address Translation):仮想アドレス変換

グループ:1 INの グループ:1

グループ情報

m番ポート を予約

図 1: ネットワーク構成例

参照

関連したドキュメント

平成 27 年 2 月 17 日に開催した第 4 回では,図-3 の基 本計画案を提案し了承を得た上で,敷地 1 の整備計画に

Using Virtual Tenant Network (VTN) function, four private networks were prepared on single physical network with OpenFlow switch.. Relocation of computer does not

At first, we explain about a virtual disparity image, which is used for estimating geometrical relation between road surface and stereo camera in the next sub-section. Now, we

Internet Explorer 11 Windows 8.1 Windows 10 Microsoft Edge Windows 10..

研究計画書(様式 2)の項目 27~29 の内容に沿って、個人情報や提供されたデータの「①利用 目的」

「技術力」と「人間力」を兼ね備えた人材育成に注力し、専門知識や技術の教育によりファシリ

定可能性は大前提とした上で、どの程度の時間で、どの程度のメモリを用いれば計

技師長 主任技師 技師A 技師B 技師C 技術員 技師長 主任技師 技師A 技師B 技師C 技術員 河川構造物設計 樋門設計