После внесения изменений в мой код, который оказался ошибкой, и теперь я не могу запустить его с помощью gunicorn. Если у вас есть совет по структурированию или факторингу, то это тоже приветствуется. Я пытаюсь запустить его с 5 дней, очень много борюсь.
Структура каталогов
app--
--db.sqlite
--__init__.py
--models.py
--MyFunctions.py
--routes.py
--schemas.py
--sockets.py
app.py
Внутри app.py
from app import *
from app.MyFunctions import *
from app.models import *
from app.schemas import *
from app.routes import *
from app.sockets import *
port=os.environ.get("PORT")
if port is None or port == "":
port = 3000
if __name__ == '__main__':
socketio.run(app, host='0.0.0.0', port=port) # when running on heroku
Внутри init .py
import jwt
from flask import (
Flask,
request,
jsonify,
make_response,
)
from flask_socketio import (
SocketIO,
send,
emit,
join_room,
leave_room,
)
from sqlalchemy import (
Column,
Integer,
String,
Boolean,
ForeignKey,
DateTime,
Sequence,
Float,
)
from flask_sqlalchemy import SQLAlchemy
from flask_marshmallow import Marshmallow
from os import environ
def debug(msg):
print('\n\n\n'+str(msg)+'\n\n\n'+'\n\nType:\t'+str(type(msg))+'\n\n')
from .models import *
socketio = SocketIO(app, cors_allowed_origins='*')
Внутри models.py (здесь импортируются только вещи, связанные с импортом, а не модели, моя большая часть импорта лежит только)
from flask import (
Flask,
request,
jsonify,
make_response,
redirect,
)
from flask_socketio import (
SocketIO,
send,
emit,
join_room,
leave_room,
)
from sqlalchemy import (
Column,
Integer,
String,
Boolean,
ForeignKey,
DateTime,
Sequence,
Float,
)
from flask_sqlalchemy import SQLAlchemy
from flask_marshmallow import Marshmallow
from flask_bcrypt import Bcrypt
from os import environ
from flask_cors import CORS, cross_origin
app = Flask(__name__)
root = os.path.dirname(os.path.abspath(__file__))
CORS(app, support_credentials=True)
basedir = os.path.abspath(os.path.dirname(__file__))
PG = os.environ.get("DATABASE_URL")
if PG is None or PG=="":
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///' + \
os.path.join(basedir, 'db.sqlite')
else:
app.config['SQLALCHEMY_DATABASE_URI'] = PG
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
app.config['SECRET_KEY'] = environ.get('STRIPE_API_KEY')
db = SQLAlchemy(app)
ma = Marshmallow(app)
bcrypt = Bcrypt(app)
socketio = SocketIO(app, cors_allowed_origins='*')
edit: В настоящее время я Я использую python только для запуска приложения на heroku, поэтому мой Procfile выглядит как
web: python app.py
И да, я пробовал много других форматов, таких как
web: gunicorn app:app
web: gunicorn models:app
web: gunicorn app/models:app
Попробовал сделать другой файл запуска также и многие другие методы, я боюсь, что мне нужно изменить их структуру, чтобы она работала.