504 Время ожидания шлюза Сервер не ответил вовремя - PullRequest
2 голосов
/ 24 апреля 2019

Я использую виртуальную машину для запуска моего приложения фляги 'sqtf'. Она работает на локальном компьютере, используя 127.0.0.1:5000, но не на моем сервере apache Я использую python3.6, apache2.4 и mod_wsgi. это упрощенная структура моего проекта:

/var/www/squashPy/src/squash_test_filter/
                              /sqtf
                                  sqtf.wsgi
                                  __init__.py
                                  /static
                                  /templates
                              /venv

После настройки моего VirtualHost 'sqtf.com.conf' на apache, а затем моего sqtf.wsgi (также настраивая мои virtualenv и / etc / hosts), сервер отвечает на www.sqtf.com, но на моей странице входа или на любом другом другое, «www.sqtf.com/auth/login» 504 Порт сервера времени ожидания шлюза 80.

В моем error.log:

Время ожидания при чтении ответа от процесса deamon 'sqtf': /var/www/squashPy/src/squash_test_filter/sqtf/sqtf.wsgi

Я добавил python-home в свой DeamonProcess. Увеличение времени ожидания ничего не меняет.

my sqtf.com.conf

<VirtualHost *:80>
     ServerName www.sqtf.com
     ServerAlias sqtf.com
     ErrorLog /var/www/squashPy/sqtf.com/logs/error.log
     CustomLog /var/www/squashPy/sqtf.com/logs/custom.log combined
     WSGIDaemonProcess sqtf python-home='var/www/squashPy/src/squash_test_filter/venv'
     WSGIProcessGroup sqtf
     WSGIApplicationGroup %{GLOBAL}
     WSGIScriptAlias / /var/www/..../sqtf/sqtf.wsgi
     Alias /static/ /var/wwww/..../sqtf/static
     <Directory /var/www/..../static>
          Require all granted
     </Directory>
<VirtualHost>

my sqtf.wsgi

    activate_this='/var/www/..../venv/bin/activate_this.py'
    with open(activate_this) as file_:
            exec(file_.read(), dict(__file__=activate_this))
    import sys
    import logging
    sys.path.insert(0, "/var/www/squashPy/src/squash_test_filter/")
    from sqtf import app as application

часть моего / etc / hosts:

    127.0.0.1 localhost
    127.0.1.1 ubuntu
    127.0.0.1 www.sqtf.com sqtf.com sqtf

    # etc ...

часть моего /sqtf/init.py

    import ...



    def create_app(test_config=None):
        # create and configure the app

        app = Flask(__name__, instance_relative_config=True)
        api = Api(app)

        app.config.from_mapping(
            SECRET_KEY='dev',
            DATABASE=os.path.join(app.instance_path, 'sqtf.sqlite'),
        )

        if test_config is None:
            # load the instance config, if it exists, when not testing
            app.config.from_pyfile('config.py', silent=True)
        else:
            # load the test config if passed in
            app.config.from_mapping(test_config)

        # ensure the instance folder exists
        try:
            os.makedirs(app.instance_path)
        except OSError:
            pass
        db.init_app(app)
        return app

1 Ответ

0 голосов
/ 25 апреля 2019

Я решаю проблему, если вы используете фабрику колб, например, с помощью create_app, вам нужно изменить эту строку from sqtf import app as application в ваших .wsgi следующим образом:

from sqtf import create_app
application=create_app()
...