- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在尝试将某些流程优先于其他流程。这是我正在使用的主要脚本,模拟一个 CPU 密集型进程:
simple_app.py
import os
from multiprocessing import Pool, cpu_count
def f(x):
while True:
x*x
if __name__ == '__main__':
cpu = cpu_count()
pid = os.getpid()
print('-' * 20)
print('pid: {}'.format(pid))
print('Utilizing {} cores'.format(cpu))
print('Current niceness: {}'.format(os.nice(0)))
print('-' * 20)
pool = Pool(cpu)
pool.map(f, range(cpu))
我的下一步是生成大量(具体来说,在本例中为 9 个)运行此代码的进程:
simple_runner.sh
# Start with lowest priority
nice -19 python3 simple_app.py &
# Much higher priority
nice -0 python3 simple_app.py &
# Lower priority spawned
nice -10 python3 simple_app.py &
# Higher priority again
nice -7 python3 simple_app.py &
# Highest priority yet
nice -1 python3 simple_app.py &
# Highest priority yet
nice -0 python3 simple_app.py &
# Highest priority yet
nice -0 python3 simple_app.py &
# Highest priority yet
nice -0 python3 simple_app.py &
# Highest priority yet
nice -0 python3 simple_app.py
然后我监控每个进程,报告子 CPU 利用率,在这里:
process_reporting_server.py
import os
import time
import argparse
import pprint
from multiprocessing import Pool, cpu_count
import psutil
def most_recent_process_info(pid, interval=0.5):
while True:
proc = psutil.Process(pid)
children_cpu_percent = [child.cpu_percent(interval) for child in proc.children()]
children_cpu_percent_mean = sum(children_cpu_percent) / len(children_cpu_percent) if children_cpu_percent else -1.
print('Time: {}, PID: {}, niceness: {}, average child CPU percent: {:.2f}'.format(
time.ctime(),
pid,
proc.nice(),
children_cpu_percent_mean)
)
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('-p', '--pids', type=str, help='Whitespace-delimited string containing PIDs', dest='pids')
parser.add_argument('-s', '--seconds', type=int, help='Seconds to sleep', default=10, dest='seconds')
args = parser.parse_args()
pids = list(map(int, args.pids.split()))
pool = Pool(len(pids))
pool.map(most_recent_process_info, pids)
我想看看给出较低 niceness 值的进程是否真的被优先考虑。所以这就是我所做的:
运行simple_app_runner.sh
:
$ ./simple_app_runner.sh
--------------------
pid: 45036
Utilizing 8 cores
Current niceness: 0
--------------------
--------------------
pid: 45030
Utilizing 8 cores
Current niceness: 19
--------------------
--------------------
pid: 45034
Utilizing 8 cores
Current niceness: 1
--------------------
--------------------
pid: 45032
Utilizing 8 cores
Current niceness: 10
--------------------
--------------------
pid: 45033
Utilizing 8 cores
Current niceness: 7
--------------------
--------------------
pid: 45037
Utilizing 8 cores
Current niceness: 0
--------------------
--------------------
pid: 45038
Utilizing 8 cores
Current niceness: 0
--------------------
--------------------
pid: 45031
Utilizing 8 cores
Current niceness: 0
--------------------
--------------------
pid: 45035
Utilizing 8 cores
Current niceness: 0
--------------------
然后,这是报告:
$ python3 process_reporting_server.py -p '45036 45030 45034 45032 45033 45037 45038 45031 45035'
稍微清理一下并使用 pandas 进行分析,我们发现在五分钟的时间间隔内,指定的良好度似乎并不重要:
>>> df.groupby('nice')['mean_child_cpu'].max()
nice
0.0 10.50
1.0 9.75
7.0 8.28
10.0 8.50
19.0 21.97
我在这里完全遗漏了什么吗?为什么我指定的 niceness 似乎不会影响 CPU 资源的优先级排序?
最佳答案
我认为您没有遗漏任何东西。我的经验是,最重要的过程得到优先考虑,其他人都在为剩下的事情而战。如果仅将一个进程重新设置为 -1 并将其余进程保留为 -0,您可能会得到相同的结果(对于像这样的纯 cpu 绑定(bind)进程)。
而且,这是因为人们通常真的不希望优先级排序像我们有时期望的那样硬核。就像现在我发布这个时我的平均负载超过 200,并且有一堆 reniced(更高优先级)进程在运行。如果所有这些过程都真的很麻烦,那么它就不会“很好”。我喜欢这样,我仍然可以在所有 CPU 负载持续的情况下使用我的浏览器。
有一次我的印象是你可以改变优先级队列,至少在一些 unix 上是这样。我依稀记得我的一些客户要求我们这样做,我们(系统管理员团队)说“这不是一个好主意”,客户要求我们这样做,我们就这样做”,然后客户要求我们撤消它。调度是棘手的事情。
这里介绍了幕后发生的事情:http://www.cs.montana.edu/~chandrima.sarkar/AdvancedOS/SchedulingLinux/index.html请特别注意底部部分 - “该算法不能很好地扩展”,它与我的第一段密切相关。
关于python - 测试 niceness 是否被正确应用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53524339/
我知道 os.nice(20) 设置了 linux 上的最大 nice 级别。 但我不知道其他 unix 的值(value)(我不关心 MS-Win)。 我可以在 python 中使用最大 nice
我在 iostat 命令的手册中搜索了关于 %nice.在explanation在 %nice 的值中,有一个关于 nice 优先级的短语。我不明白它的意思,有人可以解释一下吗? 手册页中的完整注释如
我的一个容器总是很忙,并且正在从其他需要响应且仅不时处于事件状态的容器(网络服务器)中占用 CPU。 我想降低CPU消耗容器的CPU优先级,这样每当其他容器需要CPU时,它就不会被阻塞。 我该怎么做?
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve th
更改调用进程优先级的函数(例如:nice())应该作为库调用还是系统调用来实现?我在网上阅读有关它的信息,据我了解,它曾经是一个系统调用,但现在是一个库调用。为什么会这样? 最佳答案 所有函数都是库调
注意:这不适用于网页,它是一个简单的程序,它包含一组图像并会随机选择一些图像并将它们显示在屏幕上。想象一下使用图像编辑器并在 Canvas 上手动定位导入的图像。 我很难想出一种在固定尺寸的屏幕(它只
我需要一个相当聪明的算法来为图形(图表)设计出“漂亮”的网格线。 例如,假设一个条形图的值为 10、30、72 和 60。您知道: 最小值:10最大值:72范围:62 第一个问题是:你从什么开始?在这
是否有与 Unix 命令等效的 Windows 命令,nice? 我专门寻找可以在命令行使用的东西,不是任务管理器中的“设置优先级”菜单。 我试图在 Google 上找到它,但遭到无法想出更好形容词的
这个问题在这里已经有了答案: is nice() used to change the thread priority or the process priority? (3 个答案) 关闭 1 年
nice 的手册页说“nice() 将 inc 添加到 calling process 的 nice 值中。那么,我们可以使用它来更改 nice 值吗? pthread_create 创建的线程? 编
我想远程制作类似于DinahMoe's "plink"的东西。在plink中,单击鼠标可播放音高与鼠标高度成比例的音符。我可以看到高度被划分为多个“条纹”,因此,当您移动鼠标时,您没有某种“滑动”的声
我正在开发一个使用 nice select 的脚本: تعداد حمام 1 حمام 2 حمام 3 حمام 4 حم
如何将 double 格式化为字符串,以便它显示所有(无限制)小数位(如果有)但不显示任何尾随 0? 最佳答案 double x = ...; DecimalFormat fmt = new Deci
我添加了一个 Plunker在这里,如果您在下拉列表中选择团队 2,域将设置为 9,而不是我期望的值,即 10。 在documentation它说明了以下有关 nice() 的内容 Extends t
如何使用带别名的“nice”命令? 举个例子: alias list=ls list # works nice -10 list # doesn't work 我怎样才能使最后一行起作用? 最佳答案
我目前正在修改我们现有的专有套接字包装器代码以使用 boost asio,以便它可以为我们完成一些繁重的工作。也许我们现有代码中最复杂的部分是多播处理代码。该代码允许我们的中间层服务器(一个系统中可以
我正在使用 hernansartorio/jquery-nice-select插件并试图让它截断长命名选项字符串。 当溢出设置为隐藏时,选择无法正常工作 - 当点击的下拉菜单不出现时。 (它出现但未显
我有一个 C++ (VS2010) 类(class)。 此类具有公共(public)函数,例如“ToString”。 有时我需要从类中调用 ToString。 例如: void::ConvertToL
最近从top的结果中,发现一个进程的nice值设置为10。看起来是内核做的,因为进程长时间占用大量cpu。 但是,据我所知,nice 值是由用户设置的,用于为进程指定静态优先级。而且我不确定内核是否会
我正在尝试将某些流程优先于其他流程。这是我正在使用的主要脚本,模拟一个 CPU 密集型进程: simple_app.py import os from multiprocessing import P
我是一名优秀的程序员,十分优秀!