操作系统调优
通过对物理机和虚拟机操作系统的调优,可以有效提升服务器性能。
物理机
在物理机操作系统上的调优,需要修改GRUB参数。
- 打开“/etc/grub2-efi.cfg”文件。
vi /etc/grub2-efi.cfg
- 按“i”进入编辑模式,在内核参数后增加以下IOMMU相关配置。
iommu.passthrough=1 pci=realloc kvm-arm.vgic_v4_enable=1
kvm-arm.vgic_v4_enable=1只针对鲲鹏920新型号处理器。
- 按“Esc”键,输入:wq!,按“Enter”保存并退出编辑。
- 重启物理机的操作系统,使配置生效。
虚拟机
在虚拟机操作系统上的调优,包括设置网卡队列数以及网卡中断绑核优化。
- 设置网卡队列数为1。
- 查看网口名称。
ip a
- 设置网卡队列数。请将“网口名称”替换为实际的网口名称。
ethtool -L 网口名称 combined 1
- 查看网口名称。
- 网卡中断绑核。
- 创建一个名为irq.sh的Bash脚本文件,在脚本文件中写入以下内容,用于将网卡中断绑定到指定的CPU核上。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
#!/bin/bash iface=$1 start_core=$2 end_core=$3 irq_list=(`cat /proc/interrupts |grep ${iface} | awk -F: '{print $1}'`) ncpu=$start_core for irq in ${irq_list[@]} do echo ${ncpu} > /proc/irq/${irq}/smp_affinity_list echo `cat /proc/irq/${irq}/smp_affinity_list` (( ncpu+=1 )) if (( ${ncpu} > $end_core )); then ncpu=$start_core fi done
中断绑核传入参数说明:
- iface:网卡中断名称,例如“virtio*-input.0”,其中*表示实际的网口队列名称序号,请根据实际环境修改。
网口队列名称序号可以通过如下命令查看:
cat /proc/interrupts
- start_core:中断绑定的开始CPU核编号,例如“0”,请根据实际需求修改。
- end_core:中断绑定的结束CPU核编号,例如“1”(当只有一个核心时),请根据实际环境修改。
- iface:网卡中断名称,例如“virtio*-input.0”,其中*表示实际的网口队列名称序号,请根据实际环境修改。
- 停止并禁用irqbalance服务。
systemctl stop irqbalance systemctl disable irqbalance
- 执行脚本。
- 创建一个名为irq.sh的Bash脚本文件,在脚本文件中写入以下内容,用于将网卡中断绑定到指定的CPU核上。
父主题: Redis性能调优