【问题标题】:How do I run another script in Python without waiting for it to finish? [duplicate]如何在 Python 中运行另一个脚本而不等待它完成? [复制]
【发布时间】:2010-10-07 10:58:15
【问题描述】:

我正在为一个允许他运行特定作业的用户创建一个小仪表板。我正在使用 Django,所以我希望他能够单击链接以开始作业,然后将页面返回给他,并显示作业正在运行的消息。工作结果稍后将通过电子邮件发送给他。

我相信我应该使用subprocess.Popen,但我不确定。所以在伪代码中,这就是我想要做的:

if job == 1:
    run script in background: /path/to/script.py
    return 'Job is running'

【问题讨论】:

标签: python django process background subprocess


【解决方案1】:
p = subprocess.Popen([sys.executable, '/path/to/script.py'], 
                                    stdout=subprocess.PIPE, 
                                    stderr=subprocess.STDOUT)

这将在后台启动子进程。您的脚本将继续正常运行。

阅读文档here

【讨论】:

  • nosklo:谢谢。我如何将参数传递给脚本?
  • 列表中的其他元素作为第一个参数传递。链接的文档很有用,并且链接到是有原因的。
  • 在非windows环境下,也可以查看os.fork
  • 德文:谢谢。我在这里问是因为我很难从文档中弄清楚这一点。我在文档中的任何地方都没有看到 sys.executable。如果我们只需要文档,我们就不需要 SO =)
  • @sheats: sys.executable 记录在这里docs.python.org/library/sys.html#sys.executable
【解决方案2】:

subprocess.Popen 确实是您正在寻找的。​​p>

【讨论】:

    【解决方案3】:

    虽然如果你发现你想开始在子进程和父进程之间传递一堆信息,你可能需要考虑一个线程,或者像 Twisted 这样的 RPC 框架。

    但很可能这些对于您的应用程序来说太重了。

    【讨论】:

      【解决方案4】:

      如果您正在考虑长期扩展,那么通过消息队列运行它绝对是可行的方法。向在后台持续运行的队列发送消息,并编写作业处理程序来处理不同类型的消息。

      由于您使用的是 Django,我认为 Beanstalkd 非常适合。 Here's 一个非常好的关于这个主题的教程。那篇文章的第一条评论也有一些很好的提示。

      就我个人而言,我使用了一个用 Erlang 编写的自定义内存队列服务器,以及用 C 编写的 Python 绑定。但是 redis 看起来它可能会成为未来队列/消息传递需求的有力竞争者。希望这会有所帮助!

      【讨论】:

      • celery (pypi.python.org/pypi/celery) 也很适合这个。它使用 RabbitMQ(对于消息持久性,如果有人有时间,当然可以使用 beanstalkd 的胡萝卜后端) beanstalkd 教程只解决了其中一个问题,发送消息,但将实际执行任务留给读者作为练习。
      猜你喜欢
      • 2012-06-26
      • 2011-11-15
      • 2022-08-26
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-03-22
      相关资源
      最近更新 更多