zbparse/flask_app/start_up.py

53 lines
2.1 KiB
Python
Raw Normal View History

# flask_app/start_up.py
2024-10-12 18:01:59 +08:00
import logging
2024-11-25 16:24:38 +08:00
from flask import Flask, request, g
2024-11-25 09:15:56 +08:00
from flask_app.ConnectionLimiter import ConnectionLimiter
from flask_app.logger_setup import CSTFormatter, create_logger
from flask_app.routes.get_deviation import get_deviation_bp
from flask_app.routes.little_zbparse import little_zbparse_bp
from flask_app.routes.upload import upload_bp
from flask_app.routes.test_zbparse import test_zbparse_bp
2024-11-28 11:57:32 +08:00
from flask_app.general.清除file_id import delete_file_by_ids,read_file_ids
2024-11-25 09:15:56 +08:00
class FlaskAppWithLimiter(Flask):
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
2024-11-25 16:04:53 +08:00
# 初始化一个字典来存储每个蓝图的限流器
self.connection_limiters = {}
def create_app():
2024-11-25 09:15:56 +08:00
app = FlaskAppWithLimiter(__name__)
# 设置日志的全局配置(如果需要)
handler = logging.StreamHandler()
handler.setFormatter(CSTFormatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s'))
app.logger.addHandler(handler)
app.logger.setLevel(logging.INFO)
2024-08-29 16:37:09 +08:00
# 注册蓝图
app.register_blueprint(get_deviation_bp)
app.register_blueprint(little_zbparse_bp)
app.register_blueprint(upload_bp)
app.register_blueprint(test_zbparse_bp)
2024-11-26 11:32:24 +08:00
app.connection_limiters['upload'] = ConnectionLimiter(max_connections=10)
app.connection_limiters['get_deviation'] = ConnectionLimiter(max_connections=10)
2024-11-25 16:04:53 +08:00
app.connection_limiters['default'] = ConnectionLimiter(max_connections=10)
2024-11-25 16:24:38 +08:00
@app.teardown_request
def teardown_request(exception):
2024-11-28 11:57:32 +08:00
output_folder = getattr(g, 'output_folder', None)
2024-12-02 16:48:47 +08:00
# if output_folder:
# # 执行与output_folder相关的清理操作例如删除临时文件
# logger = g.logger
# logger.info(f"正在清理输出文件夹: {output_folder}")
# file_ids=read_file_ids(output_folder)
# delete_file_by_ids(file_ids)
# logger.info("清理完毕!")
return app
2024-08-30 11:56:11 +08:00
#TODO:培训要求、总体要求、进度要求、'建设要求'到技术要求中,归类到其他要求中
2024-11-25 16:27:29 +08:00
2024-08-29 16:37:09 +08:00
if __name__ == '__main__':
app = create_app()
2024-11-26 15:12:13 +08:00
app.run(debug=True, host='0.0.0.0', port=5000)