Dockerコンテナの自動終了を停止する方法の詳細な説明

Dockerコンテナの自動終了を停止する方法の詳細な説明

この記事では、Docker コンテナとフロントエンド プロセスの関係と、コンテナを永続的に実行できるように Dockerfile/docker-compose.yml を記述する方法について簡単に説明します。

Docker コンテナのライフサイクルは、コンテナ内の前のプロセスと関連しています。そのため、数秒実行しただけで自動的に終了するコンテナがいくつかあることがあります。コンテナ内に常駐する前のプロセスがないため、前のプロセスが終了するとコンテナは自動的に終了します。

例えば、docker hello-world

# フラッシュでいろいろ出力 docker run --name hello-world hello-world
# hello-worldコンテナが終了したことがわかります docker ps -a

では、コンテナが自動的に終了するのを防ぐにはどうすればよいでしょうか? alpine/centos/ubuntu などの純粋なコンテナにログインしたい場合は、そのベースにいくつかのサービス コンポーネントをインストールし、それを独自のイメージにコミットします。

インターネット上には、コンテナの作成時に while(true) 無限ループ (もちろん sleep) を実行したり、tail -f /dev/null などを使用したりする方法が多数あります。いずれにせよ、目的は永続的なフロントエンド プロセスを開始することです。実際、docker コンテナの interactive および tty パラメータをよりエレガントに使用して、sh/bash (*nix システムに必須) コマンドを事前コマンドとして起動し、コンテナが自動的に終了しないようにすることができます。

たとえば、alpine イメージをベース イメージとして使用し、小さな alpine システム コンテナーを作成して永続的に実行できるようにし、ログインして特定のコマンドを対話的に実行できるようにします。

# alpine システムイメージを使用してコンテナを作成します # -i interactive=true で stdin を開きます
# -t tty=true はセッションターミナルを割り当てます# -d デーモンモードは省略でき、コンテナに直接入ることができます。終了するには ctrl+p+q を押す必要があります# 終了できません。終了は sh セッションを終了するのと同じで、コンテナは終了しますdocker run -it -d --name alpine alpine sh
# alpine は docker ps を実行している必要があります
# コンテナにログイン docker exec -it alpine sh
# apline はパッケージ管理として apk を使用します# 小さなトレインをインストールします# docker commit -m "alpine with sl cmd" -a "big_cat" alpine big_cat/alpine_sl を使用して新しいイメージ apk add sl を生成できます
# コンテナを終了します。注: -d のみ使用できます。-d を使用して sh ターミナルを直接起動しないと、終了できません。そうしないと、コンテナも終了します。

コンテナの変更を送信して新しいイメージを生成する

docker commit -m "alpine with sl cmd" -a "big_cat" alpine big_cat/alpine_sl
Docker イメージ
# アカウントをお持ちの場合は、docker hub に公開します: docker push big_cat/alpine_sl

# 後でコンテナを停止/起動するときに -it パラメータを指定する必要はありません。docker stop alpine
docker スタートアルパイン

コンテナの変更を送信して新しいイメージを生成する

docker commit -m "alpine with sl cmd" -a "big_cat" alpine big_cat/alpine_sl
Docker イメージ
# アカウントをお持ちの場合は、docker hub に公開します: docker push big_cat/alpine_sl

上記のコマンドは、コンテナが自動的に終了しないように、実際には sh/bash セッション ターミナルをフロント プロセスとして使用します。

コンテナを作成するときにこのように書くのは乱暴だと思うなら、それは問題ではありません。これをすべてdocker-composeにプッシュすることができます。
ドッカーの作成

バージョン: '3'

サービス:
  ビッグキャットアルパイン:
    コンテナ名: big_cat_alpine
    画像: アルパイン
    stdin_open: true # -i インタラクティブ
    端末: 真 # -t 端末
    特権: true
    エントリポイント: ["sh"] # sh を実行する

コンテナを作成してコンテナにログインする

実行ファイル:
ドッカーps
docker exec -it big_cat_alpine sh

2 つのパラメータを docker-compose に渡し、オーケストレーション後にサービス コンテナを起動します。

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

以下もご興味があるかもしれません:
  • Dockerコンテナ内の設定ファイルの変更の実装
  • spring-boot と docker-java に基づいて Docker コンテナの動的な管理と監視を実装します [完全なソース コードのダウンロード付き]
  • Linux 上で Docker コンテナを作成、一覧表示、削除する方法の概要
  • Dockerコンテナアプリケーションログの表示方法
  • Dockerコンテナのログ処理の詳細な説明
  • dockerコンテナがIP経由でホストマシンにアクセスできない問題を解決する方法の詳細な説明
  • Dockerコンテナを使用してホストネットワークにアクセスする方法
  • Dockerコンテナの操作手順の概要と詳細説明

<<:  MYSQL ログとバックアップおよび復元の問題の詳細な説明

>>:  Reactは感情を使ってCSSコードを書く

推薦する

vue+drf+サードパーティのスライディング検証コードアクセスの実装

目次1. 背景2. 検証プロセス3. 検証を作成する4. フロントエンドコード4.1 コアjsファイ...

JavaScript が Jingdong の虫眼鏡効果を模倣

この記事では、Jingdongの虫眼鏡効果を実現するためのJavaScriptの具体的なコードを紹介...

開発効率の向上に役立つ 56 個の実用的な JavaScript ツール関数

目次1. デジタルオペレーション(1)指定された範囲内で乱数を生成する2. 配列操作(1)配列の順序...

JavaScript における正規表現の実際的な応用の詳細な説明

実際の業務では、JavaScript の正規表現が依然として頻繁に使用されます。したがって、この部分...

プロファイルを使用して遅い SQL を分析する MySQL の詳細な説明 (グループ左結合はサブクエリよりも効率的です)

プロファイルを使用して遅いSQLを分析するMySQL の SQL パフォーマンス アナライザーの主な...

MySQL 5.6.22 のインストールと設定方法のグラフィックチュートリアル

このチュートリアルでは、MySQL5.6.22のインストールと設定方法の具体的なコードを参考までに共...

MySQL データ型の完全分析

データ型: 列に格納できるデータとそのデータが実際にどのように格納されるかを定義する基本ルール。デー...

iframe ページで js 関数を呼び出すには js を使用します

最近、私は毎日論文提案に取り組んでいます。自分のスキルを発揮して、再びWebをデザインしたくてうずう...

ユーザーはその理由を知る必要がある

証券会社にいた頃、設計業務が忙しくなかったため、商品のマニュアルを書く役割を担ったことがありました。...

Vueはechartsに基づいて3次元の縦棒グラフを実装します

3次元縦棒グラフは、正面、右側、上部の3つの部分で構成されています。描画するときは、正面をグラフィッ...

Linux での MySQL 5.7.19 のインストールに関する問題の概要

初めて仮想マシンに MySQL をインストールしたとき、多くの問題が発生しました。ここでそれらを書き...

tomcat をインストールし、Linux で Web サイトを展開します (推奨)

jdk をインストールします: Oracle 公式ダウンロード https://www.oracl...

JS を使用して要素が配列であるかどうかを判断する例

検証できるデータの種類は次のとおりです a = [1,2,3,4,5,6]とします。 b = [とし...

CentOS 8が利用可能になりました

CentOS 8 が利用可能になりました! CentOS 8 と RedHat Enterprise...

MySql への新しいユーザーの追加、ユーザー用のデータベースの作成、ユーザーへの権限の割り当ての概要

1. 新しいユーザーを追加するローカルIPアクセスのみを許可する '123456' ...