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}

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

相关推荐
吃饱了得干活11 小时前
Spring Cloud Gateway 微服务网关:路由、断言、过滤器
java·spring cloud
lwx5728013 小时前
探秘InnoDB:搞懂它的内存、线程、磁盘与日志刷盘策略
java·后端
Flynt14 小时前
从Spring Boot 4.0升到4.1,我在Maven和gRPC上栽了跟头
java·spring boot·后端
plainGeekDev15 小时前
Activity 间传值 → Navigation 参数
android·java·kotlin
plainGeekDev15 小时前
onActivityResult → ActivityResult API
android·java·kotlin
Sunia15 小时前
《AgentX 专栏》10-生产部署:3台2C4G云服务器把企业级Agent真正跑起来的完整方案
java·架构
ZhengEnCi16 小时前
J7A-高级Java工程师面试三道灵魂拷问-深度广度与工程素养的终极检验
java·后端
AlfredZhao17 小时前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
狼爷1 天前
吃透 Java Function 接口,搞定 99% 的 Stream 场景
java·函数式编程
祎雪双十Gy2 天前
从 DataX 的配置加载说起:我用 FastJson2 做了一个轻量级动态配置管理库
java·后端