跳转到主要内容

支持背景线程和ZODB支持

项目描述

一个用于创建可以与 ZODB 通信并使用本地站点组件的后台线程的库。

我们可能正在重新发明 Celery。

示例

假设我们有一个具有简单发布工作流的管理系统(DMS)。我们有两种状态“草案”和“发布”。在这个示例中的问题是:从“草案”到“发布”的转换需要几分钟时间,我们不希望用户等待。

首先,我们创建一个 WorkflowTransition-BackgroundThread

class MyWorkflowTransition(BackgroundWorkerThread):
    execute = True
    description = "background worker thread (%(class_name)s) for %(site_name)s User %(user_name)s"

    def __init__(self, site_db, site_oid, site_name, user_name, daemon=True, object_oid=None):
        self.object_oid = object_oid
        super(MyWorker, self).__init__(site_db, site_oid, site_name, user_name, daemon=True)

    def scheduleNextWork(self):
        return self.execute

    def getObjectFromOID(self):
        conn = getSite()._p_jar
        return conn.get(self.object_oid)

    def doWork(self):
        sleep(15) # This is our long TASK
        self.execute = False
        document = self.getObjectFromOID()
        document.wf_status = "PUBLISHED"

我们有一个简单的文档,其初始工作流状态为 draft。

class Document(Persistent):
    wf_state = "DRAFT"

现在,我们必须调用我们的 WorkflowTransition。

def setWorkflow(site, document_oid, user_name):
    worker = MyWorkflowTransition(
        site_db = site._p_jar.db(),
        site_oid = site._p_oid,
        site_name = site.__name__,
        user_name = user_name,
        object_oid = document_oid,
        )
    worker.start()

当调用 worker.start() 时,线程进入“后台”,用户不需要等待转换完成。

CHANGES

1.0.2 (2012-07-31)

  • 重构 BackgroundWorkerThread 以返回从 getSite() 获取的站点

1.0.1 (2012-04-05)

1.0.0 (2012-02-10)

  • 作为独立的包进行初始发布。

项目详情


下载文件

下载您平台上的文件。如果您不确定选择哪个,请了解更多关于 安装包 的信息。

源代码分发

cipher.background-1.0.2.tar.gz (14.6 kB 查看哈希)

上传时间 源代码

由以下机构支持

AWS AWS 云计算和安全赞助商 Datadog Datadog 监控 Fastly Fastly CDN Google Google 下载分析 Microsoft Microsoft PSF 赞助商 Pingdom Pingdom 监控 Sentry Sentry 错误日志 StatusPage StatusPage 状态页面