jmeter P函数应用
${__P__(thread,200)}
${__P__(step,20)}
${__P__(steptime,30)}
${__P__(duration,30)}
${__P__(duration,300)}
jmeter -n -t 待执行的性能脚本.jmx -l 结果文件(名字自己取).jtl -j 执行的log.log -e -o 路径/测试报告名 -Jthread=20 -Jstep=20 (参数不加则默认)
$ nvidia-smi 查看显存使用情况命令
$ watch -n 10 nvidia-smi 周期性地查看GPU使用情况 10 表示每10秒刷新一次GPU状态
vmstat interval count
间隔时间 需要输出多少次结果
vmstat 2 10
每隔两秒输出10次结果
top ps(使用时间C列 time为进程持续时间)
CPU 占用率 = (进程 cpu时间/ 进程持续时间)
ps -ef -elf
ps -au -aux
%cpu %men
CPU 中央处理器 GPU图形处理器
GPU 是图形处理器,在测试手机/游戏性能会用到(模型性能也会用到),如果是测试web后台性能,应该不用
查看和杀死Jmeter进程
jps | grep ApacheJMeter | awk '{print $1}'
jps | grep ApacheJMeter | awk '{print $1}'|xargs kill -9
后台执行
nohup jmeter -n -t 执行的脚步.jmx -l 结果文档.jtl & 后台执行,即使关闭窗口后也执行
jmeter -n -t 执行的脚步.jmx -l 结果文档.jtl &后台执行,关闭窗口后不执行
linux下测试性能 不含事务控制器的情况下打印的信息:
其中主要有两种信息 summary + 和 summary = ,其它项都是类似的
summary +4386 in 00:00:30 :在30秒内增加了4386个请求,其中时间间隔由配置文件中的interval统计频率的值决定
summary = 27455 in 00:03:12 :在3分12秒内产生的总请求数是27455个,其中的时间段是从脚本运行开始计算到当前时间为止,一般在脚本运行过程中主要关注"summary="信息即可
146.2/s :系统每秒处理的请求数,相当于TPS
Avg : 684 :平均响应时间
Min:201 :最小响应时间
Max:1499 :最大应时间
Err : 0 (0.00%) :错误数/率
Active :100 活动的线程数
当没有遇到性能瓶颈的时候:
F=VU * R /T
其中F为吞吐量,VU表示虚拟用户个数,R表示每个虚拟用户发出的请求数,T表示性能测试所用的时间
gettimeofday(取得目前的时间)相关函数
time,ctime,ftime,settimeofday
表头文件
#include <sys/time.h>
#include <unistd.h>
定义函数
int gettimeofday ( struct timeval * tv , struct timezone * tz )
函数说明
gettimeofday()会把目前的时间有tv所指的结构返回,当地时区的信息则放到tz所指的结构中。
timeval结构定义为:
struct timeval{
long tv_sec/*秒*/
long tv_usec/*微秒*/
}
timezone 结构定义为:
struct timezone{
int tz_minuteswest/*和Greenwich 时间差了多少分钟*/
int tz_dsttime/*日光节约时间的状态*/
}
上述两个结构都定义在/usr/include/sys/time.h。tz_dsttime 所代表的状态如下
DST_NONE /*不使用*/
DST_USA /*美国*/
DST_AUST /*澳洲*/
DST_WET /*西欧*/
DST_MET /*中欧*/
DST_EET /*东欧*/
DST_CAN /*加拿大*/
DST_GB /*大不列颠*/
DST_RUM /*罗马尼亚*/
DST_TUR /*土耳其*/
DST_AUSTALT /*澳洲(1986年以后)*/
返回值
成功则返回0,失败返回-1,错误代码存于errno。附加说明EFAULT指针tv和tz所指的内存空间超出存取权限。
范例
#include<sys/time.h>
#include<unistd.h>
main(){
struct timeval tv
struct timezone tz
gettimeofday (&tv , &tz)
printf(“tv_sec%d\n”, tv,.tv_sec)
printf(“tv_usec%d\n”,tv.tv_usec)
printf(“tz_minuteswest%d\n”, tz.tz_minuteswest)
printf(“tz_dsttime, %d\n”,tz.tz_dsttime)
}
执行
tv_sec: 974857339
tv_usec:136996
tz_minuteswest:-540
tz_dsttime:0
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)