序文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 - 分散システムでグローバルに一意な識別子を生成するためのより良い選択肢
最近、Tencent Cloudは「クラウド+ベンチャーキャピタルアライアンス」の設立を発表しました...
私が初めて SEO 業界に入ったとき、多くのことについてまだ無知でした。ウェブサイトの最適化能力を向...
昨日、cloudcone からプロモーション メールを受け取りました。このメールには、米国西海岸のロ...
itnuthosting は 2009 年に設立されたバングラデシュのホスティング会社で、主にドメイ...
21日、百度は新しいウェブサイト外部リンク検出ツールをリリースしました。多くの人がこの件に注目してい...
2月12日、陸松松氏は以前自身のブログで宣伝していたブログコメント宣伝手法を公に否定し、「この宣伝手...
イーサネット ネットワーキングの業界リーダーである Cumulus Networks の主任科学者で...
インターネットプロモーションは、今日企業が行わなければならない仕事の一つです。インターネット時代にお...
長らく噂されていた「生鮮食品電子商取引第一号株」がついに明るみに出た。最近、生鮮食品小売分野のリーダ...
オープンソースの詳細については、以下をご覧ください。 51CTO オープンソース基本ソフトウェアコミ...
石玉珠のオークションは3時間で2130万9150元で落札され、優美網は「プラットフォーム運営費」とし...
Hivelocityはどうですか? Hivelocity VPS はいかがでしょうか? Hivelo...
以前共有されたコンテンツは、ブランドキーワードの最適化、ナレッジ検索マーケティング、QQグループのプ...
約 2 年前、私たちは EC2 にアプリケーションをデプロイするための Ansible ベースの構成...
eName.cnは4月15日、海外メディアの報道によると、決済ドメイン名youpay.comが最近、...