コンテナが企業の IT インフラストラクチャに欠かせない要素となっていることは間違いありません。コンテナには次のような多くの利点があります。
しかし、多くのユーザーは依然としてコンテナを一般的な仮想マシンのように扱い、コンテナには使い捨てであるという重要な特性があることを忘れています。 この特性により、ユーザーはコンテナの取り扱いと管理方法に関する視点を変える必要に迫られます。では、コンテナを最良の状態に保つにはどうすればよいでしょうか? Docker コンテナで避けるべき 10 のことを紹介します。 1. コンテナにデータを保存しない コンテナを停止、破壊、または交換できるためです。コンテナ内で実行されているアプリケーションのバージョン 1.0 は、影響やデータ損失なしに、バージョン 1.1 に簡単に置き換えられる必要があります。したがって、データを保存する必要がある場合は、バッチで保存します。この場合、2 つのコンテナーが同じボリュームにデータを書き込むと破損する可能性があるため、注意が必要です。アプリケーションが共有データ ストアに書き込むように設計されていることを確認してください。 2. アプリケーションを2部に分けて提出しない コンテナを仮想マシンのように考える人もいますが、ほとんどの人は、実行中の既存のコンテナにアプリケーションをデプロイする必要があると考えがちです。開発フェーズでは、継続的にデプロイとデバッグを行う必要があります。これは当然のことです。ただし、QA および本番環境向けの継続的デリバリー (CD) パイプラインの場合、アプリケーションはイメージの一部である必要があります。 3. 大きな画像を作成しない 大きな画像は配布しにくいからです。アプリケーション/プロセスを実行するために必要なファイルとライブラリのみがあることを確認してください。不要なパッケージをインストールしたり、多くのファイルを新しいイメージ レイヤーにダウンロードする「更新」を実行したりしないでください。 4. 単層画像を使用しない 階層化ファイル システムを効果的に活用するには、オペレーティング システム用の独自のベース イメージ レイヤー、ユーザー名定義用の別のレイヤー、ランタイム インストール用の別のレイヤー、構成用の別のレイヤー、最後にアプリケーション用の別のレイヤーを常に作成します。画像の再作成、管理、配布が容易になります。 5. 実行中のコンテナからイメージを作成しない つまり、イメージを作成するために「docker commit」を使用しないでください。この画像作成方法は再現不可能なので、完全に避けるべきです。常に完全に再現可能な Dockerfile またはその他の S2I (ソースからイメージ) アプローチを使用してください。Dockerfile をソース管理リポジトリ (git) に保存すると、Dockerfile への変更を追跡できます。 6. 「最新」タグだけを使うのはやめましょう Maven ユーザーにとって、最新のタグは「スナップショット」のようなものです。コンテナの階層化ファイルシステムの性質上、タグの使用が推奨されます。数か月後にイメージをビルドし、親レイヤー (Dockerfile の FROM) が下位互換性のない、またはバグのある新しいバージョンに置き換えられ、ビルド キャッシュから「最新」バージョンが取得されたためにアプリケーションが実行されないことがわかっても、驚くことはありません。また、コンテナを本番環境にデプロイするときには、「最新」タグの使用を避ける必要があります。そうしないと、実行しているイメージのバージョンがわからなくなってしまいます。 7. 単一のコンテナ内で複数のプロセスを実行しないでください。 コンテナは単一のプロセス (http デーモン、アプリケーション サーバー、データベース) を実行するのに最適ですが、複数のプロセスがある場合は、プロセスを個別に管理、ログを取得、更新するのが難しくなる可能性があります。 8. 資格情報を画像に保存しないでください。 環境変数を使用してください。イメージ内にユーザー名やパスワードをハードコードしないでください。環境変数を使用して、コンテナ外部からその情報を取得します。この原則の良い例は、Postgres ミラーリングです。 9. プロセスをルートとして実行しない 「デフォルトでは、Docker コンテナはルート ユーザーとして実行されます。Docker が成熟するにつれて、より安全なデフォルトが提供される場合があります。現在、ルート ユーザーを要求することは他のユーザーにとって危険であり、すべての環境で利用できるとは限りません。イメージでは、USER ディレクティブを使用して、コンテナを実行するための非ルート ユーザーを指定する必要があります。 10. IPアドレスに頼らない 各コンテナには独自の内部 IP アドレスがあり、コンテナを起動および停止すると変更される可能性があります。アプリケーションまたはマイクロサービスが別のコンテナと通信する必要がある場合は、環境変数を使用して、正しいホスト名とポートをあるコンテナから別のコンテナに渡します。 上記は、Docker コンテナのアプリケーションにおける 10 の悪い習慣の詳細です。Docker コンテナのアプリケーションの詳細については、123WORDPRESS.COM の他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
>>: vue+openlayer をベースにマップの集約と散乱効果を実現
目次Centosイメージを取得するCentos ベースの nginx コンテナを生成するCentos...
1998 年の CSS2 勧告の時点で、テーブルは徐々に舞台から消え、歴史の中に記録されるようになり...
イメージを作成する方法は 3 つあります。既存のイメージに基づいてコンテナを作成する、ローカル テン...
問題の起源docker を使用する場合、残念ながら docker コンテナ内のホストのポート 80 ...
今日、クライアントが広告を掲載したいのですが、提供された素材は Flash です。私たちはあまり気に...
以下のように表示されます。主に認証コマンドを実行します: 2つの方法1. 任意のホストがユーザー b...
目次1. インデックス署名とは何ですか? 2. インデックス署名構文3. インデックス署名に関する注...
fd コマンドは、Linux ファイル システムを検索するためのシンプルで簡単な方法を提供します。...
MacOS Catalina アップグレード後の VMware ブラック スクリーンに対する完璧なソ...
序文インデックスの選択はオプティマイザ段階の作業であることはわかっていますが、オプティマイザは万能で...
エディターは、Vue3のデータの関連する問題も共有します。次のような例を見てみましょう。 Vue.c...
今日システムを再インストールした後、コンピューターに mysql を再インストールし、ZIP ファイ...
MySQL フルバックアップ1. バイナリログを有効にし、データベースから分離して別々に保存する v...
初心者は、いくつかの HTML タグを理解することで HTML を学習できます。この入門書は、初心者...
目次01-イベントバブリング1.1- イベントバブリングの概要1.2-イベントバブリングの利用(イベ...