3

我有一台双四核机器。所以,我的cpu列表是0-7。

我正在尝试从 python 运行任务集

mapping = [2,2,2,2,2]
for i in range(0,len(mapping)):
        cmd = "taskset -c" +  str(mapping[r]) + "python <path>/run-apps.py" + thr[r] + "&"
        os.system(cmd)

它说:

taskset: invalid option -- '2'
taskset (util-linux-ng 2.17.2)
usage: taskset [options] [mask | cpu-list] [pid | cmd [args...]]
set or get the affinity of a process

  -p, --pid                  operate on existing given pid
  -c, --cpu-list             display and specify cpus in list format
  -h, --help                 display this help
  -V, --version              output version information

The default behavior is to run a new command:
  taskset 03 sshd -b 1024
You can retrieve the mask of an existing task:
  taskset -p 700
Or set it:
  taskset -p 03 700
List format uses a comma-separated list instead of a mask:
  taskset -pc 0,3,7-11 700
Ranges in list format can take a stride argument:
  e.g. 0-31:2 is equivalent to mask 0x55555555

但是核心 2 是可用的,我要运行同样的东西commandline.

taskset -c 2 python <path>/run-apps.py lbm &

不知道是什么问题..

任何提示?

4

3 回答 3

5

您可以避免调用任务集并改用 psutil: https ://pythonhosted.org/psutil/#psutil.Process.cpu_affinity

>>> import psutil
>>> psutil.cpu_count()
4
>>> p = psutil.Process()
>>> p.cpu_affinity()  # get
[0, 1, 2, 3]
>>> p.cpu_affinity([0])  # set; from now on, process will run on CPU #0 only
>>> p.cpu_affinity()
[0]
>>>
>>> # reset affinity against all CPUs
>>> all_cpus = list(range(psutil.cpu_count()))
>>> p.cpu_affinity(all_cpus)
>>>
于 2016-11-29T01:43:57.290 回答
3

与您发布的命令行相比,您缺少几个空格...例如:

cmd = "taskset -c " +  str(mapping[r]) + " python <path>/run-apps.py " + thr[r] + " &"

在您的代码中,当解析“命令行”时,taskset看到的字符串-c2根据许多命令行解析库与-c -2解释您所看到的错误的内容相同。

有时,如果您使用字符串插值代替,这些内容会更容易阅读:

cmd = "taskset -c %s python <path>/run-apps.py %s &" % (mapping[r],thr[r])

或新风格.format

cmd = "taskset -c {0} python <path>/run-apps.py {1} &".format(mapping[r],thr[r])

最后,如果不提及 python模块,任何解决方案os.system都不应该使用。subprocess

process = subprocess.Popen(['taskset',
                            '-c',
                            str(mapping[r]),
                            'python',
                            '<path>/run-apps.py',
                            str(thr[r]) ] )

它将完全避免使用 shell,这会稍微更有效,并使您免受 shell 注入类型的攻击。

于 2013-02-05T20:53:22.143 回答
0

你缺少空格。为了帮助自己尝试以下方法:

  1. 注释掉 os.system() 行
  2. 在 os.system() 行下方,添加:

    打印命令

你会看到你的命令行是什么样子的。在需要的地方添加空格。然后取消注释 os.system() 行。

于 2013-02-05T21:01:32.943 回答