質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

88.03%

Dockerfileの書き方 RUNでシェルを走らせるか、COPYしたsetup.shを動かすのか、メリット・デメリットを知りたい。

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 306

score 77

Dockerを学び始めた初心者です。

Dockerfileでいろいろインストールするときに、DockerfileにRUNコマンドを書いて、インストールしたり、設定したりとするのがよいのか、予め実行させる処理をシェルスクリプトにまとめ、ファイルとしてCOPYコマンドでtmpなどに入れて実行させるのか、どちらが良いのでしょうか。

私としては、Dockerのコンテナはできる限り何もない状態にしておき、runするときにシェルを動かして、imageを使い回せるような形にするのが正解かと思っていたのですが、けっこうDockerfile内のRUNで設定している人も多いようで、どちらが最適なのかわかりません。

結局は、imageを使い回すような処理は書くことはなさそうだとも感じています。

良い点、悪い点など教えていただけますと幸いです。

よろしくおねがいします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

check解決した方法

-1

回答のコメント欄で私の勘違いがわかったのでそちらをまとめます。

ENTRYPOINTや、CMDの処理がdocker startするたびに実行されてしまうということが理解できていませんでした。全部シェルスクリプトに書いていました。

試したところ、シェルで実行させていた処理は、毎回コンテナを立ち上げるたびに初期化されていました。

@matsuandさん
RUNはイメージビルド時に実行されるコマンド、CMDはコンテナ内にてイメージが実行される際に実行されるコマンド。利用目的が異なると思います。コンテナを再起動したときのことを考えると違いが明らかで、(変更点がなければキャッシュが効くので)再実行されなくてよいコマンドが RUN、(再)実行されて欲しいコマンドが CMD ではないですか?(CMDはイメージビルド時には実行されません。)

  • 再実行されなくてよいコマンドが RUN
  • (再)実行されて欲しいコマンドが CMD(CMDはイメージビルド時には実行されません。) もしくはENTRYPOINT。

シェルスクリプトにしかかけないことをシェルスクリプトに書くべきで、それ以外はDockerfileに書くべきと結論づけました。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

-1

Dockerfileはdocker-composeとセットで使う事がほとんどだと思うけど、Dockerfile内では.envやdocker-compose.ymlで設定した引数を利用出来るのでRUNの一部として利用出来ます
動的に変数を作り、それをRUNに使う事も出来ます

対して予め用意したシェルスクリプトだとそれが出来ません
※シェルの中で環境変数・変数を作って使う事は出来ます
RUNでsedして書き換える事も出来ます

どちらが最適なのかわかりません。

自分のやり易いようにどうぞ
個人利用の範囲ならやり易い方法や好みの方法から始めて不都合があれば適宜手法を変えてけばいいです
ただし他の人にイメージを配布するならシェルスクリプトをエントリーポイントとしてイメージに突っ込むしかないでしょう

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2021/03/18 20:30

    キャッシュが邪魔なら--no-cacheって軽い感じでやってましたけど、キャッシュって重要視しなきゃいけないものですか?dockerに限らずキャッシュは邪魔なら消すっていう扱いしてるんですけど、dockerの場合違うんですか?
    普通に分からないので教えてください

    キャンセル

  • 2021/03/18 21:08 編集

    @hentaiman さん、
    ご質問なら新たに挙げて頂くのが良いかと思いますので、当コメントによりこのスレでの最後とさせて頂きたく思います。キャッシュを利用するのが当たり前と捉えていましたので、適切に説明できるかわかりませんが試みてみます。マルチステージビルドにて共通ベースイメージを利用する場合、キャッシュを利用してビルド時間短縮が図られる例があります。またCI(継続的インテグレーション)に適していると言われます。環境変更や依存パッケージの更新などにおいてレイヤーキャッシュのうち必要なものだけが再ビルドされます。これもキャッシュがあれば再ビルドの所要総時間を減らすと考えられます。

    キャンセル

  • 2021/03/18 22:15

    > マルチステージビルドにて共通ベースイメージ

    なるほど!確かに!

    > ご質問なら新たに挙げて頂くのが良いか
    回答に対するツッコミだったので、誤っている点を正確に知りたくて聞いただけなので、特に新たに質問して訊きたい事ではありません。
    ですので、コメントではなく回答をされていれば特に質問はしなかったです。
    今回はキャッシュを活かすパターンが聞けて良かったです。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 88.03%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • トップ
  • 最適化に関する質問
  • Dockerfileの書き方 RUNでシェルを走らせるか、COPYしたsetup.shを動かすのか、メリット・デメリットを知りたい。