AnolisOS 入门八:使用keentune(轻豚) 调优系统性能

2023-10-31 07:20

本文主要是介绍AnolisOS 入门八:使用keentune(轻豚) 调优系统性能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Anolis 龙蜥社区https://openanolis.cn/轻豚主站https://openanolis.cn/sig/KeenTune

注意:使用keentune 前您应当对服务器硬件、Linux核心参数、网络通讯等知识领域有所了解

警告: 错误的使用调试工具,可能会使服务中断,请谨慎使用!

简介:

        性能调优,是一个将硬件、软件、操作系统融会贯通,将性能发挥到极致的过程。通常调校的目标是以用户的期望为依据,因此,调校的目标往往是符合用户的期盼即可。

1.安装:

       最低硬件要求:2核4G 10G可用磁盘空间

        这里使用dnf的方式,单机部署,有能力的同学可以使用源代码(git)编译的方式安装。       

#1.添加软件源
curl -o /etc/yum.repos.d/anolisos-experimental.repo  https://gitcode.net/-/snippets/1745/raw/master/anolisos-experimental.repo#2.安装Keentune 相关软件
dnf install -y keentuned keentune-brain keentune-bench keentune-target#3.安装依赖软件
dnf install -y python36 python36-devel go #4.pip切换国内源(可选)
mkdir ~/.pip
curl -o ~/.pip/pip.conf https://gitcode.net/-/snippets/1749/raw/master/pip.conf#4.安装python3相关软件,注意:至少需要2G以上硬盘空间!!!
pip3 install --upgrade pip
pip3 install numpy==1.19.5 POAP==0.1.26 tornado==6.1 hyperopt==0.2.5 ultraopt==0.1.1 bokeh==2.3.2 requests==2.25.1 pySOT==0.3.3 scikit_learn==0.24.2 paramiko==2.7.2 PyYAML==5.4.1 pynginxconfig#5.设置go 环境
go env -w GO111MODULE=on
go env -w GOPROXY=https://goproxy.cn,direct

二、启动

#1. 启动keentune相关服务
systemctl start keentuned keentune-brain keentune-target keentune-bench#1. 查看服务状态
systemctl status keentuned keentune-brain keentune-target keentune-bench#2.设置开机自动启动(可选)
systemctl enable keentuned keentune-brain keentune-target keentune-bench

使用 netstat -an | grep 98  确认从 9870-9874 的端口都已经开启 

注:如果有端口没有成功启动,请逐一对服务进行排查

三、简单使用

keentune 拥有两种性能调优模式,基于AI 的动态调优和基于预设场景的静态调优,这里我们选择静态调优继续:

通过 keentune profile list 可以看到,已经预设了5种使用场景

  1. cpu_high_load 高CPU负载
  2. io_high_throughput 高IO吞吐量
  3. mysql_tpcc MYSQL 的TPCC优化
  4. net_high_throuput 高网络吞吐量
  5. net_low_latency 网络低延迟
#查看帮助
keentune -h#查看静态配置
keentune profile list

#查看指定配置的参数
keentune profile info --name cpu_high_load.conf

#使 cpu_high_load 配置生效
keentune profile set --name cpu_high_load.conf

设置成功后可以看到 [ok]状态,共有多少参数设置成功

使用sysctl -a  查看设置成功后的参数(此处以swappiness为例)

 注意:keentune 只是调整了运行值,重启后会恢复原值

恢复初始状态: 

# 恢复初始状态
keentune profile rollback

四、其他

1)手动调整预置场景参数

#目录下存放着所有预置场景的配置文件
/etc/keentune/profile 

上述目录存放着所有预置场景的配置文件,可以根据自己的经验、服务器配置对预设场景的参数进行手动调整 

2)使用网络预设场景时可能会遇到的问题

#应用 网络高负载或者 低延时场景时
#会遇到如下错误:keentune profile set --name net_low_latency.conf
[ERROR] profile.Set failed, msg: Prepare before Set err:exec backup failed, err:response suc is false, msg is map[sysctl:sysctl: cannot stat /proc/sys/net/generic-receive-offload: No such file or directory]

 是因为配置文件中的如下参数造成的:

net.mtu: 1500
net.generic-receive-offload: off
net.generic-segmentation-offload: off
net.tcp-segmentation-offload: off

        由于在新的Linux 内核中 网卡的gro、gso、tso 设置已经交由 ethtool 工具来设置,解决方法如下:

        使用vi 等文本编辑工具,将 上述4条内容从 net_low_latency.conf 中删除,再执行如下命令:

#ethtool 关闭 gro gso tso,注:重启后会恢复默认值
#ethtool -K 网卡名称 命令
ethtool -K eth0 gro off 
ethtool -K eth0 gso off
ethtool -K eth0 tso off#设置mtu 1500
echo "1500" > /sys/class/net/eth0/mtu#启用策略
keentune profile set --name net_low_latency.conf

五、最后

        所谓前人种树后人白嫖,本文志在抛砖引玉,从官方文档可以看出基于AI的动态参数调整才是keentune 的核心价值所在。

参考文献:

https://openanolis.cn/sig/KeenTune

https://gitee.com/anolis/keentuned
https://gitee.com/anolis/keentune_bench
https://gitee.com/anolis/keentune_target
https://gitee.com/anolis/keentune_brain

____________________________________

2023-7-24 更新

原主站 http://keentune.io 已失效,切换到 KeenTune - OpenAnolis 龙蜥操作系统开源社区 

 

这篇关于AnolisOS 入门八:使用keentune(轻豚) 调优系统性能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/313724

相关文章

Python并行处理实战之如何使用ProcessPoolExecutor加速计算

《Python并行处理实战之如何使用ProcessPoolExecutor加速计算》Python提供了多种并行处理的方式,其中concurrent.futures模块的ProcessPoolExecu... 目录简介完整代码示例代码解释1. 导入必要的模块2. 定义处理函数3. 主函数4. 生成数字列表5.

Python中help()和dir()函数的使用

《Python中help()和dir()函数的使用》我们经常需要查看某个对象(如模块、类、函数等)的属性和方法,Python提供了两个内置函数help()和dir(),它们可以帮助我们快速了解代... 目录1. 引言2. help() 函数2.1 作用2.2 使用方法2.3 示例(1) 查看内置函数的帮助(

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

Python中使用uv创建环境及原理举例详解

《Python中使用uv创建环境及原理举例详解》uv是Astral团队开发的高性能Python工具,整合包管理、虚拟环境、Python版本控制等功能,:本文主要介绍Python中使用uv创建环境及... 目录一、uv工具简介核心特点:二、安装uv1. 通过pip安装2. 通过脚本安装验证安装:配置镜像源(可

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma