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

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

ただいまの
回答率

87.48%

WSGIを利用するメリット

解決済

回答 1

投稿 編集

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

score 24

前提

Webアプリケーションを勉強中の身です。見当違いな質問でしたらご容赦ください。
Docker コンテナ上で、nginx(reverse proxy) + flask を用いて web app を運用しようと考えています。

疑問

タイトル通りなのですが、WSGIを利用する理由がよくわかりません。
現状の構造として、nginx が reverse proxy として HTTP リクエストを app server(server コンテナ) にリダイレクトし、app server がレスポンスしている状態です。
「flask nginx」で検索すると、大抵「flask + nginx + uWSGI で環境構築」のように、(u)WSGI が必須かの認識を持ってしまいますが、なくても動いてるし何なんだろうと思い質問させていただきました。

調べたこと

以下を見ると、WSGI の有無によって、Webサーバによっては使えないWebアプリフレームワークが出たりと制限が出るとのことでした。
ということは WSGI がなくても稼働していることからも、(flask, nginx) の pair は上記制限は発生しないという認識でよいのでしょうか?
もしそうなら、(app server が web server の実装を知る必要があるとはいえ)このようなケースでは WSGI を間に挟むことのメリットはほとんどないということでしょうか?
何卒よろしくお願いいたします。

  • https://grmn.hatenablog.com/entry/2018/09/06/132459
  • https://gihyo.jp/dev/feature/01/wsgi/0001

Appendix

docker-compose.yml

version: '3'

services:
    reverse-proxy:
        image: nginx
        container_name: nginx
        volumes:
            - ./reverse-proxy/conf.d:/etc/nginx/conf.d
        ports:
            - 8080:8080
        tty: true

    server:
        image: python:3.9.5-alpine
        container_name: server
        volumes:
            - ./app:/home/app/app
            - ./run.sh:/home/app/run.sh
        command: >
            sh -c "pip install flask pyyaml
            && cd /home/app
            && ./run.sh"
        tty: true
        expose:
            - 8000
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • quickquip

    2021/06/18 16:16 編集

    app server がなんのことか質問に書いてもらえないでしょうか?

    キャンセル

  • moni

    2021/06/18 16:31

    失礼いたしました。docker-compose.yml にあるように、server コンテナのことを app server と呼んでいました。
    上記追記いたしました。

    キャンセル

  • quickquip

    2021/06/18 16:33

    run.sh の中身はなんでしょうか?
    結局起動しているのは、(私が思い当たるのは)flask.Flask.run で起動する開発用サーバぐらいですが、それでしょうか……?

    https://flask.palletsprojects.com/en/2.0.x/api/#flask.Flask.run

    (編集が行き違ったので取り消して再度投稿してます)

    キャンセル

  • moni

    2021/06/18 16:43

    おっしゃる通り、Flask オブジェクトの run メソッドを起動しているだけです。
    開発用サーバということは、このメソッドで起動したサーバは本番に使うべきではないということなんですかね...?

    ・run.sh
    #!/bin/sh
    python -m app

    ・__main__.py
    from . import app

    app.run(host="0.0.0.0", debug=True, port=8000, threaded=True)

    キャンセル

回答 1

checkベストアンサー

0

https://flask.palletsprojects.com/en/2.0.x/api/#flask.Flask.run

It is not intended to meet security and performance requirements for a production server. Instead, see Deployment Options for WSGI server recommendations.

"本番サーバーのセキュリティやパフォーマンスの要件を満たすことを目的としたものではない"と明記されてます。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2021/06/18 17:24

    なるほど、ありがとうございます。
    そもそも flask app の起動は基本 flask.Flask.run だと思っていたのが勘違いだったのだと思います。
    run で起動するサーバはセキュリティ・速度は良くないかもしれないが、WSGI 機能も有したものなので uWSGI などを使わずとも通信できたという認識で正しいでしょうか?

    キャンセル

  • 2021/06/18 17:47

    werkzeug.serving.run_simpleに行き着くので、WSGIの開発用サーバを起動する、という認識でよいかと思います。

    https://github.com/pallets/flask/blob/2.0.1/src/flask/app.py#L922

    https://werkzeug.palletsprojects.com/en/2.0.x/serving/

    キャンセル

  • 2021/06/18 17:58

    なるほど、納得です!ありがとうございました!
    内部的にWSGIサーバを起動していることで「ウェブサーバとアプリケーションサーバは異なる」というのが腑に落ちなかったのが解消されました。

    キャンセル

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

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

関連した質問

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