Docker での FastAPI デプロイの詳細なプロセス

Docker での FastAPI デプロイの詳細なプロセス

Docker 学習

https://www.cnblogs.com/poloyy/p/15257059.html

プロジェクト構造

。
├── アプリ
│ ├── __init__.py
│ └── main.py
├── Dockerファイル
└── 要件.txt

FastAPI アプリケーションの main.py コード

入力からインポート オプション

fastapiからFastAPIをインポートする

アプリ = FastAPI()

@app.get("/")
read_root() を定義します:
    {"Hello": "World"} を返します

@app.get("/items/{item_id}")
def read_item(item_id: int, q: Optional[str] = None):
    {"item_id": item_id, "q": q} を返します

Dockerファイル

# 1. 公式PythonベースイメージFROM python:3.9から起動します

# 2. 現在の作業ディレクトリを/codeに設定する
# requirements.txt ファイルとアプリケーション ディレクトリ WORKDIR /code を配置する場所です。

# 3. まず requirements.txt ファイルをコピーします。# このファイルは頻繁に変更されないため、Docker はこれを検出してこのステップでキャッシュを使用し、次のステップでもキャッシュを有効にします。COPY ./requirements.txt /code/requirements.txt

# 4. pip コマンドを実行して依存関係をインストールします。RUN pip install --no-cache-dir --upgrade -r /code/requirements.txt

# 5. FastAPIプロジェクトコードをコピーします。COPY ./app /code/app

# 6. サービス CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "80"] を実行します。

ステップ4: pipコマンド分析を実行する

pip install --no-cache-dir --upgrade -r /code/requirements.txt を実行します。

  • --no-cache-dir オプションは、ダウンロードしたパッケージをローカルに保存しないように pip に指示します。これは、同じパッケージをインストールするために pip を再度実行する場合にのみ必要ですが、コンテナーを使用する場合はそうではありません。
  • --no-cache-dir は pip にのみ関連し、Docker やコンテナには関連しません。
  • --upgrade オプションは、すでにインストールされているパッケージをアップグレードするように pip に指示します。
  • 前の手順でコピーされたファイルは Docker キャッシュによって検出される可能性があるため、Docker キャッシュが利用可能な場合はこの手順も使用されます。
  • このステップでキャッシュを使用すると、開発中にイメージを何度もビルドするときに、毎回すべての依存関係をダウンロードしてインストールする必要がなく、多くの時間を節約できます。

Docker キャッシュ

ここで重要なトリックがDockerfileにあります。まず、FastAPIアプリケーションコードではなく、依存関係のファイルのみをコピーします。

 ./要件.txt /コード/要件.txt
  • Docker やその他のツールは、これらのコンテナ イメージを段階的に構築し、レイヤーを 1 つずつ追加します。
  • Dockerfileの先頭(最初の行)から、Dockerfile内の各命令は任意のファイルを作成します。
  • Docker やその他のツールも、イメージを構築するときに内部キャッシュを使用します。
  • コンテナ イメージが最後にビルドされてからファイルが変更されていない場合は、ファイルを再度コピーして新しいレイヤーを最初から作成するのではなく、前回作成されたのと同じレイヤーが再利用されます。
  • ファイルコピーを避けるだけでは必ずしも状況は改善されませんが、そのステップでキャッシュを使用するので、次のステップでもキャッシュを使用することができます。
  • 例えば、依存関係をインストールするための指示にキャッシュを使用することができます。

pip install --no-cache-dir --upgrade -r /code/requirements.txt を実行します。

  • requirements.txt は頻繁に変更されないため、ファイルをコピーすることで、Docker はこのステップでキャッシュを使用できます。
  • Dockerはキャッシュを使用してこれらの依存関係をダウンロードしてインストールすることができ、これにより多くの時間が節約されます。
  • パッケージの依存関係のダウンロードとインストールには数分かかる場合がありますが、キャッシュを使用すると数秒しかかかりません。
  • コンテナイメージは開発プロセス中に何度もビルドされ、コードの変更が有効かどうかをチェックするため、累積的な時間を大幅に節約できます。

./app /コード/app

  • Dockerfileの最後にFastAPIアプリケーションコードをコピーします
  • これは最も頻繁に変更されるものなので、最後に配置してください。このステップ以降はキャッシュを使用できなくなります。

Dockerイメージのビルド

Dockerfileでコマンドラインを開く

イメージをビルドします。

ミラーを見る

Docker イメージ

Dockerコンテナを起動する

docker run -d --name mycontainer -p 80:80 myimage

コンテナを表示

ドッカーps

127.0.0.1/にアクセス

127.0.0.1/docs にアクセスしてください

Gunicorn を使用した公式 Docker イメージ - Uvicorn

  • このイメージには、利用可能なCPUコアに基づいてワーカープロセスの数を設定する自動調整メカニズムが含まれています。
  • 適切なデフォルト設定がありますが、環境変数や設定ファイルを使用してすべての設定を更新できます。
  • このイメージ上のプロセスの数は、利用可能なCPUコアに基づいて自動的に計算され、CPUから可能な限り多くのパフォーマンスを引き出そうとします。
  • しかし、これはまた、プロセスの数はコンテナが稼働しているCPUに依存するため、消費されるメモリの量もこれに依存することを意味します。
  • したがって、アプリケーションが大量のメモリを消費し (たとえば、機械学習モデルを使用している場合)、サーバーの CPU コアは多数あるがメモリが少ない場合、コンテナーは使用可能なメモリよりも多くのメモリを使用することになり、パフォーマンスが大幅に低下する (またはクラッシュする) 可能性があります。

公式栗

tiangolo/uvicorn-gunicorn-fastapi:python3.9 から
コピー ./requirements.txt /app/requirements.txt
pip install --no-cache-dir --upgrade -r /app/requirements.txt を実行します。
コピー ./app /app

アプリケーションシナリオ

  1. Kubernetes を使用しており、クラスターレベルのレプリケーションを設定している場合は、このイメージを使用せず、最初からイメージを構築することをお勧めします。
  2. アプリケーションがシンプルで、CPU に基づいてデフォルトのプロセス数を設定するだけで十分な場合は、クラスタ レベルでレプリケーションを手動で構成する必要はなく、アプリケーションで複数のコンテナを実行する必要もありません。
  3. または、Docker Compose を使用してデプロイし、単一のサーバー上で実行する場合など。

詩のDockerイメージを使用する

# ステージ 1: Poetry をインストールし、Poetry の pyproject.toml ファイルからプロジェクトの依存関係を含む requirements.txt を生成するためにのみ使用されます。
tiangolo/uvicorn-gunicorn:python3.9 から requirements-stage として

# /tmp を現在の作業ディレクトリとして設定します。ここで requirements.txt ファイルが生成されます。WORKDIR /tmp

# 詩をインストールする
pip install poetry を実行します。

# ./pyproject.toml ./poetry.lock* /tmp/ をコピーします

# requirements.txt を生成する
poetry export -f requirements.txt --output requirements.txt --without-hashes を実行します。

# これは最終段階です。これ以降の内容は最終的なコンテナイメージに残ります。 FROM python:3.9

# 現在の作業ディレクトリを /code に設定する
WORKDIR /コード

# requirements.txt をコピーします。このファイルは前の Docker ステージにのみ存在するため、--from-requirements-stage を使用してコピーします。COPY --from=requirements-stage /tmp/requirements.txt /code/requirements.txt

# コマンド RUN pip install --no-cache-dir --upgrade -r /code/requirements.txt を実行します。

# コピー ./app /code/app

# サービス CMD を実行 ["uvicorn", "app.1_Quick Start:app", "--host", "0.0.0.0", "--port", "80"]
  • 最初のステージの Docker は Dockerfile の一部です。これは、後のステージで使用するいくつかのファイルを生成するためだけに使われる一時的なコンテナ イメージです。
  • Poetryを使用する場合、Dockerマルチステージビルドを使用するのが理にかなっています
  • 最終的なコンテナ イメージに Poetry とその依存関係を実際にインストールする必要はないため、プロジェクトの依存関係をインストールするために必要なのは、生成された requirements.txt ファイルだけです。

詩の詳細なチュートリアル

https://www.jb51.net/article/195070.htm

Docker にデプロイされた FastAPI に関するこの記事はこれで終わりです。Docker にデプロイされた FastAPI に関するその他の関連コンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • Docker で onlyoffice をインストールして展開する詳細なプロセス
  • Docker で Confluence をデプロイする
  • docker を使用して Spring Boot をデプロイし、Skywalking に接続する方法

<<:  IE 環境での css-vars-ponyfill の使用に関する詳細な説明 (nextjs ビルド)

>>:  HTML ではスペースはどのように表現されますか (どのような意味ですか)?

推薦する

JavaScriptを使用してページ効果を作成する

11. JavaScriptを使用してページ効果を作成する11.1 DOMプログラミングDOM プロ...

mysql バッチで大量のデータを削除する

mysql バッチで大量のデータを削除する1000万件のレコードを持つテーブル(syslogs)があ...

MySQL で絵文字表現を挿入できない理由と解決策

失敗のシナリオMySQL データベースに絵文字表現を挿入するために JDBC を呼び出すと、例外ja...

nohup /dev/null 2>&1 の使い方の詳しい説明

nohup コマンド: プロセスを実行しており、アカウントからログアウトしてもプロセスが終了しないと...

Springboot プロジェクトに動的にパラメータを渡すための Docker の実装方法

背景最近、Docker 初心者の友人から、毎回プロジェクト構成ファイルにハードコーディングしてサービ...

MySQLのロックについて理解しておくべきこと

1. はじめにMySQL ロックは、その範囲に応じて、グローバル ロック、テーブル ロック、行ロック...

HTMLは無効なテーブル幅設定の問題を解決します

テーブルに table-layer:fixed スタイルを設定し、テーブル内の行が結合されていること...

Linuxのsortコマンドの複数のパラメータを理解するための1つの質問

sort コマンドは非常によく使用されますが、-o、-n、-u、-r などの多くのパラメーターがあり...

CSS 属性値正規マッチングセレクターの使い方 (ヒント)

属性値の正規一致セレクターには 3 つの種類があります。 [属性^="値"] [...

Mysql ALTER TABLE はフィールドを追加するときにテーブルをロックしますか?

目次MySQL 5.6以前MySQL 5.6以降要約する知らせMySQL 5.6以前更新手順元のテー...

Vue3 ミックスインの使い方

目次1. mixin の使い方は? 2. ミックスイン使用時の注意2.1. ミックスイン オブジェク...

データベースのインデックス作成に関する知識ポイントのまとめ。必要な情報はすべてここにあります。

データベースインデックスについては皆さんもよくご存知だと思います。 インデックスは、データベース テ...

nginxとIISで使用できるSSL証明書を作成する

目次SSL証明書の作成1. 秘密鍵を生成する2. 証明書要求ファイルを生成する3. CRT証明書ファ...

docker compose サービスの起動順序を制御する方法

まとめDocker-compose は複数の Docker コンテナ サービスを簡単に組み合わせるこ...

nginx の場所に複数の Proxy_pass メソッドがある

1. まず、nginxの位置情報に関する関連知識を確認しましょう1) 位置マッチング手順: ~ #波...