當前位置: 首頁>>代碼示例>>Python>>正文


Python pool.close方法代碼示例

本文整理匯總了Python中multiprocessing.pool.close方法的典型用法代碼示例。如果您正苦於以下問題:Python pool.close方法的具體用法?Python pool.close怎麽用?Python pool.close使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在multiprocessing.pool的用法示例。


在下文中一共展示了pool.close方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: test_no_import_lock_contention

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def test_no_import_lock_contention(self):
        with test.support.temp_cwd():
            module_name = 'imported_by_an_imported_module'
            with open(module_name + '.py', 'w') as f:
                f.write("""if 1:
                    import multiprocessing

                    q = multiprocessing.Queue()
                    q.put('knock knock')
                    q.get(timeout=3)
                    q.close()
                    del q
                """)

            with test.support.DirsOnSysPath(os.getcwd()):
                try:
                    __import__(module_name)
                except pyqueue.Empty:
                    self.fail("Probable regression on import lock contention;"
                              " see Issue #22853") 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:22,代碼來源:_test_multiprocessing.py

示例2: test_unpickleable_result

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def test_unpickleable_result(self):
        from multiprocessing.pool import MaybeEncodingError
        p = multiprocessing.Pool(2)

        # Make sure we don't lose pool processes because of encoding errors.
        for iteration in range(20):

            scratchpad = [None]
            def errback(exc):
                scratchpad[0] = exc

            res = p.apply_async(unpickleable_result, error_callback=errback)
            self.assertRaises(MaybeEncodingError, res.get)
            wrapped = scratchpad[0]
            self.assertTrue(wrapped)
            self.assertIsInstance(scratchpad[0], MaybeEncodingError)
            self.assertIsNotNone(wrapped.exc)
            self.assertIsNotNone(wrapped.value)

        p.close()
        p.join() 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:23,代碼來源:_test_multiprocessing.py

示例3: test_pool_worker_lifetime_early_close

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def test_pool_worker_lifetime_early_close(self):
        # Issue #10332: closing a pool whose workers have limited lifetimes
        # before all the tasks completed would make join() hang.
        p = multiprocessing.Pool(3, maxtasksperchild=1)
        results = []
        for i in range(6):
            results.append(p.apply_async(sqr, (i, 0.3)))
        p.close()
        p.join()
        # check the results
        for (j, res) in enumerate(results):
            self.assertEqual(res.get(), sqr(j))

#
# Test of creating a customized manager class
# 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:18,代碼來源:_test_multiprocessing.py

示例4: test_large_fd_transfer

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def test_large_fd_transfer(self):
        # With fd > 256 (issue #11657)
        if self.TYPE != 'processes':
            self.skipTest("only makes sense with processes")
        conn, child_conn = self.Pipe(duplex=True)

        p = self.Process(target=self._writefd, args=(child_conn, b"bar", True))
        p.daemon = True
        p.start()
        self.addCleanup(test.support.unlink, test.support.TESTFN)
        with open(test.support.TESTFN, "wb") as f:
            fd = f.fileno()
            for newfd in range(256, MAXFD):
                if not self._is_fd_assigned(newfd):
                    break
            else:
                self.fail("could not find an unassigned large file descriptor")
            os.dup2(fd, newfd)
            try:
                reduction.send_handle(conn, newfd, p.pid)
            finally:
                os.close(newfd)
        p.join()
        with open(test.support.TESTFN, "rb") as f:
            self.assertEqual(f.read(), b"bar") 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:27,代碼來源:_test_multiprocessing.py

示例5: _listener

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def _listener(cls, conn, families):
        for fam in families:
            l = cls.connection.Listener(family=fam)
            conn.send(l.address)
            new_conn = l.accept()
            conn.send(new_conn)
            new_conn.close()
            l.close()

        l = socket.socket()
        l.bind((test.support.HOST, 0))
        l.listen()
        conn.send(l.getsockname())
        new_conn, addr = l.accept()
        conn.send(new_conn)
        new_conn.close()
        l.close()

        conn.recv() 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:21,代碼來源:_test_multiprocessing.py

示例6: test_timeout

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def test_timeout(self):
        old_timeout = socket.getdefaulttimeout()
        try:
            socket.setdefaulttimeout(0.1)
            parent, child = multiprocessing.Pipe(duplex=True)
            l = multiprocessing.connection.Listener(family='AF_INET')
            p = multiprocessing.Process(target=self._test_timeout,
                                        args=(child, l.address))
            p.start()
            child.close()
            self.assertEqual(parent.recv(), 123)
            parent.close()
            conn = l.accept()
            self.assertEqual(conn.recv(), 456)
            conn.close()
            l.close()
            p.join(10)
        finally:
            socket.setdefaulttimeout(old_timeout)

#
# Test what happens with no "if __name__ == '__main__'"
# 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:25,代碼來源:_test_multiprocessing.py

示例7: get_high_socket_fd

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def get_high_socket_fd(self):
        if WIN32:
            # The child process will not have any socket handles, so
            # calling socket.fromfd() should produce WSAENOTSOCK even
            # if there is a handle of the same number.
            return socket.socket().detach()
        else:
            # We want to produce a socket with an fd high enough that a
            # freshly created child process will not have any fds as high.
            fd = socket.socket().detach()
            to_close = []
            while fd < 50:
                to_close.append(fd)
                fd = os.dup(fd)
            for x in to_close:
                os.close(x)
            return fd 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:19,代碼來源:_test_multiprocessing.py

示例8: test_ignore

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def test_ignore(self):
        conn, child_conn = multiprocessing.Pipe()
        try:
            p = multiprocessing.Process(target=self._test_ignore,
                                        args=(child_conn,))
            p.daemon = True
            p.start()
            child_conn.close()
            self.assertEqual(conn.recv(), 'ready')
            time.sleep(0.1)
            os.kill(p.pid, signal.SIGUSR1)
            time.sleep(0.1)
            conn.send(1234)
            self.assertEqual(conn.recv(), 1234)
            time.sleep(0.1)
            os.kill(p.pid, signal.SIGUSR1)
            self.assertEqual(conn.recv_bytes(), b'x'*(1024*1024))
            time.sleep(0.1)
            p.join()
        finally:
            conn.close() 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:23,代碼來源:_test_multiprocessing.py

示例9: test_ignore_listener

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def test_ignore_listener(self):
        conn, child_conn = multiprocessing.Pipe()
        try:
            p = multiprocessing.Process(target=self._test_ignore_listener,
                                        args=(child_conn,))
            p.daemon = True
            p.start()
            child_conn.close()
            address = conn.recv()
            time.sleep(0.1)
            os.kill(p.pid, signal.SIGUSR1)
            time.sleep(0.1)
            client = multiprocessing.connection.Client(address)
            self.assertEqual(client.recv(), 'welcome')
            p.join()
        finally:
            conn.close() 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:19,代碼來源:_test_multiprocessing.py

示例10: _listener

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def _listener(cls, conn, families):
        for fam in families:
            l = cls.connection.Listener(family=fam)
            conn.send(l.address)
            new_conn = l.accept()
            conn.send(new_conn)
            new_conn.close()
            l.close()

        l = socket.socket()
        l.bind((test.support.HOST, 0))
        l.listen(1)
        conn.send(l.getsockname())
        new_conn, addr = l.accept()
        conn.send(new_conn)
        new_conn.close()
        l.close()

        conn.recv() 
開發者ID:IronLanguages,項目名稱:ironpython3,代碼行數:21,代碼來源:_test_multiprocessing.py

示例11: scrape_pages

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def scrape_pages(pages):
    for page in pages:
        make_transient(page)

    # free up the connection while doing net IO
    db.session.close()
    db.engine.dispose()

    pool = get_worker_pool()
    map_results = pool.map(scrape_with_timeout, pages, chunksize=1)
    scraped_pages = [p for p in map_results if p]
    logger.info(u'finished scraping all pages')
    pool.close()
    pool.join()

    logger.info(u'preparing update records')
    row_dicts = [x.__dict__ for x in scraped_pages]
    for row_dict in row_dicts:
        row_dict.pop('_sa_instance_state')

    logger.info(u'saving update records')
    db.session.bulk_update_mappings(PageNew, row_dicts)

    scraped_page_ids = [p.id for p in scraped_pages]
    return scraped_page_ids


# need to spawn processes from workers but can't do that if worker is daemonized 
開發者ID:ourresearch,項目名稱:oadoi,代碼行數:30,代碼來源:queue_green_oa_scrape.py

示例12: scrape_with_timeout

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def scrape_with_timeout(page):
    pool = NDPool(processes=1)
    async_result = pool.apply_async(scrape_page, (page,))
    result = None
    try:
        result = async_result.get(timeout=600)
        pool.close()
    except TimeoutError:
        logger.info(u'page scrape timed out: {}'.format(page))
        pool.terminate()

    pool.join()
    return result 
開發者ID:ourresearch,項目名稱:oadoi,代碼行數:15,代碼來源:queue_green_oa_scrape.py

示例13: _fetch_stock_data

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def _fetch_stock_data(self, stock_list):
        """獲取股票信息"""
        pool = multiprocessing.pool.ThreadPool(len(stock_list))
        try:
            res = pool.map(self.get_stocks_by_range, stock_list)
        finally:
            pool.close()
        return [d for d in res if d is not None] 
開發者ID:shidenggui,項目名稱:easyquotation,代碼行數:10,代碼來源:basequotation.py

示例14: as_bulk_resolve

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def as_bulk_resolve(candidates, threads=50):
    """
    Resolve a list of IPs to AS information.

    Returns a map of each result as a tuple of (ASN, owner) keyed to
    its candidate.  Returns None if no ASN could be found or (ASN,
    None) if an ASN was found but no owner is available.

    WARNING: This function will create a pool of up to 'threads'
    threads.
    """

    result = {}

    if not candidates:
        return result

    pool = multiprocessing.pool.ThreadPool(
        processes=min(len(candidates), threads))

    for ip, as_ in pool.imap(
            __asresolve__,
            candidates,
            chunksize=1):
        result[ip] = as_
    pool.close()
    return result 
開發者ID:perfsonar,項目名稱:pscheduler,代碼行數:29,代碼來源:psas.py

示例15: run

# 需要導入模塊: from multiprocessing import pool [as 別名]
# 或者: from multiprocessing.pool import close [as 別名]
def run(self):
        self.parent_conn.close()
        for s in iter(self.child_conn.recv, None):
            self.child_conn.send(s.upper())
        self.child_conn.close() 
開發者ID:Microvellum,項目名稱:Fluid-Designer,代碼行數:7,代碼來源:_test_multiprocessing.py


注:本文中的multiprocessing.pool.close方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。