ホームページ 運用・保守 Docker CentOS が Docker ホストにアクセスできない場合はどうすればよいですか?

CentOS が Docker ホストにアクセスできない場合はどうすればよいですか?

Apr 17, 2023 pm 04:41 PM

Docker を使用してコンテナ環境を構築する必要がある開発者にとって、Linux オペレーティング システムで Docker を使用することは良い選択です。ただし、一部のユーザーは、CentOS で Docker を使用するときにいくつかの問題に遭遇する可能性があります。その 1 つは、ホスト マシン経由で Docker にアクセスできないことです。この記事では、この問題が発生する理由を説明し、考えられる解決策をいくつか紹介します。

1. 問題の原因

CentOS に Docker をインストールすると、「docker0」という名前のデフォルトの仮想ブリッジが作成されます。各 Docker コンテナはこのブリッジに接続し、「docker0」IP アドレス範囲の IP アドレスを使用します。このようにして、ホストと Docker コンテナは共有の「docker0」ブリッジを介して通信できます。ただし、CentOS ファイアウォールがデフォルトで正しく構成されていないため、Docker ホストにアクセスできません。これは、CentOS ファイアウォールが他の IP アドレス範囲からの受信パケットをブロックするためです。

2. 解決策

  1. ファイアウォールの構成
    まず、Docker ブリッジ アドレス範囲からのパケットを許可するように CentOS でファイアウォールを構成する必要があります。ファイアウォールを構成するコマンドは次のとおりです。
sudo firewall-cmd --permanent --zone=trusted --add-interface=docker0
sudo firewall-cmd --permanent --zone=trusted --add-source=172.17.0.0/16
sudo firewall-cmd --permanent --zone=trusted --add-source=172.18.0.0/16
sudo firewall-cmd --reload
ログイン後にコピー

上記のコマンドでは、「信頼された」ゾーンを定義し、「docker0」ブリッジを追加しました。さらに、「172.17.0.0/16」および「172.18.0.0/16」の IP アドレス範囲からのパケットがこのゾーンに入ることが許可されます。最後に、「firewall-cmd --reload」コマンドを使用して、新しいファイアウォール ルールがすぐに有効になるようにします。

  1. Docker DNS のセットアップ
    ファイアウォールの問題と同様に、Docker コンテナは DNS 名を正しく解決できません。こうすることで、コンテナーがホストに接続されていても、外部ネットワークにアクセスできなくなります。この問題を解決する 1 つの方法は、Docker コンテナーで DNS を手動で構成することです。

これを行うには、パス「/etc/docker/daemon.json」の下にある Docker 構成ファイルを編集し、次の内容を追加する必要があります:

"dns": ["8.8.8.8", "8.8.4.4"]
ログイン後にコピー

これにより、コンテナ内にある Docker が DNS 名を解決できるように Google DNS を設定します。

  1. Docker のバージョンを確認して更新する
    上記の 2 つの方法に加えて、使用している Docker のバージョンが最新バージョンにアップグレードされていることも確認する必要があります。 Docker のバージョンが古すぎると、予期しない動作やエラーが発生する可能性があります。

Docker のバージョンを確認するには、次のコマンドを入力します。

$ docker version
ログイン後にコピー

Docker の古いバージョンを実行している場合は、次のコマンドを使用してアップグレードできます。

$ sudo yum update docker
ログイン後にコピー

または、Docker が公式に推奨する Yum リポジトリを使用してインストールする場合は、次のコマンドを使用して Docker をアップグレードできます:

$ sudo yum install docker-ce
ログイン後にコピー
  1. Docker ネットワーク構成を確認してください
    最後に、次のことを確認してください。すべての設定が正しいことを確認するための Docker ネットワーク構成。次のコマンドを入力してください:
$ docker network ls
ログイン後にコピー

これにより、すべての Docker ネットワークがリストされます。すべてのネットワークが「docker0」に関連しておらず、正しく構成されていることを確認してください。

概要

CentOS で Docker を使用すると、便利なコンテナ環境を提供できます。ただし、一部のユーザーは別の問題に遭遇する可能性があります。最も一般的な問題の 1 つは、ホストの Visit Docker を通過できないことです。この記事では、ファイアウォール構成、Docker DNS 設定、Docker バージョンの更新、Docker ネットワーク設定の検査など、この問題の解決策について説明します。 CentOS でこの問題が発生した場合は、上記のいずれかの方法を試して解決できます。

以上がCentOS が Docker ホストにアクセスできない場合はどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Dockerインタビューの質問:DevOpsエンジニアリングインタビューをエース Dockerインタビューの質問:DevOpsエンジニアリングインタビューをエース Apr 06, 2025 am 12:01 AM

Dockerは、DevOpsエンジニアにとって必須のスキルです。 1.Dockerは、アプリケーションとその依存関係をコンテナにパッケージ化することにより、分離と移植性を実現するオープンソースのコンテナ化されたプラットフォームです。 2. Dockerは、名前空間、コントロールグループ、フェデレーションファイルシステムで動作します。 3。基本的な使用には、コンテナの作成、実行、管理が含まれます。 4.高度な使用法には、DockerComposeを使用してマルチコンテナーアプリケーションを管理することが含まれます。 5.一般的なエラーには、コンテナ障害、ポートマッピングの問題、データの持続性の問題が含まれます。デバッグスキルには、ログの表示、コンテナの入り、および詳細情報の表示が含まれます。 6.パフォーマンスの最適化とベストプラクティスには、画像の最適化、リソースの制約、ネットワーク最適化、DockerFileを使用するためのベストプラクティスが含まれます。

Dockerボリューム:コンテナ内の永続的なデータの管理 Dockerボリューム:コンテナ内の永続的なデータの管理 Apr 04, 2025 am 12:19 AM

Dockervolumeは、コンテナを再起動、削除、または移行すると、データが安全であることが保証されます。 1。ボリュームの作成:Dockervolumecreatemydata。 2。コンテナとマウントボリュームを実行します:Dockerrun-It-Vmydata:/app/dataubuntubash。 3.高度な使用には、データ共有とバックアップが含まれます。

Dockerの画像を更新する方法 Dockerの画像を更新する方法 Apr 15, 2025 pm 12:03 PM

Docker画像を更新する手順は次のとおりです。最新の画像タグ新しい画像をプルする新しい画像は、特定のタグのために古い画像を削除します(オプション)コンテナを再起動します(必要に応じて)

Dockerによってコンテナを出る方法 Dockerによってコンテナを出る方法 Apr 15, 2025 pm 12:15 PM

Dockerコンテナを終了する4つの方法:コンテナ端子でCtrl Dを使用するコンテナターミナルに出口コマンドを入力しますDocker stop< container_name>コマンドを使用するDocker Kill< container_name>ホストターミナルのコマンド(フォース出口)

Dockerのファイルを外部にコピーする方法 Dockerのファイルを外部にコピーする方法 Apr 15, 2025 pm 12:12 PM

Dockerの外部ホストにファイルをコピーする方法:Docker CPコマンドを使用:Docker CP [Options]< Container Path> <ホストパス>。データボリュームの使用:ホストにディレクトリを作成し、-vパラメーターを使用してコンテナを作成するときにディレクトリをコンテナにマウントして、双方向ファイルの同期を実現します。

Dockerセキュリティ硬化:容量から容器を保護します Dockerセキュリティ硬化:容量から容器を保護します Apr 05, 2025 am 12:08 AM

Dockerセキュリティの強化方法は次のとおりです。1。-cap-dropパラメーターを使用してLinux機能を制限します。2。読み取り専用コンテナを作成します。これらの戦略は、脆弱性の露出を減らし、攻撃者の機能を制限することにより、コンテナを保護します。

Dockerを再起動する方法 Dockerを再起動する方法 Apr 15, 2025 pm 12:06 PM

Dockerコンテナを再起動する方法:コンテナID(Docker PS)を取得します。コンテナを停止します(docker stop< container_id>);コンテナを起動します(docker start< container_id>);再起動が成功していることを確認します(Docker PS)。その他の方法:Docker Compose(Docker-Compose Restart)またはDocker API(Dockerドキュメントを参照)。

Dockerデスクトップの使用方法 Dockerデスクトップの使用方法 Apr 15, 2025 am 11:45 AM

Dockerデスクトップの使用方法は? Dockerデスクトップは、ローカルマシンでDockerコンテナを実行するためのツールです。使用する手順には次のものがあります。1。Dockerデスクトップをインストールします。 2。Dockerデスクトップを開始します。 3。Docker Imageを作成します(DockerFileを使用); 4. Docker画像をビルド(Docker Buildを使用); 5。Dockerコンテナを実行します(Docker Runを使用)。

See all articles