質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
TCP

TCP(Transmission Control Protocol)とは、トランスポート層のプロトコルで、コネクション型のデータサービスです。

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

ネットワーク

ネットワークとは、複数のコンピューター間を接続する技術です。インターネットが最も主流なネットワークの形態で、TCP/IP・HTTP・DNSなどの様々なプロトコルや、ルータやサーバーなどの様々な機器の上に成り立っています。

Q&A

1回答

6393閲覧

ファイアウォールで片側だけの通信制御を行うことは可能か?

Zaganchan

総合スコア80

TCP

TCP(Transmission Control Protocol)とは、トランスポート層のプロトコルで、コネクション型のデータサービスです。

Windows

Windowsは、マイクロソフト社が開発したオペレーティングシステムです。当初は、MS-DOSに変わるOSとして開発されました。 GUIを採用し、主にインテル系のCPUを搭載したコンピューターで動作します。Windows系OSのシェアは、90%を超えるといわれています。 パソコン用以外に、POSシステムやスマートフォンなどの携帯端末用、サーバ用のOSもあります。

ネットワーク

ネットワークとは、複数のコンピューター間を接続する技術です。インターネットが最も主流なネットワークの形態で、TCP/IP・HTTP・DNSなどの様々なプロトコルや、ルータやサーバーなどの様々な機器の上に成り立っています。

0グッド

2クリップ

投稿2018/03/06 07:08

編集2018/03/06 09:07

質問内容
どちらもOSはWindowsとして、サーバーA,サーバーB間でTCP通信するときの話です。

この通信がAのポート5000番、Bのポート8000番とで行われるとします。
(AからBに情報を投げ、Bで処理してAに返すような通信です)

この時、セキュリティが強化されたWindowsファイアウォールを用いて、片道だけ通信を制限するようなことは可能でしょうか。(A⇒BはOKだがB⇒Aの時点でエラーとなるような状態)

わたしは通信を一度確立してしまう以上不可能で、通信を防ぐとしたら送信用の5000番ポートを塞ぐしかないと思っています。(SPIを使えば実現できるのでしょうか…?)
しかし、実証しているような情報も特になく、理論的にはっきり私が理解しているわけでもないため、質問させていただきました。

試してみたこと
Windowsのセキュリティが強化されたWindowsファイアウォールを用いて受信の5000番を塞いでみましたが、特に問題なく通信が行われました。
現在はWireSharkを用いて通信パケットを見ています。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

y_waiwai

2018/03/06 07:56

「Windowsのセキュリティが強化されたWindowsファイアウォール」とはなんでしょうか?
guest

回答1

0

Aのサーバのポートをファイアウォールで閉じれば十分です。

まず、理解して欲しいのは
『この通信がAのポート5000番、Bのポート8000番とで行われるとします』の部分は誤解だという事です。

たぶんコネクションを確立する手順をご存じないために生じた誤解だと思いますので、簡単に手順を説明します。

サーバS(Listen port:8000)とクライアントCがコネクションを確立する手順:

0)最初(コネクションを確立しようとする前の状態):
SはListen port(待ち受けポート)でクライアントからの接続を待っている。

1)クライアントからの接続:
Cはコネクション要求のパケット(SYNパケット)をSに送ります。SYNパケットのは、CのIPアドレス、SのIPアドレス、Cのポート(Cで未使用のポートからそのたび選ばれます。ここでは、201803が使われたとします)、Sのポート(8000)などの情報が入っています。

2)サーバからの応答:
SはSYNパケットを受信すると、コネクション要求を受け入れた事を示すSYN+ACKパケットをCに送ります。

3)コネクションの確立:
CはSYN+ACKパケットを受け取ると、サーバの受け入れを確認したことを示すACKパケットをSに送ります。
ここまでで、SとCの間のコネクションが確立します。

上記の手順で注目して頂きたいのは、CのListen portが使われていない事です。
CからSにコネクションを確立するためには、SのListen portにパケットを送る事が出来れば十分なのです。逆の言い方をすると、SのListen portがCからのパケットを受信できなければ(ファイアウォールで阻止されれば)、CはSとTCPでの通信が出来ません。
そこで、最初の行で書いたように「Aのサーバのポートを閉じれば十分です。」という回答になります。

また、Cのポートは他のマシンにコネクションを確立しようとする度に、その時使われていないポート番号のなかから選ばれるものなので、ほぼ毎回違う。Listen port(Bのサーバの8000)は使われているポートなので、それが他のサーバにコネクションするときに使われることはないといった事も常識として覚えておいてください。

補足:
4)ソケット通信;
コネクションが確立した後、Sの8000ポートとCの201803ポートの間のソケットを双方で作り、それを使ってデータのやり取りを行います。

投稿2018/03/07 13:02

coco_bauer

総合スコア6915

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Zaganchan

2018/03/08 06:54

ご回答ありがとうございます。 一点お伺いしたいのですが、 >CからSにコネクションを確立するためには、SのListen portにパケットを送る事が出来れば十分なのです。逆の言い方をすると、SのListen portがCからのパケットを受信できなければ(ファイアウォールで阻止されれば)、CはSとTCPでの通信が出来ません。 ということは、ポートを塞いだ場合に一切の通信が出来ないという認識でよいでしょうか。 無茶で無意味な話なのは承知の上なのですが、CからSへの処理要求通信を通して、Sで処理が終わった後に帰ってくる応答だけをブロックしたいのです。(イメージからして間違っていたらすみません。) ポートが閉じられており、TCPの通信確立の際、ACKに対してSYN/ACKが帰ってこない時点でRSTが発行され通信が終了してしまうため、そもそも処理要求なんて送れない、という認識で問題ないでしょうか。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問