11

我有一个 Pylons 应用程序,我想将一些逻辑移动到一个单独的批处理过程中。我一直在主应用程序下运行它进行测试,但它将在数据库中做很多工作,我希望它是一个单独的进程,将在后台不断运行。主 pylons 应用程序会将作业提交到数据库中,新进程将完成每个作业中请求的工作。

如何将控制器作为独立脚本启动?

我目前有:

from warehouse2.controllers import importServer
importServer.runServer(60)

在控制器文件中,但不是控制器类的一部分:

def runServer(sleep_secs):
    try:
        imp = ImportserverController()
        while(True):
            imp.runImport()
            sleepFor(sleep_secs)

    except Exception, e:
        log.info("Unexpected error: %s" % sys.exc_info()[0])
        log.info(e)

但是在命令行上启动 ImportServer.py 会导致:

2008-09-25 12:31:12.687000 Could not locate a bind configured on mapper Mapper|I
mportJob|n_imports, SQL expression or this Session
4

2 回答 2

11

如果要加载 Pylons 应用程序的一部分,例如来自 Pylons 外部的模型,请先在脚本中加载 Pylons 应用程序:

from paste.deploy import appconfig
from pylons import config

from YOURPROJ.config.environment import load_environment

conf = appconfig('config:development.ini', relative_to='.')
load_environment(conf.global_conf, conf.local_conf)

这将加载 Pylons 应用程序,该应用程序设置了大部分状态,以便您可以继续使用 SQLAlchemy 模型和 Session 来处理数据库。

请注意,如果您的代码正在使用诸如请求/响应/等之类的 pylons 全局变量,那么这将不起作用,因为它们需要正在进行的请求才能存在。

于 2009-04-24T03:42:01.870 回答
1

我正在修改我的回答并支持 Ben Bangert 的另一个回答,因为它是正确的。我回答并从此学会了正确的方法(如下所述)。如果您真的想要,请查看此答案的历史记录,以查看我最初提出的错误(但有效)解决方案。

于 2008-09-25T19:04:57.483 回答