Docker サーバーへの TFTP 接続がタイムアウトしました。

Docker サーバーへの TFTP 接続がタイムアウトしました。

インストールしようとしています。職場での学習練習としてDocker(Windows用boot2docker経由)を使用します。 FOGにはすべてをインストールし、Ubuntuサーバーでうまく動作する便利な小さなスクリプトがありますが、Dockerで実行するのに問題があります。

FOGが推奨するバージョンであるUbuntu 12.04を使用しました。すべてがうまくいくようです。tftp localhostコンテナ内のファイルが利用可能で、Windows 8.1ホスト(たとえば)でtftpを使用してコンテナからファイルをインポートgetできますが、別のシステムで同じ操作を実行しようとすると、今後の時間です。gettftp 127.0.0.1 GET boot.txt

私は以下を試しました:

  • boot2docker で UDP ポート 69 を開きます (VirtualBox > boot2docker-vm> 設定 > ネットワーク > ポート転送 > UDP ポート 69 を追加する)しかし、これはシステムのIPアドレスです))
    • また、Wiresharkを見ると、TFTPデータから見た58162、43595、および59037を含む複数のUDPポートが追加されました。結論として、私はWindows 8.1で昇格された権限と昇格されていない権限でこれを試しました。
  • Windows 8.1 の両端でファイアウォールを完全に無効にします。
  • VirtualBoxのネットワークタイプをブリッジモードに設定します(以前と同じようにNAtに戻ります)。
  • Docker内でtcpdumpを使用して、パケットがリモートシステムから着信していることを確認します。 (しかし、サーバーは応答を送信していますが、パケットはコンテナから出ません。)
  • Wiresharkを使用してWindows 8.1でトラフィックを見つけます。リモートコンピュータからのTFTPデータを表示できますが、リモートコンピュータに応答が返されません。
  • Ubuntuにファイアウォールがあることを確認してください(いいえ、Dockerの非常にシンプルなバージョンです)。
  • 別のコンピュータからFOGのWebインターフェイスにアクセスしてみました。 (うまくいきます。FOGに新しい画像を追加できます。)
  • Dockerの空のUbuntuインストールにTFTPサーバーをインストールしてみてください(例:FOGインストールスクリプトを実行しない)。または
  • 私のイメージを実行して-p 69:69/udpポートのパススルーを明示的に許可します。
  • UDP ポート 69 を明示的に公開するには、iptables をインストールします。
  • ポート69がブロックされていることを確認するために、作業ネットワークのファイアウォールとスイッチを確認しました。ブロックされていません(TFTPトラフィックがDockerホストに到達したため)。
  • 私は所有者から走ったtftp <ip address of another machine on the network running Wireshark> GET boot.txt。 TFTPトラフィックが着信していることを確認します(ただし、TFTPサーバーを実行していないためエラーを返します)。
  • 以前はFOGをサーバー上で実行していましたが、後で電子メールサーバーなどにさらにリソースを提供するために廃棄されました。
  • Ubuntu 14.04ラップトップでDockerイメージを試してみました(したがって14.04をホ​​ストとして使用し、Dockerコンテナをゲストとして使用)、うまくいったので、問題はWindowsにあるようです。ここでどこに行くべきかわからない。

したがって、問題はTFTPパケットがWindowsをエスケープできないようです(ただしHTTPトラフィックはエスケープします)。

どんな提案がありますか?

答え1

最後に、Dockerイメージを近くのUbuntuノートブックに移動しました。今私のTFTPサーバーは修正なしで完全に実行されるので、問題はVirtualbox、Windows、またはboot2dockerに関連していることがほとんど確実です(最後の問題はわかりませんが)。

私の質問をより関連性の高いstackexchangeに投稿する予定です(これはDockerの問題ではないことを知っています)、答えを得たら、他の人が恩恵を受けるようにこの質問を更新します。

関連情報