gpt4 book ai didi

python - 如何从我的主 Flask 应用程序动态创建和启动辅助 Flask 应用程序?

转载 作者:行者123 更新时间:2023-12-05 07:26:21 25 4
gpt4 key购买 nike

我有一个 Flask 应用程序,我希望能够使用它在不同的端口上启动另一个 Flask 应用程序(在主应用程序运行时未知)。这些子应用程序旨在非常简单,并根据需要加速/减速,但是,最好从主 flask 应用程序中完成。

我不认为 DispatcherMiddleware 是解决方案,因为子应用程序在主应用程序启动时尚未确定。

question关于在类中使用 flask 是我开始的路线。这是我使用的稍微修改过的文件:

from flask import Flask, request, redirect, Response


class EndpointAction(object):

def __init__(self, action):
self.action = action
self.response = Response(status=200, headers={})


def __call__(self, *args):
self.action()
return self.response


class AppWrapper(object):

def __init__(self, name, host='0.0.0.0', port=8080, cert_path=None, key_path=None):
self.app = Flask(name)
self.host = host
self.port = port

if None not in [cert_path, key_path]:
self.context = (cert_path, key_path)
else:
self.context = None


def run(self):
self.app.run(host=self.host, port=self.port, ssl_context=self.context)


def add_endpoint(self, endpoint=None, endpoint_name=None, handler=None):
self.app.add_url_rule(endpoint, endpoint_name, EndpointAction(handler))


def action():
return 'welcome to my page'

但是,当我尝试从我的主应用程序的路由文件中调用运行时,我收到警告说 app.run() 被忽略了。

@app.route('/start')
def start():
child = AppWrapper(name='test')
child.add_endpoint(endpoint='/ad', endpoint_name='ad', handler=action)
child.run()
return 'started'

警告:静默忽略 app.run() 因为应用程序是从 flask 命令行可执行文件运行的。考虑将 app.run() 放在 if __name__ == "__main__"守卫后面以消除此警告。

我目前正在开发模式下使用 flask run 启动主应用程序。

这是往下走的正确路径还是有更好的方法?如果建议的解决方案是类似的类实现,我该如何绕过 app.run() 警告?

编辑:关于我正在努力完成的事情的背景。这个主应用程序就像一个管理面板,在一个端口上运行,防火墙限制谁可以访问它。主要应用程序功能的一部分是接受和存储辅助应用程序的配置。因此,用户将能够 POST HTML 和 1-4 个基本路由(以及其他配置),辅助应用程序将提供服务。在主应用程序中,我试图让 flask 应用程序根据用户指定的配置运行。因此,当用户选择临时为该应用提供服务时,辅助 flask 应用会在外部可见的单独端口上启动。

最佳答案

我会在这里考虑时间与精力的权衡。与其构建一个构建应用程序的应用程序,不如培训您的用户自己构建应用程序更容易,甚至可能为他们提供基本模板以快速提高工作效率。

您还提到通过您的门户提交自定义 HTML,这听起来像是您希望用户通过门户提交 Jinja2 模板,而这些模板又需要写入文件系统并由子应用程序加载。如果用户提交有缺陷的模板,这无疑会产生问题,导致应用程序崩溃,并带走所有其他子应用程序,因为一切都从同一个 python 解释器运行。

但是,我理解培训潜在的非技术人员使用 Flask 的难度。如果您仍然想坚持门户的想法,可能值得定义您想让用户配置的配置值,并实现一个 CRUD 系统来验证这些输入并将它们存储在数据库中。

当子应用程序启动时(在单独的 Python 进程中),您可以从数据库中提取这些值并使用它们来构建应用程序。来自 flask 团队的 davidism 有一个答案 talks about pulling config from the database .

我也想看看 docker。 Flask mega 教程有一个 whole section on docker这应该让您了解这些功能。

还有一个 Python SDK for Docker它为您提供了 python 中 docker 终端命令的所有功能。

所以理论上你可以:

  • 父级应用向用户展示门户,允许他们定义经过验证并存储在数据库中的所需配置。

  • 一个子应用程序将从数据库中读取配置,并根据此配置初始化 Flask 应用程序对象。这可以手动配置为在 docker 容器中运行。

  • 能够使用 python docker sdk 从父应用中启动子应用容器。一旦您已经使子应用支持 docker,应该很容易。

这具有隔离所有组件的优势,但可能涉及比您希望的更多的开发时间。

当然,您可以在用户培训和自动化之间找到一些适合您目的的中间地带。

关于python - 如何从我的主 Flask 应用程序动态创建和启动辅助 Flask 应用程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54365756/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com