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コマンド分析を実行する
Docker キャッシュここで重要なトリックがDockerfileにあります。まず、FastAPIアプリケーションコードではなく、依存関係のファイルのみをコピーします。 ./要件.txt /コード/要件.txt
DockerイメージのビルドDockerfileでコマンドラインを開く
ミラーを見る
Dockerコンテナを起動する
コンテナを表示
127.0.0.1/にアクセス 127.0.0.1/docs にアクセスしてください Gunicorn を使用した公式 Docker イメージ - Uvicorn
公式栗 tiangolo/uvicorn-gunicorn-fastapi:python3.9 から コピー ./requirements.txt /app/requirements.txt pip install --no-cache-dir --upgrade -r /app/requirements.txt を実行します。 コピー ./app /app アプリケーションシナリオ
詩の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"]
詩の詳細なチュートリアル https://www.jb51.net/article/195070.htm Docker にデプロイされた FastAPI に関するこの記事はこれで終わりです。Docker にデプロイされた FastAPI に関するその他の関連コンテンツについては、123WORDPRESS.COM の過去の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: IE 環境での css-vars-ponyfill の使用に関する詳細な説明 (nextjs ビルド)
>>: HTML ではスペースはどのように表現されますか (どのような意味ですか)?
<br />元のアドレス: http://andymao.com/andy/post/8...
OS X 環境で MySQL を起動すると、エラー メッセージが表示されます。 016-03-03T...
この記事は共有および集約することを歓迎します。全文を転載する必要はありません。著作権を尊重してくださ...
Apache Tomcat は、Java Servlet および Java Server Pages...
目次概要1. フロントエンドとバックエンドの分離とWeb APIの優先ルート設計2. Axiosネッ...
MySQL データベースでは、テーブルが互いに関連付けられた後は、それらを任意に削除することはできま...
この記事では、例を使用して、MySQL 5.7 で生成された列の使用方法を説明します。ご参考までに、...
1. Linuxカーネルドライバモジュールの仕組み静的ロードでは、ドライバモジュールをカーネルにコン...
1 はじめにデータベースを設計する場合、画像や音声ファイルをデータベースに挿入することは避けられませ...
1. CSSを通す必要がある背景CSS におけるメディアクエリの用途は、デバイスサイズの判別、マウス...
退屈していたので、突然角丸四角形の実装を思いつきました。しかし、私たちはこの話題についてあまりにも長...
目次Vueライフサイクルの紹介とフック機能VUEライフサイクルフックVue ライフサイクルの紹介作成...
準備Windows Server 2008 R2 Enterprise (2.40GH、8GB、64...
フロントエンド開発者にとって、さまざまな主要ブラウザのさまざまなバージョンでコードが適切に動作するこ...
序文この記事では、vue に付属している vue-router.js ルーティングを使用してページン...