昨天领导交代客户需要一个可以测试CPU性能的脚本,问题简化下就是说要做一个可以手动设置对CPU产生消耗的程序。心想哪有这种脚本,或许性能测试工具还差不多。琢磨了下,或许用死循环可以达到差不多的效果,但是单进程(单线程)造成的影响有限,因为服务器都是多个物理核心。那就是用多线程吧,手动写了个多线程demo,生成后发现线程都集中在一个CPU内工作,虽然把单个CPU搞成100%了,但是整体消耗不大(大约10%左右)。后来百度了下说得CPU绑定线程才有用,但是这方面不是一下就能熟悉的,所以还是多进程的实现较为简单。
代码很简单:
#include <stdio.h> #include <stdlib.h> #include <sys/types.h> #include <unistd.h> #include <wait.h> /** *@Usage: ./$0 [SUBPROCESS NUMBER] */ int main(int argc, char *argv[]){ pid_t pid; int i, pn=4; if(argc==2){ pn=atoi(argv[1]); } for(i=0;i<pn;i++){ pid=fork(); if(pid<=0)break; } if(pid<0){ printf("fork() error\n"); return -1; }else if(pid==0){ //sub process works for(;;)i=(i%4)*1.0; }else{ //wait for the sub process‘s termination wait(NULL); } return 0; }
gcc -Wall test.c -o test.o chmod +x test.o #启动五个子进程试试效果 ./test.o 5
贴张图:
消耗CPU的程序
时间: 2024-09-28 03:27:19