cpu壓測神器:cpuburn深度指南


1. 前言

最近在測試一個物聯網的項目,項目里包含設備資源進行監控告警的功能。例如如下監控項:cpu負載超核、內存使用率過高、硬盤使用率過高,系統流量超速等。為了驗證監控的有效性,就需要構造對應場景來進行測試。

如何對cpu,內存,硬盤,流量這幾類資源進行數據構造呢?

我在網速搜羅了一圈發現有四個比較好用的工具,能較方便的構造對應場景:

  • cpuburn
  • memtester
  • dd
  • netperf

首先我們來介紹這款燒腦神器,cpuburn

2.簡介

項目地址:https://patrickmn.com/projects/cpuburn/

一句話介紹:cpuburn lets you utilize 100% of all available cores from the command line — useful when stress-testing(cpuburn 能夠讓你用一行命令來打滿所有CPU的可用核,在做壓力測試的時候特別奏效)

3.安裝方式

cpuburn主要是針對windows和linux系統。

有三種安裝方式

1. 二進制運行

2. 源碼編譯安裝

3. yum或者apt安裝

3.1 二進制安裝

3.1.1 Linux版下載地址

Linux:

1)32位   cpuburn-1.0-i386.tar.gz

2)64位  cpuburn-1.0-amd64.tar.gz

3.1.2 Linux下安裝

1)根據系統位數下載上述文件(以64位為例)

wget https://cdn.pmylund.com/files/tools/cpuburn/linux/cpuburn-1.0-amd64.tar.gz

2)解壓縮,解壓完之后即可得到cpuburn二進制

tar xzvf cpuburn-1.0-amd64.tar.gz

3) 拷貝cpuburn到/usr/bin

cp cpuburn /usr/bin/

3.1.3 Windows版下載地址

Windows: cpuburn-1.0.zip

3.1.3 Windows下安裝

1)點擊下載后解壓縮到當前目錄

2)添加到Path環境變量中(可選)

運行如圖

3.2 源碼編譯安裝

這種方式適合官方沒有對應系統包的情況,比如mac

1)安裝go環境(如果已經安裝,請忽略)

參考:go環境搭建

2)下載源碼

git clone https://github.com/patrickmn/cpuburn

3) 編譯源碼

執行完如下命令后會在當前目錄生成cpuburn二進制文件

go build cpuburn.go

3.3 使用yum或者apt安裝

Centos:
yum install -y cpuburn
Ubuntu:
apt-get install -y cpuburn

4. 幫助

輸入:cpuburn -h

Usage of ./cpuburn:

-n int

number of cores to burn (0 = all) //指定進行壓測的CPU核數,默認為0(有幾核壓幾核)

-u int

seconds between updates (0 = don't update) (default 10) //打印運行時長的間隔,默認10秒中打印一次運行時間(0代表靜默模式,不打印任何信息)

5. 例子

1. 壓測所有CPU核(當前CPU有8核),每隔10秒更新一次運行時間。

cpuburn

2.壓測CPU核數為4,每隔10秒更新一次運行時間。

cpuburn -n=4

查看效果:

輸入:top,然后按最上面的數字1,可以看到4核幾乎被全部榨滿了。

3.靜默模式運行cpuburn

cpuburn -u=0

6.源碼解析

cpuburn是go寫的一個小工具,非常的輕巧,讓我們簡單拜讀一下。

package main

import (
        "flag"
        "fmt"
        "runtime"
        "time"
)

var (
        numBurn        int
        updateInterval int
)

func cpuBurn() {          //這里是核心,每個go協程不斷的讓出CPU時間片
        for {
                for i := 0; i < 2147483647; i++ {
                }
                runtime.Gosched()
        }
}

func init() { //初始化變量
        fmt.Printf("Your System is %s,and CPUs/cores number is %d\n",runtime.GOOS, runtime.NumCPU); //這里是我加的一個打印信息
        flag.IntVar(&numBurn, "n", 0, "number of cores to burn (0 = all)")
        flag.IntVar(&updateInterval, "u", 10, "seconds between updates (0 = don't update)")
        flag.Parse()
        if numBurn <= 0 {
                numBurn = runtime.NumCPU()
        }
}

func main() {
        runtime.GOMAXPROCS(numBurn)    //設定使用的cpu核數,不設定默認使用1核運行所有協程
        fmt.Printf("Burning %d CPUs/cores\n", numBurn)
        for i := 0; i < numBurn; i++ {              //根據指定的cpu核數創建go攜程
                go cpuBurn()
        }
        if updateInterval > 0 {   //如果設定了更新時間,則不斷每間隔updateInterval*60秒打印更新時間
                t := time.Tick(time.Duration(updateInterval) * time.Second) //設定定時器時間間隔
                for secs := updateInterval; ; secs += updateInterval { //間隔幾秒打印一下當前運行的總時間
                        <-t
                        fmt.Printf("%d seconds\n", secs)
                }
        } else { //如果沒有設定更新時間,則一直阻塞住。
                select {} // wait forever
        }
}

 

重新編譯cpuburn.go,執行下看看效果:

博主:測試生財(一個不為996而996的測開碼農)

座右銘:專注測試開發與自動化運維,努力讀書思考寫作,為內卷的人生奠定財務自由。

內容范疇:技術提升,職場雜談,事業發展,閱讀寫作,投資理財,健康人生。

csdn:https://blog.csdn.net/ccgshigao

博客園:https://www.cnblogs.com/qa-freeroad/

51cto:https://blog.51cto.com/14900374

微信公眾號:測試生財(定期分享獨家內容和資源)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM