我有一个Pylons应用程序,我想将一些逻辑移到单独的批处理过程中.我一直在主应用程序下运行它进行测试,但它将在数据库中做很多工作,我希望它是一个独立的进程,将在后台不断运行.主要的pylons应用程序将作业提交到数据库中,新进程将完成每个作业中所请求的工作.
如何将控制器作为独立脚本启动?
我目前有:
from warehouse2.controllers import importServer
importServer.runServer(60)
Run Code Online (Sandbox Code Playgroud)
并在控制器文件中,但不是控制器类的一部分:
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)
Run Code Online (Sandbox Code Playgroud)
但是在命令行上启动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
Run Code Online (Sandbox Code Playgroud)
Ben*_*ert 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)
Run Code Online (Sandbox Code Playgroud)
这将加载Pylons应用程序,该应用程序设置大部分状态,以便您可以继续使用SQLAlchemy模型和Session来使用数据库.
请注意,如果您的代码使用pylons全局变量(例如request/response/etc),那么这将无效,因为它们需要正在进行的请求才能存在.
我正在编辑我的回复并投票赞成 Ben Bangert 的另一个答案,因为它是正确的。我回答了并从此学会了正确的方法(如下所述)。如果您确实愿意,请查看此答案的历史记录,以查看我最初提出的错误(但有效)的解决方案。