Dockerイメージの階層化の原理の詳細な説明

Dockerイメージの階層化の原理の詳細な説明

ベースイメージ

ベースイメージには 2 つの意味があります。

  • 他のイメージに依存せず、ゼロから構築します
  • 他の画像も拡大できます

したがって、ベースイメージは通常、Ubuntu、Debian、CentOS などのさまざまな Linux ディストリビューションの Docker イメージです。

ベース イメージは、最小限のインストールで Linux ディストリビューションを提供します。

ほとんどのイメージはベースイメージに基づいて構築されます。そのため、通常は公式にリリースされたベースイメージが使用されます。 Docker Hub で見つけることができます。たとえば、centos: https://hub.docker.com/_/centos

Docker ベースイメージを自分で構築することも、既存のベースイメージを直接使用することもできます。たとえば、centos。 Docker Hub から直接プルできます。
引く

docker プル CentOS

チェック

docker イメージ Centos 
リポジトリ タグ イメージ ID 作成 サイズ
centos 最新 1e1148e4cc2c 2か月前 202MB

最新の CentOS イメージは 200 MB しかないことがわかります。小さすぎると思いますか?これは、Docker イメージが実行時に Docker ホスト マシンのカーネルを直接使用するためです。

Linux オペレーティング システムは、ユーザー空間とカーネル空間で構成されています。

カーネル空間はカーネル、ユーザー空間は rootfs です。異なるディストリビューション間の違いは主に rootfs です。たとえば、Ubuntu 14.04 ではサービス管理に upstart を使用し、ソフトウェア パッケージの管理に apt を使用しますが、CentOS 7 では systemd と yum を使用します。これらはユーザー空間での違いであり、カーネルには大きな違いはありません。

したがって、Docker は複数の Linux イメージを同時にサポートし、さまざまなオペレーティング システム環境をシミュレートできます。

ベースイメージには同じユーザー空間とリリースバージョンのみが含まれており、カーネル空間では Docker ホストマシンのカーネルが使用されます。

ストレージ構造

上記はベースイメージをダウンロードする方法を示しています。通常、このベースイメージに基づいて独自のイメージを構築します。たとえば、CentOS に nginx ロード バランシングを追加します。まず、画像の構造がどのようなものかを理解する必要があります。

公式ドキュメント: https://docs.docker.com/storage/storagedriver/

Dockerイメージのレイヤー構造

画像を開始すると、新しい書き込み可能なレイヤーが画像の上に読み込まれます。このレイヤーは通常「コンテナ レイヤー」と呼ばれ、その下には「イメージ レイヤー」があります。

コンテナ レイヤーは読み取りと書き込みが可能で、コンテナ内のすべてのファイルの変更と書き込みはこのレイヤーで行われます。イメージレイヤーは読み取り専用で、読み取りのみが許可されます。

コピーオンライト

Docker は、変更時のコピー戦略を使用して、ベースイメージのセキュリティを確保するとともに、パフォーマンスとスペースの使用率を高めます。

  • コンテナがファイルを読み取る必要がある場合

一番上の画像レイヤーから下に向かって検索します。見つかったらメモリに読み込みます。すでにメモリ内にある場合は、そのまま使用できます。つまり、同じマシン上で実行されている Docker コンテナは実行時に同じファイルを共有します。

  • コンテナがファイルを変更する必要がある場合

上から下まで検索し、見つかったらコンテナ レイヤーにコピーします。コンテナの場合、コンテナ レイヤーのファイルは表示されますが、イメージ レイヤーのファイルは表示されません。その後、コンテナ レイヤーのファイルを直接変更できます。

  • コンテナがファイルを削除する必要がある場合

上から下まで検索し、見つかったらコンテナに削除を記録します。これは実際の削除ではなく、ソフト削除です。これにより、画像のサイズは減少するのではなく、増加するだけです。

コンテナにファイルを追加する必要がある場合、イメージ レイヤーに影響を与えることなく、最上位のコンテナ書き込み可能レイヤーに直接追加されます。

画像の合理化と最適化

ベースイメージの最適化

ベース イメージを選択するときは、適切な小さいイメージを選択します。一般的に使用される Linux システム イメージには、Ubuntu、CentOs、Alpine などがあります。

Dockerfile命令の連鎖

Dockerfile では、各命令によってイメージ レイヤーが作成され、イメージのサイズが増加します。現在のレイヤーへの変更は、前のレイヤーには影響しません。

  • && を使用して命令を連結します(RUN命令内)
  • ソフトウェアをインストールした後は必ずクリーニングしてください

具体的な例は以下のとおりです。

カスタム Dockerfile:

ubuntu:14.04から
#基本ソースイメージ MAINTAINER xiongkun
#イメージの作成者、名前、メールアドレスを記入してください WORKDIR /home
実行 dd if=/dev/zero of=50M.file bs=1M count=50
#サイズ50Mのテストファイルを作成する RUN rm -rf 50M.file
#ファイルを削除する

最適化された Dockerfile:

ubuntu:14.04から
#基本ソースイメージ MAINTAINER xiongkun
#イメージの作成者、名前、メールアドレスを記入してください WORKDIR /home
実行 dd if=/dev/zero of=50M.file bs=1M count=50 && rm -rf 50M.file
#ファイルを作成し、同じレイヤーで削除する

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • Docker イメージの階層化に関する詳細な理解 (初心者必読)
  • Dockerイメージレイヤリングの実装を徹底的に理解する
  • Docker イメージの階層化と Dockerfile の記述スキル
  • Dockerファイルの階層化の原則の詳細な分析

<<:  JavaScript における変数と関数の昇格の詳細な例

>>:  SQLクエリの実行順序をゼロから学ぶ

推薦する

Windows で mysql5.7.21 をインストールするための詳細なチュートリアル

この記事では、参考までにMySQL 5.7.21のインストールチュートリアルを紹介します。具体的な内...

MYSQL(電話番号、IDカード)データ非感応化の実装

1. データ感度低下の説明日常の開発ニーズでは、データの感度低下が頻繁に発生します。たとえば、ID ...

XHTML チュートリアル: 初心者のための XHTML の基礎

<br />当サイトのオリジナルコンテンツですので、転載の際は出典を123WORDPRE...

非常に詳細な基本的なJavaScript構文ルール

目次01 JavaScript(略称:js) js は 3 つの部分に分かれています。 JavaSc...

EChartsマルチチャート連携機能の実装プロセス

表示するデータが多い場合、1 つのチャートに表示しても効果はよくありません。このとき、2 つのチャー...

Linux システムに docker をインストールし、ssh 経由で docker コンテナにログインする方法

注: 私はCentosを使ってdockerをインストールしていますステップ1: Dockerをインス...

Linux で Apache を使用してファイル サーバーを構築する手順

1. ファイルサーバーについてプロジェクトでは、公開ソフトウェアやデータをプロジェクト チーム メン...

Ubuntu 18.04 のインストールで「ldlinux.c32 のロードに失敗しました」というエラーが表示され、解決手順がわかりません

序文私は Win7 を搭載した古いラップトップを持っています。古いシステムを維持しながら、同時に U...

Docker で Python スクリプトを実行する方法

まず、Docker イメージ用の特定のプロジェクト ディレクトリを作成します。例: mkdir /h...

Tomcat は親の委任メカニズムを破壊して Web アプリケーションの分離を実現します。

目次Tomcat クラスローダー階層WebAppクラスローダー共有クラスローダーカタリナクラスローダ...

Nginx がフロントエンド リソースへのクロスドメイン アクセスの問題をどのように解決するかの詳細な説明

フロントエンドのクロスドメイン問題に2日間近く悩まされましたが、ようやくngnxを使って解決したので...

子ども向けウェブサイトの視覚構造レイアウト設計手法の分析

1. 温かくて優しい関連アドレス: http://www.web-designers.cn/post...

Vueモバイル端末の適応化問題の詳細説明

1. vue uiでプロジェクトを作成する 2. 基本設定項目を選択する 3. プロジェクトを実行す...

JavaScript クリップボードの使用法の詳細な説明

(1)はじめに: clipboard.js は、テキストをクリップボードにコピーする機能を実装する軽...

JavaScriptはキャンバスを使用して座標と線を描画します

この記事では、JavaScriptでキャンバスを使用して座標と線を描く具体的なコードを参考までに紹介...