14

我有一些托管在 Windows 服务中的 WCF 服务。昨天我查看任务管理器,发现我的 windows 服务进程的 CPU 时间超过 5 小时,而所有其他进程的大部分时间都是 0。

这意味着什么?

我应该担心 CPU 时间超过 5 小时吗?

4

4 回答 4

18

CPU 时间表示自进程启动以来进程使用了​​多少处理时间(在 Windows 中:指向Technet 文章的链接。)

基本上是这样计算的:

CPU Time of Process = Process Uptime * CPU Utilization of Process

例如,如果进程已经运行了 5 个小时,而 CPU 时间为 5 个小时,那么这意味着该进程一直在使用 100% 的 CPU 资源。这可能是好事也可能是坏事,这取决于您是想保持较低的资源消耗,还是想利用系统的全部功能。

如果进程使用 50% 的 CPU 资源并运行 10 小时,则 CPU 时间将为 5 小时。

于 2009-05-08T13:56:41.657 回答
3

CPU 时间反映了您的程序在 CPU 中执行指令与等待 IO 或其他资源所花费的时间。您是否应该担心它超过 5 小时?

我猜不是,需要考虑的一些事情是:

  1. 这个过程运行了多长时间?

  2. 您对可能窃取 CPU 的进程或其他进程的性能有任何问题吗?

  3. 您还有哪些其他流程?这些活动进程是您希望使用 CPU 的吗?作为 80 个进程的参考,我有大约 20 个使用了超过 1 秒的 CPU 时间。

编辑

WCF 服务可能正在从其他服务窃取 CPU,您需要监控它们以确保它们的性能符合您的预期。您还可以根据总 CPU 使用情况来了解情况。例如,如果您只看到 25% 的 CPU 被使用,那么您的其他服务不应该受到影响;但是,如果您的运行率高于 75%,那么他们可能会受到影响。

当涉及到监控时,一定要随着时间的推移进行监控,这样您就可以看到性能趋势如何,它将帮助您隔离问题。例如,您的服务运行良好,但在部署后它慢慢开始占用越来越多的 CPU(假设每周 10%)。除非您对 CPU 使用率进行趋势分析,否则您可能有一天醒来并看到您的服务运行缓慢,这可能是部署后的数周。

于 2009-05-08T13:56:23.840 回答
1

如果您担心您的进程正在使用多少 CPU 时间,您应该使用perfmon来长时间跟踪您的进程的 CPU 使用率,以确定您是否有问题。

于 2009-05-08T22:10:37.320 回答
0

任务管理器中的 CPU 时间到底是什么?

答案很简单:

自启动以来进程使用的总处理器时间(以秒为单位)。

于 2014-04-30T08:58:23.850 回答