Запущено приложение фляги с использованием Apache и mod_wsgi не работает - PullRequest
0 голосов
/ 15 октября 2019

Я пытаюсь получить свое приложение для производства с использованием Apache 2.4, но я получаю сетевую ошибку, которая, по-моему, означает, что мое приложение фляги не работает.

Когда я запускаю Apache и перехожу квеб, я получаю - сетевая ошибка:

Не удалось загрузить ресурс: net :: ERR_CONNECTION_REFUSED

Во-первых, есть ли способ его дебютировать? потому что ничего нет в журнале. может быть, способ проверить, вызывает ли Apache мой файл .wsgi? А также я приложил свой код, и я действительно могу использовать некоторую помощь!

некоторые детали: я использую Apache 2.4 и python 3.7.4. Мой файл приложения: Operator.py в каталоге "C: \ users \ myapp"

Я добавил ссылку на wsgi с помощью: LoadFile "C: /python37/python37.dll" LoadModule wsgi_module "C: / users/myapp/venv/lib/site-packages/mod_wsgi/server/mod_wsgi.cp37-win_amd64.pyd "WSGIPythonHome" C: / users / myapp / venv / "

httpd.conf (в Apache):

Define SRVROOT "c:/Apache24"
ServerRoot "${SRVROOT}"

Listen 80

LoadFile "C:/python37/python37.dll"
LoadModule wsgi_module 
"C:/users/ihen2622/documents/jgh_prototype/venv/lib/site- 
packages/mod_wsgi/server/mod_wsgi.cp37-win_amd64.pyd"
WSGIPythonHome "C:/users/ihen2622/documents/jgh_prototype/venv/"

LoadModule actions_module modules/mod_actions.so
LoadModule alias_module modules/mod_alias.so
LoadModule allowmethods_module modules/mod_allowmethods.so
LoadModule asis_module modules/mod_asis.so
LoadModule auth_basic_module modules/mod_auth_basic.so
LoadModule authn_core_module modules/mod_authn_core.so
LoadModule authn_file_module modules/mod_authn_file.so
LoadModule authn_socache_module modules/mod_authn_socache.so
LoadModule authz_core_module modules/mod_authz_core.so
LoadModule authz_groupfile_module modules/mod_authz_groupfile.so
LoadModule authz_host_module modules/mod_authz_host.so
LoadModule authz_user_module modules/mod_authz_user.so
LoadModule autoindex_module modules/mod_autoindex.so
LoadModule cgi_module modules/mod_cgi.so
LoadModule dir_module modules/mod_dir.so
LoadModule env_module modules/mod_env.so
LoadModule include_module modules/mod_include.so
LoadModule isapi_module modules/mod_isapi.so
LoadModule log_config_module modules/mod_log_config.so
LoadModule mime_module modules/mod_mime.so
LoadModule negotiation_module modules/mod_negotiation.so
LoadModule setenvif_module modules/mod_setenvif.so
LoadModule socache_shmcb_module modules/mod_socache_shmcb.so
LoadModule ssl_module modules/mod_ssl.so

<IfModule unixd_module>
 User daemon
 Group daemon
</IfModule>

ServerAdmin admin@example.com

<Directory />
 AllowOverride none
 Require all denied
</Directory>

DocumentRoot "${SRVROOT}/htdocs"

<Directory "${SRVROOT}/htdocs">
 Options Indexes FollowSymLinks ExecCGI
 AllowOverride None
 Require all granted
</Directory>

<IfModule dir_module>
  DirectoryIndex index.html index.cgi index.py
</IfModule>

<Files ".ht*">
 Require all denied
</Files>

ErrorLog "logs/error.log"
LogLevel warn

<IfModule log_config_module>
 LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined
 LogFormat "%h %l %u %t \"%r\" %>s %b" common

 <IfModule logio_module>
   # You need to enable mod_logio.c to use %I and %O
   LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio
 </IfModule>
 CustomLog "logs/access.log" common
</IfModule>

<IfModule alias_module>
 ScriptAlias /cgi-bin/ "${SRVROOT}/cgi-bin/"
</IfModule>

<Directory "${SRVROOT}/cgi-bin">
 AllowOverride None
 Options None
 Require all granted
</Directory>

<IfModule headers_module>
 RequestHeader unset Proxy early
</IfModule>

<IfModule mime_module>
 TypesConfig conf/mime.types
 AddType application/x-compress .Z
 AddType application/x-gzip .gz .tgz
 AddHandler cgi-script .cgi .py
</IfModule>

Include conf/extra/httpd-ssl.conf

Include conf/extra/httpd-manual.conf

<IfModule proxy_html_module>
 Include conf/extra/proxy-html.conf
</IfModule>

<IfModule ssl_module>
 SSLRandomSeed startup builtin
 SSLRandomSeed connect builtin
</IfModule>

httpd-ssl.conf (Apache):

...
Listen 443

<VirtualHost *:443>

DocumentRoot "${SRVROOT}/htdocs/dist"
ServerName thenameoftheserver:443
WSGIScriptAlias \ "C:/Users/myapp/web.wsgi"

<Directory "C:/Users/myapp>
Require all granted
</Directory>



</VirtualHost>                                  

web.wsgi (в моем приложении, python):

import sys
import logging

activate_this = r'C:/Users/myapp/venv/Scripts/activate_this.py'
with open(activate_this) as file_:
exec(file_.read(), dict(__file__=activate_this))

logging.basicConfig(stream=sys.stderr)
sys.path.insert(0, "C:/Users/myapp")

from Operator import app as application

мое приложение (python):

# -*- coding: utf8 -*-
#! C:\python37\python
import cgitb
from flask_cors import CORS

cgitb.enable()

# load app
from init_app import app

db.create_all(app=app)
cors = CORS(app, resources={r"/*": {"origins": "https://thecorrectpath/*"}})

@app.route('/')
def analytics():
    print('hello')

if __name__ == '__main__':
     app.run(host=HOST, debug=DEBUG, threaded=True)
...