- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
python 3.6.6
这是代码:
import asyncio
import time
from concurrent.futures import ProcessPoolExecutor
executor_processes = ProcessPoolExecutor(2)
def calculate():
while True:
print("while")
time.sleep(1)
async def async_method():
loop_ = asyncio.get_event_loop()
loop_.run_in_executor(executor_processes, calculate)
await asyncio.sleep(1)
print("finish sleep")
if __name__ == '__main__':
loop = asyncio.get_event_loop()
loop.run_until_complete(async_method())
print("main_thread is finished")
while
finish sleep
main_thread is finished
while
while
...
import asyncio
import time
import multiprocessing
def calculate():
while True:
print("while")
time.sleep(1)
async def async_method():
proc = multiprocessing.Process(target=calculate)
proc.daemon = True
proc.start()
await asyncio.sleep(1)
print("finish sleep")
if __name__ == '__main__':
loop = asyncio.get_event_loop()
loop.run_until_complete(async_method())
print("main_thread is finished")
while
finish sleep
main_thread is finished
loop_.run_in_executor(executor_processes, calculate)
“类似守护进程”的行为?
最佳答案
您显示的代码显然只是一个小示例,用于演示您希望实现的目标。我们不知道您的实际任务/问题。但老实说,我不相信你在这里走的是正确的道路。ProcessPoolExecutor
是 concurrent.futures
的一部分标准库包。它返回一个 Future
调用时发送给调用者 submit()
.那个Future
是尚未完成的计算结果的代理。这是一个 promise ;尽管在这种情况下该术语在技术上并不完全正确。见 Wiki page为了区别。
这意味着,计算应在有限时间内完成并产生结果。这就是 ThreadPoolExecutor
的原因。和 ProcessPoolExecutor
Python 中的实现不允许您生成守护进程。要求一个你实际上并不想要实现的结果的 promise 没有多大意义。
你怎么还能实现你的目标?
1 - 子类 ProcessPoolExecutor
? 可以拦截新进程的创建和启动,潜入p.daemon = True
在 _adjust_process_count()
.但是,由于 concurrent.futures
设计时没有考虑到无限期运行的任务,这不会有太大帮助。不像 multiprocessing
, concurrent.futures.process
定义一个 exit handler不考虑守护进程。它只是试图 join()
一切,这可能需要一些时间来无限循环。
2 - 定义您自己的退出处理程序! 两者都可以,multiprocessing
和 concurrent.futures.process
do:定义一个退出处理程序,在您的 Python 进程即将关闭时进行清理。 atexit可以提供帮助:
import atexit
executor_processes = ProcessPoolExecutor(2)
def calculate():
while True:
print("while")
time.sleep(1)
def end_processes():
[proc.terminate() for proc in multiprocessing.active_children()]
async def async_method():
[...]
if __name__ == '__main__':
atexit.register(end_processes)
loop = asyncio.get_event_loop()
[...]
terminate()
.
kill()
是你最后的手段。
关于python - 如何使 ProcessPoolExecutor 中的任务表现得像守护进程?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56237493/
一 点睛 线程可以设置为守护线程,ThreadGroup 也可以设置为守护 ThreadGroup,但是若将一个 ThreadGroup 设置为 deamon,也并不会影响线程的 daemon 属性,
我有一个 python 脚本需要在启动时作为守护进程运行。进程从 tty(和 pdb)分离,但代码不运行。 我已经将它缩小到一个最小的例子 import daemon from time import
reactjs isMounted API 的文档提到: You can use this method to guard asynchronous calls to setState() or fo
我正在开发一个需要嵌入 HTTP 服务器的守护进程。我正在尝试使用 BaseHTTPServer 来完成它,当我在前台运行它时,它工作正常,但是当我尝试将守护进程 fork 到后台时,它停止工作。我的
我正在尝试使用 Apache Commons Daemon 使用 Daemon 接口(interface)来守护我的应用程序。 Java 应用程序本身不执行任何操作,只是写入 stout。 我编译了j
我正在使用 Bootle Python Web Framework 在 Ubuntu 上开发网络应用程序。是否有任何有效的方法来守护启动默认 bottlepy 网络服务器的脚本? 谢谢。 UPD:现在
我一直使用 bluepill成功地守护简单的 Ruby 脚本。然而这一次,我有一个脚本,它也在加载 Rails 环境,因此我可以访问 Rails 应用程序及其各自模型的数据库连接。我使用的 bluep
我试图守护一些代码,但我遇到了一些麻烦。 如果我用 tklogger() 调用代码,它运行得很好。但是,如果我在守护程序上下文中调用它,我会得到以下跟踪信息: Traceback (most rece
我打算使用 systemd 将 celery 4.3.0 作为守护进程运行,但它给了我这个错误: 它会启动 worker 但会很快停止它们。但是,我可以通过键入以下命令手动运行工作人员: celery
我是一名优秀的程序员,十分优秀!