序文Kubernetes では、コンテナは Pod でデプロイおよび管理されます。 Pod は、Kubernetes オブジェクト モデル内で作成、デプロイ、管理できる最小かつ最もシンプルな単位です。ここでは、単一のポッド内で異なるコンテナ タイプを使用して、特定の機能を実装できます。 Kubernetes で使用される一般的なコンテナ タイプを次に示します。
初期化コンテナPod では、アプリケーションを実行するために複数のコンテナを実行できますが、アプリケーション コンテナが起動する前に実行される 1 つ以上の init コンテナも実行できます。 Init コンテナは、メイン アプリケーション コンテナが起動する前に初期化タスクを実行するように設計されています。これらは、構成ファイルの設定、データベースの初期化、外部サービスの準備完了の待機などのタスクに使用できます。 Init コンテナは、次の点を除いて、通常のコンテナとまったく同じです。
場合
ここでの init-container は、データ ボリューム データを使用して、nginx ホームページの index.html を上書きします。 サービスオーケストレーションファイル
ポッドとサービスを作成する
ここで、ブラウザから nginx エンドポイントにアクセスしようとすると、次の出力が表示されます。 画像 サイドカーコンテナサイドカー コンテナは、メイン アプリケーション コンテナと同じ Pod で実行されるセカンダリ コンテナです。これらのコンテナーは、メイン アプリケーション コードを直接変更せずに、ログ記録、監視、セキュリティ、データ同期などの追加のサービスや機能を提供することで、メイン アプリケーション コンテナーの機能を強化または拡張するために使用されます。 サイドカー コンテナを使用する例:nginx-sidecar.yaml を作成します: 上記の Pod には 2 つのコンテナが含まれています。1 つはアプリケーション コンテナ (nginx) で、もう 1 つはメイン アプリケーションの nginx アクセス ログを収集するために使用するサイドカー コンテナです。 nginx-svc.yaml を作成します: ポッドとサービスを作成する
ブラウザから nginx エンドポイントにアクセスしようとすると、nginx のウェルカム ページが表示されます。次に、以下のコマンドを使用してサイドカー ログにアクセスしようとすると、最新のアクセスのアクセス ログが取得されます。 一時コンテナエフェメラル コンテナーは、リソースや実行の保証がなく、自動的に再起動されることがないため、アプリケーションの構築には適していないという点で他のコンテナーとは異なります。エフェメラル コンテナーは通常のコンテナーと同じ ContainerSpec を使用して記述されますが、多くのフィールドはエフェメラル コンテナーに対して互換性がなく、禁止されています。 エフェメラル コンテナーにはポートがない場合があるため、ポート、ライブネス プローブ、準備プローブなどのフィールドの使用は禁止されています。 Pod リソースの割り当ては不変であるため、リソースの設定は禁止されています。 エフェメラル コンテナは、コンテナがクラッシュした場合やコンテナ イメージにデバッグ ツールが含まれていない場合など、kubectl exec を使用しても問題を解決できない場合に、対話型のトラブルシューティングを行うのに役立ちます。 Pod をデバッグするには 2 つの方法があります。 a.デバッグ用の一時コンテナの使用 Pod は実行中だが実行できない場合は、このアプローチを使用できます。 kubectl debug コマンドを使用して、実行中の Pod に一時コンテナを追加できます。このアプローチでは、同じ Pod 内に新しいコンテナが作成されます。 <podname> を既存の Pod 名に置き換え、<containername> をデバッグする既存のコンテナに置き換えます。このコマンドは、新しい busybox コンテナを追加し、それにアタッチします。 b.デバッグにはポッドのコピーを使用する Pod がクラッシュしてアクセスできない場合は、この方法を使用できます。このアプローチでは、元の Pod のコンテナとともに新しいデバッグ コンテナを含む新しい Pod が作成されます。 元の Pod 名を ORIGINAL-POD に置き換え、新しいデバッグ Pod 名を NEW-DEBUG-POD に置き換えてください。新しいデバッグ Pod は元の Pod のコピーです。 場合ephemeral-pod.yaml を作成します。 この YAML ファイルは、デバッグ ツールなしで一時停止されたコンテナ イメージを作成します。 上記のコマンドは、デフォルトの名前空間に一時的な Pod を作成します。 次のコマンドを使用して実行してみます。 ただし、このコンテナイメージにはシェルがないため、次のエラーが発生します。 ここで、一時コンテナであるデバッグ コンテナを使用して Pod に入ってみましょう。 次のコマンドを使用して、一時コンテナを作成し、それを上記のポッド ephemeral-pod に接続します。 このコマンドは、新しい busybox コンテナを追加し、それを一時ポッドに接続します。 --target パラメータは、実行するコンテナを指定します。さらに、コマンドは一時コンテナのコンソールに自動的に接続します。 出力: これで、実際のコンテナ(一時的なコンテナ)にアクセスしてデバッグできるようになります。 マルチコンテナKubernetes を使用すると、並列に実行される複数のコンテナを持つ Pod を定義できます。コンテナは同じネットワーク名前空間を共有し、localhost 経由で相互に通信できます。これらのマルチコンテナ ポッドは、リソースとデータを共有しながら、密に結合されたプロセスを一緒に実行する必要があるシナリオを対象としています。 場合nginx-multi-container-pod.yaml を作成します。 上記のマニフェスト ファイルには 2 つのコンテナーがあります。1 つはメイン アプリケーション (nginx) で、もう 1 つは nginx Web アプリケーションのホームページを継続的に更新するのに役立つ追加のコンテナーです。 nginx-svc.yaml を作成します: ポッドとサービスの作成
ここで、ブラウザ経由で nginx エンドポイントにアクセスしようとすると、上記の追加コンテナによって更新された日付が表示されます。 |
<<: ビジネスの中断を回避する、K8s ノードのトラブルシューティング ガイド、ぜひご覧ください。
>>: ULID - 分散システムでグローバルに一意な識別子を生成するためのより良い選択肢
私は、朱衛坤が素晴らしい人だと言うためにこの記事を書いているわけではありません。繰り返しますが、私は...
ショートビデオ、セルフメディア、インフルエンサーのためのワンストップサービスリタ・ゼン出典: mor...
[[329658]]導入現在、5 年間稼働している VMware の完全なセットを保有しています。...
この 2 日間、私の友人グループでは、Xiaohongshu を Android アプリ マーケット...
ブラック リンクとは何ですか? ブラック リンクとは、不適切な手段やサードパーティのソフトウェアを使...
[[436204]]背景インターネット時代と環境では、需要に迅速に対応し、システムのスループットを向...
1. 問題JAVA テキスト ファイルはどのようにして CLASS バイナリ ファイルに変換されるの...
たった1日の午後、私は注意を払っていませんでした。子供の世話をしていたのですが、私のQQグループがブ...
[[425938]] Velero (https://velero.io) は、Kubernetes...
[要約] 財務省は、インターネット企業が宝くじを販売するには財務省に申請する必要があると述べており、...
トレーニングの目的: 今日のインターネットの急速な発展により、大量の高品質のトラフィックをウェブサイ...
中国のインターネットは、一言で言えば、上半期にライブストリーミングを推進し、下半期に検索で競争すると...
企業による DevOps の導入は、開発がこれまで以上に高速化することを意味します。では、特にビジネ...
多くの企業のウェブサイト、特にウェディング写真のウェブサイトは、キーワードランキングのみに焦点を当て...
COVID-19パンデミックの発生以来、人々の生活やビジネス運営は根本的に変化しました。この流行によ...