Docker iconイメージ

Docker

既存のDockerコンテナにモジュールを追加したいときのメモ|Docker requirements.txtの更新を反映する

Dockerを触っていると、最初に環境を作ったときは「これで十分!」と思ったのに、数日後には「やっぱりあのモジュール必要だったわ…」なんてこと、よくありますよね。

まるで冷蔵庫の中身を確認せずにカレーを作り始めて、「にんじんがない!」と気づくあの瞬間に似ています。

さて、そんなときに必要なのが requirements.txt の更新です。

Python系のプロジェクトではおなじみのこのファイルに、新たに必要になったモジュールを追記していきます。

実際の手順

  1. requirements.txt に欲しいモジュールを追記する。 (例:pandas==2.2.0 とかを追加)
  2. その後、Dockerコンテナを作り直す必要があります。

つまり、こういう流れになります

docker-compose down
docker-compose build
docker-compose up -d

なぜこの流れが必要?

  • down : いったんコンテナを停止&削除。中途半端な状態をクリアにします。
  • build : 新しい requirements.txt を取り込んでイメージを再構築。
  • up -d : バックグラウンドで新しいコンテナを起動。

つまり、「一度冷蔵庫を空にして、新しい材料で作り直す」イメージですね。

余談|もっとスマートにできないの?

もちろん方法はいくつかあります。

  • コンテナ内に直接 pip install してしまう手もありますが、それだとDockerの再現性が崩れるので非推奨。
  • 本番環境やチーム開発なら、必ず requirements.txt を更新して ビルドからやり直すのが安全です。

もし「停止せずに差分だけ反映したい」という場面では、以下を使うと、down → build → up をある程度まとめてやってくれます。

ただし、キャッシュや古い依存関係が邪魔して「アレ?更新されてないぞ…」となる場合があるので、確実さを優先するなら上記の三手順が一番安牌です。

## 停止せずに差分だけ反映したい
docker-compose up -d --build

まとめ

  • 追加モジュールが必要になったら requirements.txt に追記。
  • その後は docker-compose down → build → up -d の三連コンボで再構築。
  • 「あとから欲しくなるモジュール」は珍しくないので、慌てず手順で対応。

「なんで入ってないの!?」と慌てるときも、落ち着いて再ビルドすればOKです。

今日の一杯

今日の一杯 赤ワイン

2025/7/7

フェウド・アランチョ ネロ・ダーヴォラ レビュー|今日の一杯 赤ワイン

「フェウド・アランチョ ネロ・ダーヴォラ」は、味わい深く、コスパの良い、安定した品質の一本です。 トマト系の煮込み料理や、チーズをたっぷりのせたラザニアとも合い、もちろん、静かな夜にひとりでグラスを傾ける時間にもぴったり。 海外の専門家たちからも高評価を得ており、日常使いからしっかりした食事まで汎用的に活躍します。 味と風味 口に含むと、熟したダークベリーやラズベリーの果実味が広がりながら、後半にかけてほんのりドライハーブのような余韻が続きます。 酸味は控えめで、タンニンはしっかりしています。 飲みごたえ ...

続きを読む

エナジードリンク 今日の一杯

2025/6/30

ZONe ENERGY ABSOLUTE VICTORY 勝 レビュー|今日の一杯 エナジードリンク

ZONe ABSOLUTE VICTORYは2025年1月に発売されたエナジードリンクです。 受験勉強をイメージしたデザインの商品で、学問の神様として知られる菅原道真公を祀る太宰府天満宮に「HYPER ZONe 」を奉納し、受験生の合格を祈願しているそうです。 寒い冬に体を温めるように、成分にジンジャーシロップが配合されており、堅調に生姜の味がします。 カナダドライのジンジャーエールとはまた違う、比較的マイルドな飲みやすい生姜ジュースといった印象です。 ZONeの1本あたりのカフェイン量は75mgとコーヒ ...

続きを読む

  • この記事を書いた人

朝倉卍丸

シングルモルトスコッチなどのお土産を持ってきた人を助けるのが好きです。サービスの分割が重要ですが、まあ昔ながらの方法でやりたいこともありますよね。

よく読まれている記事

条件の0=0は全てが正であるを意味するSQL 1

SQLの条件に0=0のような記述を見かけます。 変わった書き方の条件ですが、これは「全てが正である」事を意味しており、結合条件の場合はCROSS JOINと同じです。 下記の例で言えば、結合するsub ...

DISTINCTを使わないで重複排除を考えるSQL 2

SQLのDISTINCTはEXISTSとかGROUP BYでなんとかする事もできます。 DISTINCTは暗黙的なソートがされますが、何のDBを使うにせよ過去のバージョンならともかく、最近のバージョン ...

RFC 5322に準拠させた正規表現言語別 3

RFC5322で定義されている正規表現を、各言語の正規表現に変化させた形になります。 完全な電子メール正規表現は存在しないので、結局のところ何かの公式基準に従っていたとしても、自分が携わるサービスのル ...

-Docker