Linux-提高CPU、内存使用率shell脚本

目录

1、提升CPU利用率

(1)构造CPU达到100%

[(2) 结束命令](#(2) 结束命令)

2、提高内存利用率

可以申请的内存

申请内存空间:

完成后释放内存:

[3、 使用ChaosBlade工具](#3、 使用ChaosBlade工具)

cpu注入:

内存注入:

1、提升CPU利用率

(1)构造CPU达到100%

for i in `seq 1 $(cat /proc/cpuinfo |grep "physical id" |wc -l)`; do dd if=/dev/zero of=/dev/null & done

(2) 结束命令

pkill -9 dd

以5核的linux为例,下面为实例的shell代码:

复制代码
#!/bin/bash
read -p "请输入一个数字(0:停止;8:CPU80%;10:CPU100%):" num

if [ $num -eq 8 ]; then
    pkill -9 dd
    for i in $(seq 1 $(cat /proc/cpuinfo | grep "physical id" | wc -l | awk '{print $1-1}')); do
        dd if=/dev/zero of=/dev/null &
    done
elif [ $num -eq 10 ]; then
    pkill -9 dd
    for i in $(seq 1 $(cat /proc/cpuinfo | grep "physical id" | wc -l)); do
        dd if=/dev/zero of=/dev/null &
    done
elif [ $num -eq 0 ]; then
    pkill -9 dd
else
    echo "无效的输入"
fi

2、提高内存利用率

可以申请的内存

首先,判断需要申请多少内存

用top命令或free命令查看服务器的cpu和内存使用情况。

使用top/sar -r查看内存使用率

申请内存空间:

复制代码
#!/bin/bash
mkdir /tmp/memory
mount -t tmpfs -o size=8192M tmpfs /tmp/memory
dd if=/dev/zero of=/tmp/memory/block

完成后释放内存:

复制代码
#!/bin/bash
rm /tmp/memory/block
umount /tmp/memory
rmdir /tmp/memory

3、 使用ChaosBlade工具

前言:

本文介绍一款开源的故障注入工具chaosblade,该工具原本由阿里研发,现已开源;工具特点:功能强大,使用简单。

该工具故障注入包含:cpu,内存,磁盘io,磁盘占用,网络注入等

简写:

status --> s; destroy -->d; create --> c;

cpu注入:

blade create cpu load --cpu-list 0,1 --cpu-percent 80 --加压0,1两个核心,负载到80%

blade create cpu load --cpu-count 3 --将3个核心加压

blade create cpu fullload --cpu满载

blade create cpu load --cpu-list 0,1,2 --timeout 100 --将0,1,2三个核心加压100s,不带timeout参数默认一直加压

内存注入:

blade create mem load --mode ram --mem-percent 80 --占用80%的ram内存

blade create mem load --mode ram --mem-percent 80 --rate 100 --占用80%ram内存,占用速率100M每秒,rate参数只在占用ram时生效。

blade create mem load --mode catche --reserve 100 --占用catche内存,保留100M内存,速率100M/S,不加mode参数,默认值为catche,采用ram占用必须加mode参数。

注:内存注入满了会导致blade故障无法消除,推荐加percent参数;不使用任何参数会默认将内存加满,使用需谨慎。

执行成功,会返回一个id,如需撤销故障注入,执行如下命令
./blade d {id}

(工具去网上搜下下载即可,需要的话可关注我后私聊)

相关推荐
何极光7 小时前
IDEA集成Maven
java·maven·intellij-idea
火山上的企鹅7 小时前
Codex实战:APP远程升级服务搭建(三)后台管理页面(APK 上传、版本管理、多应用页签)
服务器·网络·数据库·oracle·qgc
程序员二叉7 小时前
【JUC】ThreadLocal底层原理|内存泄漏|弱引用|跨线程传递方案
java·开发语言·面试·职场和发展·juc
程序员二叉7 小时前
【JUC】线程池全套深度详解|参数|流程|拒绝策略|调优|异常处理
java·开发语言·jvm·算法·面试·juc
Net_Walke7 小时前
【Linux系统】静态链接库与动态链接库
linux·嵌入式硬件
老马识途2.07 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
青山木7 小时前
Hot 100 --- 轮转数组
java·数据结构·算法
syc78901237 小时前
中文语境下AI编码工具实战对比:从迭代体验看日常开发选择
linux·人工智能·ubuntu
❀搜不到7 小时前
远程服务器codex使用本地cc-switch的deepseek api
运维·服务器
凡人叶枫8 小时前
Effective C++ 条款22:将成员变量声明为 private
linux·开发语言·c++