解决方案:
isolcpus= "10-15,50-55"
def parse_cpumask(isolcpus,cpu_len=80):
isolcpus_list = isolcpus.split(",")
cpumask_list = [1]*cpu_len
for cpus_list in isolcpus_list:
cpus = [int(cpu) for cpu in cpus_list.split("-")]
cpumask_list[cpus[0]:cpus[-1]+1]=[0]*(cpus[-1]-cpus[0]+1)
cpu_str = "".join([str(i) for i in cpumask_list[::-1]])
cpumask = hex(int(cpu_str,2))[2:]
return cpumask
parse_cpumask(isolcpus) #ffffff03ffffffff03ff
函数解析:isolcpus这是一个设置隔离cpu的字符串,"10-15,50-55"指的是隔离10到15核,50到55核。cpu_len表示linux系统cpu的总的核数。该函数将隔离的cpu对应的核数转化为对应的cpumask。本质是一个二进制,十六进制之间的转化。
使用场景:
在linux服务器中,我们有时需要隔离出几个cpu用于特殊场景使用,这就需要修改系统启动文件,并且在内核参数中添加isolcpus=10-15,50-55。然后我们在设定系统某些工作队列的时候,我们希望这个工作队列中存放隔离cpu中的任务,以防止其他核任务的干扰,这时我们就需要将这些隔离的cpu转化为对应的cpu掩码,然后配置到工作队列中。就可以使用parse_cpumask函数进行解析。然后配置。如
echo ffff,ff03ffff,ffff03ff > /sys/kernel/pcrypt/pdecrypt/serial_cpumask
echo ffff,ff03ffff,ffff03ff > /sys/kernel/pcrypt/pdecrypt/parallel_cpumask