2

GNU make 可以使用 -jN 参数处理并行任务,并且通常使用的任务数 N 是用于构建的计算机上硬件线程数的 1 到 2 倍。

例如,在双 E5520 机器(2 个 CPU,每个 CPU 4 个内核,每个内核 2 个线程)上,最快的构建是使用 make -j16 和 make -j32 之间的命令进行的。

现在我对我的构建服务器不太了解,但是当我运行时cat /proc/cpuinfo

它显示它有 4 个处理器,每个信息都是这样的

processor   : 0
vendor_id   : GenuineIntel
cpu family  : 6
model       : 37
model name  : Intel(R) Core(TM) i3 CPU         530  @ 2.93GHz
stepping    : 2
cpu MHz     : 2933.000
cache size  : 4096 KB
physical id : 0
siblings    : 4
core id     : 0
cpu cores   : 2
apicid      : 0
initial apicid  : 0
fpu     : yes
fpu_exception   : yes
cpuid level : 11
wp      : yes
flags       : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe syscall nx rdtscp lm constant_tsc arch_perfmon pebs bts rep_good xtopology nonstop_tsc aperfmperf pni dtes64 monitor ds_cpl vmx est tm2 ssse3 cx16 xtpr pdcm sse4_1 sse4_2 popcnt lahf_lm arat tpr_shadow vnmi flexpriority ept vpid
bogomips    : 5851.87
clflush size    : 64
cache_alignment : 64
address sizes   : 36 bits physical, 48 bits virtual
power management:

问题:

1>那么在这里我如何为我的构建计算 N?

2>如果我的系统最多可以支持 8 个线程,如果我放弃了make -j32怎么办?

3>如果我只使用 make 那么只会运行 1 个线程进行编译怎么办?

4

1 回答 1

2

使用 -j 选项不会伤害任何东西。它仅用于调整 make 应该使用的同时处理的数量,以便从系统中获得最大的性能来进行构建。

如果您想让 CPU 时间更多地用于您正在做的其他事情(也许更快的浏览响应),您可以将其设置为小于 4,每个内核 x 2 个超线程。

您可以将其设置为 4 以上,以便其中一个进程使用每个执行单元,而其他处理器正在等待 I/O。

如果你有足够的内存 -j32 应该不会伤害任何东西,但它也无济于事。请参阅评论,了解您不想过度使用的原因。

如果您一直在制作一个软件包,您可以进行试验,看看哪种设置可以使其构建速度最快,而不会影响您的交互性能。另一种调优方法是查看最高输出并查看 -j 多处理级别在大多数情况下保持 CPU 利用率接近 100%。

在他的Linux Kernel in a Nutshell book [1] 中,Greg Kroah-Hartman 建议在设置 -j 选项时将执行单元的数量增加一倍。对你来说就是这样-j8

[1]简而言之Linux 内核,Greg Kroah-Hartman,pg。26. [ http://www.kroah.com/lkn/]

于 2012-05-25T04:32:39.347 回答