判断Linux 进程运行在哪个 CPU 内核上的 几种方法
如果一个进程使用 taskset 命令明确的被固定(pinned)到 CPU 的特定内核上,你可以使用 taskset 命令找出被固定的 CPU 内核:
  $ taskset -c -p
  例如, 如果你对 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 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