判断Linux 进程运行在哪个 CPU 内核上的 几种方法 如果一个进程使用 taskset 命令明确的被固定(pinned)到 CPU 的特定内核上,你可以使用 taskset 命令找出被固定的 CPU 内核:   $ taskset -c -p <pid>   例如, 如果你对 PID 5357 这个进程有兴趣:   $ taskset -c -p 5357   pid 5357's current affinity list: 5   输出显示这个过程被固定在 CPU 内核 5上。   但是,如果你没有明确固定进程到任何 CPU 内核,你会得到类似下面的亲和力列表。   pid 5357's current affinity list: 0-11   输出表明该进程可能会被安排在从0到11中的任何一个 CPU 内核。在这种情况下,taskset 不能识别该进程当前被分配给哪个 CPU 内核,你应该使用如下所述的方法。   方法二   ps 命令可以告诉你每个进程/线程目前分配到的 (在“PSR”列)CPU ID。   $ ps -o pid,psr,comm -p <pid>   PID PSR COMMAND   5357 10 prog   输出表示进程的 PID 为 5357(名为”prog”)目前在CPU 内核 10 上运行着。如果该过程没有被固定,PSR 列会根据内核可能调度该进程到不同内核而改变显示。   方法三   top 命令也可以显示 CPU 被分配给哪个进程。首先,在top 命令中使用“P”选项。然后按“f”键,显示中会出现 “Last used CPU” 列。目前使用的 CPU 内核将出现在 “P”(或“PSR”)列下。   $ top -p 5357

平均分配php-fpm进程到对应的每个CPU上脚本
[root@localhost ~]# cat task.sh 
#!/bin/bash
CPUS=$(grep -c CPU /proc/cpuinfo)
PIDS=$(ps aux | grep "php-fpm[:] pool" | awk '{print $2}')

let i=0
for PID in $PIDS; do
  CPU=$(echo "$i % $CPUS" | bc)
  taskset -pc $CPU $PID
  let i++
done

平均分配nginx的work进程到对应的每个CPU上脚本

#!/bin/bash CPUS=$(grep -c CPU /proc/cpuinfo) PIDS=$(ps aux | grep "nginx: worker process" | awk '{print $2}')

let i=0 for PID in $PIDS; do CPU=$(echo "$i % $CPUS" | bc) taskset -pc $CPU $PID let i++ done