在Linux上简单模拟系统负载的方法

系统 Linux
系统管理员通常需要探索在不同负载对应用性能的影响。这意味着必须要重复地人为创造负载。当然,你可以通过专门的工具来实现,但有时你可能不想也无法安装新工具。

 [[217119]]

系统管理员通常需要探索在不同负载对应用性能的影响。这意味着必须要重复地人为创造负载。当然,你可以通过专门的工具来实现,但有时你可能不想也无法安装新工具。

每个 Linux 发行版中都自带有创建负载的工具。他们不如专门的工具那么灵活,但它们是现成的,而且无需专门学习。 

CPU

下面命令会创建 CPU 负荷,方法是通过压缩随机数据并将结果发送到 /dev/null

  1. cat /dev/urandom | gzip -9 > /dev/null

如果你想要更大的负荷,或者系统有多个核,那么只需要对数据进行压缩和解压就行了,像这样:

  1. cat /dev/urandom | gzip -9 | gzip -d | gzip -9 | gzip -d > /dev/null

按下 CTRL+C 来终止进程。 

内存占用

下面命令会减少可用内存的总量。它是通过在内存中创建文件系统然后往里面写文件来实现的。你可以使用任意多的内存,只需哟往里面写入更多的文件就行了。

首先,创建一个挂载点,然后将 ramfs 文件系统挂载上去:

  1. mkdir z
  2. mount -t ramfs ramfs z/

第二步,使用 dd 在该目录下创建文件。这里我们创建了一个 128M 的文件:

  1. dd if=/dev/zero of=z/file bs=1M count=128

文件的大小可以通过下面这些操作符来修改:

  • bs= 块大小。可以是任何数字后面接上 B(表示字节),K(表示 KB),M( 表示 MB)或者 G(表示 GB)。
  • count= 要写多少个块。 

磁盘 I/O

创建磁盘 I/O 的方法是先创建一个文件,然后使用 for 循环来不停地拷贝它。

下面使用命令 dd 创建了一个全是零的 1G 大小的文件:

  1. dd if=/dev/zero of=loadfile bs=1M count=1024

下面命令用 for 循环执行 10 次操作。每次都会拷贝 loadfile 来覆盖 loadfile1

  1. for i in {1..10}; do cp loadfile loadfile1; done

通过修改 {1..10} 中的第二个参数来调整运行时间的长短。(LCTT 译注:你的 Linux 系统中的默认使用的 cp 命令很可能是 cp -i 的别名,这种情况下覆写会提示你输入 y 来确认,你可以使用 -f 参数的 cp 命令来覆盖此行为,或者直接用 /bin/cp 命令。)

若你想要一直运行,直到按下 CTRL+C 来停止,则运行下面命令:

  1. while true; do cp loadfile loadfile1; done 
责任编辑:庞桂玉 来源: Linux中国
相关推荐

2018-06-25 09:54:14

LinuxDNS负载均衡

2012-02-02 13:04:50

JavaSpring

2017-01-12 15:58:17

Linux死锁分析方法

2021-04-09 10:58:51

UbuntuLinuxWindows 10

2009-04-21 11:27:52

MVCJSPJDBC

2011-03-25 11:21:36

NagiosLinux

2017-07-17 10:53:06

Linux交换分区

2011-03-03 13:46:00

NTFS-3G

2012-08-13 10:16:34

IBMdW

2023-07-11 09:24:11

2020-05-07 09:18:57

Linux压缩文件命令

2022-12-03 16:02:51

2019-07-05 09:45:19

UbuntuLinux释放空间

2011-01-14 14:00:19

GanetiLinux集群虚拟化

2019-02-19 09:00:45

Linux创建文件命令

2020-06-23 14:21:35

Linux系统功能

2020-12-26 14:48:21

UbuntuLinuxDeb文件

2010-11-17 09:29:31

linux Fedora 13Ubuntu 10.0

2014-10-09 14:35:44

HAProxy负载均衡

2011-01-18 11:37:59

Linuxsocket性能
点赞
收藏

51CTO技术栈公众号