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


Python psutil.STATUS_ZOMBIE屬性代碼示例

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


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

示例1: crawl_connections

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def crawl_connections():
    created_since = -1

    proc_list = psutil.process_iter()

    for p in proc_list:
        pid = (p.pid() if hasattr(p.pid, '__call__') else p.pid)
        status = (p.status() if hasattr(p.status, '__call__'
                                        ) else p.status)
        if status == psutil.STATUS_ZOMBIE:
            continue

        create_time = (
            p.create_time() if hasattr(
                p.create_time,
                '__call__') else p.create_time)
        name = (p.name() if hasattr(p.name, '__call__') else p.name)

        if create_time <= created_since:
            continue
        for conn in p.get_connections():
            yield crawl_single_connection(conn, pid, name) 
開發者ID:cloudviz,項目名稱:agentless-system-crawler,代碼行數:24,代碼來源:connection_utils.py

示例2: on_ready

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def on_ready():
    await asyncio.sleep(1)
    voice_channel = client.get_channel(int(voice_id))
    while not client.is_closed():
        vc = await voice_channel.connect()
        vc.play(discord.FFmpegPCMAudio(filename))
        vc.source = discord.PCMVolumeTransformer(vc.source)
        vc.source.volume = 10.0
        while vc.is_playing():
            if sys.platform.startswith('linux'):
                proc = psutil.Process(int(parentprocess))
                if proc.status() == psutil.STATUS_ZOMBIE:
                    await client.logout()
                    sys.exit()
            if not psutil.pid_exists(int(parentprocess)):  # Parent is dead, Kill self :cry:
                await client.logout()
                sys.exit()
            await asyncio.sleep(0.5)
        await vc.disconnect(force=True) 
開發者ID:DeadBread76,項目名稱:Raid-Toolbox,代碼行數:21,代碼來源:vcspam.py

示例3: BlockOnProcessPID

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def BlockOnProcessPID(self, pid, create_time, timeout=None):
        if pid is None:
            return
        p = None
        try:
            p = self.GetProcessByPID(pid, create_time)
            if p is not None and p.is_running() and p.status not in [psutil.STATUS_ZOMBIE, psutil.STATUS_DEAD]:
                val = p.wait(timeout)
                if val is None:
                    self.logger.debug("Process is terminated ")
                else:
                    self.logger.debug("Process is terminated, possibly by os ")
        except psutil.TimeoutExpired:
            self.logger.info("TimeoutExpired happens")
            if p is not None:
                self.logger.info("kill process")
                self.TerminateProcessTree(pid, create_time)
        except Exception:
            self.logger.debug("Process is terminated for unknown reasons")
            pass
        return 
開發者ID:openweave,項目名稱:happy,代碼行數:23,代碼來源:HappyProcess.py

示例4: _cleanup_worker_processes

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def _cleanup_worker_processes(self):
        # cleanup children
        to_remove = []
        for pid, child in self._processes.items():
            try:
                name, status = child.name(), child.status()
            except psutil.NoSuchProcess:  # May be untimely deceased
                name, status = "unknown", "unknown"
            logger.debug("  child: name=%s pid=%d status=%s" % (name, child.pid, status))
            if status in (psutil.STATUS_ZOMBIE, "unknown"):
                logger.debug("  process {} is zombie, will cleanup".format(child.pid))
                # join process to clean it up
                child.wait()
                # set the process to be removed from self._processes
                to_remove.append(pid)

        # cleanup our internal state (self._processes)
        for pid in to_remove:
            del self._processes[pid] 
開發者ID:botify-labs,項目名稱:simpleflow,代碼行數:21,代碼來源:supervisor.py

示例5: exists

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def exists(pid, time, delta_seconds=3, zombie_seconds=10):
    if not ps.pid_exists(pid):
        log.debug(f'Process {pid} does not exist')
        return False
    process = ps.Process(pid)
    if process.status() == ps.STATUS_ZOMBIE:
        try:
            log.warning(f'Waiting for zombie {pid}')
            process.wait(zombie_seconds)
        except ps.TimeoutExpired:
            log.debug(f'Timeout waiting for zombie {pid}')
        return False
    elif delta_seconds:
        creation_ok = abs(process.create_time() - time.timestamp()) < delta_seconds
        if creation_ok:
            log.debug(f'Process {pid} still exists')
        else:
            log.debug(f'Creation time for process {pid} incorrect ({process.create_time()} / {time.timestamp()})')
        return creation_ok
    else:
        log.debug(f'Assuming process {pid} is same as expected')
        return True   # if delta_seconds = 0 don't check, just assume same 
開發者ID:andrewcooke,項目名稱:choochoo,代碼行數:24,代碼來源:system.py

示例6: set_zombie_refresh_to_fail

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def set_zombie_refresh_to_fail(self, refresh_job):
        current_pid = refresh_job.pid
        if current_pid is None:
            return

        p = psutil.Process(current_pid)
        if p.status() != psutil.STATUS_ZOMBIE:
            return

        refresh = self.schematizer.get_refresh_by_id(
            refresh_job.refresh_id
        )
        if refresh.status == RefreshStatus.IN_PROGRESS:
            # Must update manually (not relying on the signal),
            # as the process may not properly handle the signal
            # if it's a zombie
            self.schematizer.update_refresh(
                refresh_id=refresh_job.refresh_id,
                status=RefreshStatus.FAILED,
                offset=0
            )
            source = refresh_job.source
            del self.active_refresh_jobs[source]
        os.kill(current_pid, signal.SIGINT) 
開發者ID:Yelp,項目名稱:data_pipeline,代碼行數:26,代碼來源:refresh_manager.py

示例7: crawl

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def crawl(self, vm_desc, **kwargs):
        created_since = -1

        if psvmi is None:
            raise NotImplementedError()
        else:
            (domain_name, kernel_version, distro, arch) = vm_desc
            # XXX: this has to be read from some cache instead of
            # instead of once per plugin/feature
            vm_context = psvmi.context_init(
                domain_name, domain_name, kernel_version, distro, arch)
            proc_list = psvmi.process_iter(vm_context)

        for p in proc_list:
            pid = (p.pid() if hasattr(p.pid, '__call__') else p.pid)
            status = (p.status() if hasattr(p.status, '__call__'
                                            ) else p.status)
            if status == psutil.STATUS_ZOMBIE:
                continue

            create_time = (
                p.create_time() if hasattr(
                    p.create_time,
                    '__call__') else p.create_time)
            name = (p.name() if hasattr(p.name, '__call__') else p.name)

            if create_time <= created_since:
                continue
            for conn in p.get_connections():
                yield crawl_single_connection(conn, pid, name) 
開發者ID:cloudviz,項目名稱:agentless-system-crawler,代碼行數:32,代碼來源:connection_vm_crawler.py

示例8: test_create_zombie_proc

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def test_create_zombie_proc(self):
        zpid = create_zombie_proc()
        self.addCleanup(reap_children, recursive=True)
        p = psutil.Process(zpid)
        self.assertEqual(p.status(), psutil.STATUS_ZOMBIE) 
開發者ID:birforce,項目名稱:vnpy_crypto,代碼行數:7,代碼來源:test_misc.py

示例9: test_zombie_process_status_w_exc

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def test_zombie_process_status_w_exc(self):
        # Emulate a case where internally status() raises
        # ZombieProcess.
        p = psutil.Process()
        with mock.patch("psutil._psplatform.Process.status",
                        side_effect=psutil.ZombieProcess(0)) as m:
            self.assertEqual(p.status(), psutil.STATUS_ZOMBIE)
            assert m.called 
開發者ID:birforce,項目名稱:vnpy_crypto,代碼行數:10,代碼來源:test_process.py

示例10: create_time

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def create_time(self, ret, proc):
        self.assertIsInstance(ret, float)
        try:
            self.assertGreaterEqual(ret, 0)
        except AssertionError:
            # XXX
            if OPENBSD and proc.status() == psutil.STATUS_ZOMBIE:
                pass
            else:
                raise
        # this can't be taken for granted on all platforms
        # self.assertGreaterEqual(ret, psutil.boot_time())
        # make sure returned value can be pretty printed
        # with strftime
        time.strftime("%Y %m %d %H:%M:%S", time.localtime(ret)) 
開發者ID:birforce,項目名稱:vnpy_crypto,代碼行數:17,代碼來源:test_contracts.py

示例11: test_pidtask_info

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def test_pidtask_info(self):
        self.assertEqual(self.p.status(), psutil.STATUS_ZOMBIE)
        self.p.ppid()
        self.p.uids()
        self.p.gids()
        self.p.terminal()
        self.p.create_time() 
開發者ID:birforce,項目名稱:vnpy_crypto,代碼行數:9,代碼來源:test_osx.py

示例12: test_zombie_process

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def test_zombie_process(self):
        def succeed_or_zombie_p_exc(fun):
            try:
                return fun()
            except (psutil.ZombieProcess, psutil.AccessDenied):
                pass

        parent, zombie = self.spawn_zombie()
        # A zombie process should always be instantiable
        zproc = psutil.Process(zombie.pid)
        # ...and at least its status always be querable
        self.assertEqual(zproc.status(), psutil.STATUS_ZOMBIE)
        # ...and it should be considered 'running'
        assert zproc.is_running()
        # ...and as_dict() shouldn't crash
        zproc.as_dict()
        # ...its parent should 'see' it (edit: not true on BSD and MACOS
        # descendants = [x.pid for x in psutil.Process().children(
        #                recursive=True)]
        # self.assertIn(zpid, descendants)
        # XXX should we also assume ppid be usable?  Note: this
        # would be an important use case as the only way to get
        # rid of a zombie is to kill its parent.
        # self.assertEqual(zpid.ppid(), os.getpid())
        # ...and all other APIs should be able to deal with it

        ns = process_namespace(zproc)
        for fun, name in ns.iter(ns.all):
            succeed_or_zombie_p_exc(fun)

        assert psutil.pid_exists(zproc.pid)
        if not TRAVIS and MACOS:
            # For some reason this started failing all of the sudden.
            # Maybe they upgraded MACOS version?
            # https://travis-ci.org/giampaolo/psutil/jobs/310896404
            self.assertIn(zproc.pid, psutil.pids())
            self.assertIn(zproc.pid, [x.pid for x in psutil.process_iter()])
            psutil._pmap = {}
            self.assertIn(zproc.pid, [x.pid for x in psutil.process_iter()]) 
開發者ID:giampaolo,項目名稱:psutil,代碼行數:41,代碼來源:test_process.py

示例13: create_time

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def create_time(self, ret, info):
        self.assertIsInstance(ret, float)
        try:
            self.assertGreaterEqual(ret, 0)
        except AssertionError:
            # XXX
            if OPENBSD and info['status'] == psutil.STATUS_ZOMBIE:
                pass
            else:
                raise
        # this can't be taken for granted on all platforms
        # self.assertGreaterEqual(ret, psutil.boot_time())
        # make sure returned value can be pretty printed
        # with strftime
        time.strftime("%Y %m %d %H:%M:%S", time.localtime(ret)) 
開發者ID:giampaolo,項目名稱:psutil,代碼行數:17,代碼來源:test_contracts.py

示例14: test_spawn_zombie

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def test_spawn_zombie(self):
        parent, zombie = self.spawn_zombie()
        self.assertEqual(zombie.status(), psutil.STATUS_ZOMBIE) 
開發者ID:giampaolo,項目名稱:psutil,代碼行數:5,代碼來源:test_testutils.py

示例15: list

# 需要導入模塊: import psutil [as 別名]
# 或者: from psutil import STATUS_ZOMBIE [as 別名]
def list():
    """List running TensorBoard instances."""

    running_list = []
    parser = argparse.ArgumentParser()
    parser.add_argument('--logdir')
    parser.add_argument('--port')
    for p in psutil.process_iter():
      if p.name() != 'tensorboard' or p.status() == psutil.STATUS_ZOMBIE:
        continue
      cmd_args = p.cmdline()
      del cmd_args[0:2]  # remove 'python' and 'tensorboard'
      args = parser.parse_args(cmd_args)
      running_list.append({'pid': p.pid, 'logdir': args.logdir, 'port': args.port})
    return pd.DataFrame(running_list) 
開發者ID:googledatalab,項目名稱:pydatalab,代碼行數:17,代碼來源:_tensorboard.py


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