Python Multiprocessing.Process模块中的“bootstrap”一词是指什么?

4

在Multiprocessing包中使用Process和Pool模块时,我不断遇到_bootstrap方法的引用。

从我看到的内容来看,该方法导入了multiprocessing util.py模块,并使用它的方法(结合其他几个方法)来跟踪、记录和管理子进程。

def _bootstrap(self):
    from . import util
    global _current_process

    try:
        self._children = set()
        self._counter = itertools.count(1)
        try:
            sys.stdin.close()
            sys.stdin = open(os.devnull)
        except (OSError, ValueError):
            pass
        _current_process = self
        util._finalizer_registry.clear()
        util._run_after_forkers()
        util.info('child process calling self.run()')
        try:
            self.run()
            exitcode = 0
        finally:
            util._exit_function()
    except SystemExit, e:
        if not e.args:
            exitcode = 1
        elif isinstance(e.args[0], int):
            exitcode = e.args[0]
        else:
            sys.stderr.write(str(e.args[0]) + '\n')
            sys.stderr.flush()
            exitcode = 1
    except:
        exitcode = 1
        import traceback
        sys.stderr.write('Process %s:\n' % self.name)
        sys.stderr.flush()
        traceback.print_exc()

    util.info('process exiting with exitcode %d' % exitcode)
    return exitcode

我稍微研究了一下"bootstrap"这个术语,并发现它在Python模块中以各种不同的上下文使用,除了可能在参考统计学中测量准确性的过程中(除了Twitter Bootstrap框架之外)。

但在这种情况下,函数名称似乎是指将各种元素绑定在一起的方法?是这样吗?

1个回答

6

_bootstrap 函数是在创建一个 multiprocessing.Process 后立即运行的。无论是 在它被 fork 之后

def _launch(self, process_obj):
    code = 1
    parent_r, child_w = os.pipe()
    self.pid = os.fork()
    if self.pid == 0:
        try:
            os.close(parent_r)
            if 'random' in sys.modules:
                import random
                random.seed()
            code = process_obj._bootstrap()
        finally:
            os._exit(code)
    else:
        os.close(child_w)
        util.Finalize(self, os.close, (parent_r,))
        self.sentinel = parent_r

或者在它生成后

def _main(fd):
    with os.fdopen(fd, 'rb', closefd=True) as from_parent:
        process.current_process()._inheriting = True
        try:
            preparation_data = pickle.load(from_parent)
            prepare(preparation_data)
            self = pickle.load(from_parent)
        finally:
            del process.current_process()._inheriting
    return self._bootstrap()
< p > Process 中传递的 target_bootstrap 执行:

    try:
        self.run()  # This runs target.
        exitcode = 0
    finally:
        util._exit_function()

所以在这个上下文中,“bootstrap”是指引导(或更常见的是引导)计算机。也就是说,启动时完成的第一批工作,负责实际启动您真正感兴趣的软件。对于multiprocessing_bootstrap负责执行运行target函数所需的设置,然后进行清理。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接