Windows IO 性能简单测试
转自:http://bbs.csdn.net/topics/360111289, 有改动。
#include <windows.h>#include <stdio.h>#include <process.h>#include<memory>#pragma comment(lib,"ws2_32.lib")ULONGLONG g_nReadCounts=0,g_nWriteCounts=0,g_nOtherCounts=0,g_nReadsBytes=0,g_nWriteBytes=0,g_nOtherBytes=0;void PrintIODetails(){static DWORD lastTickCount;static IO_COUNTERS lastIoCounters;DWORD tickCount;IO_COUNTERS ioCounters;static int firstTime = 1;tickCount = GetTickCount();if (!GetProcessIoCounters(GetCurrentProcess(), &ioCounters)) {return;}if (firstTime){firstTime = 0;printf(" Time Reads Writes Others Read(Bytes) Write(Bytes) Other(Bytes)\n");printf("--------------------------------------------------------------------------------\n");}else{printf("%8lu%8llu%8llu%8llu%16llu%16llu%16llu\n",tickCount - lastTickCount,ioCounters.ReadOperationCount - lastIoCounters.ReadOperationCount,ioCounters.WriteOperationCount - lastIoCounters.WriteOperationCount,ioCounters.OtherOperationCount - lastIoCounters.OtherOperationCount,ioCounters.ReadTransferCount - lastIoCounters.ReadTransferCount,ioCounters.WriteTransferCount - lastIoCounters.WriteTransferCount,ioCounters.OtherTransferCount - lastIoCounters.OtherTransferCount);g_nReadCounts += (ioCounters.ReadOperationCount - lastIoCounters.ReadOperationCount);g_nWriteCounts += (ioCounters.WriteOperationCount - lastIoCounters.WriteOperationCount);g_nOtherCounts += (ioCounters.OtherOperationCount - lastIoCounters.OtherOperationCount);g_nReadsBytes += (ioCounters.ReadTransferCount - lastIoCounters.ReadTransferCount);g_nWriteBytes += (ioCounters.WriteTransferCount - lastIoCounters.WriteTransferCount);g_nOtherBytes += (ioCounters.OtherTransferCount - lastIoCounters.OtherTransferCount);}lastTickCount = tickCount;memcpy(&lastIoCounters, &ioCounters, sizeof(IO_COUNTERS));}#define PACKCOUNT 10#define BUFFSIEZ 50000volatile bool bWorkThreadFinish = false;void workerThread(void * dummy){int i;FILE * fp;char buff[BUFFSIEZ];WSADATA wsaData;SOCKET s;struct sockaddr_in localAddr;struct sockaddr_in peerAddr;memset(buff, 'X', sizeof(buff));Sleep(2000);// 写文件fp = fopen("io.txt", "w");if (fp) {printf("fwrite = %d\n", fwrite(buff, 1, sizeof(buff), fp));Sleep(10000);// 关闭文件,测试Flushprintf("fclose\n");fclose(fp);Sleep(2000);}// 读文件fp = fopen("io.txt", "r");if (fp) {printf("fread = %d\n", fread(buff, 1, sizeof(buff), fp));fclose(fp);Sleep(2000);}// 网络发memset((void *)&localAddr, 0, sizeof(localAddr));localAddr.sin_family = AF_INET;localAddr.sin_addr.s_addr = htonl(INADDR_ANY);localAddr.sin_port = htons(0);memset((void *)&peerAddr, 0, sizeof(peerAddr));peerAddr.sin_family = AF_INET;peerAddr.sin_addr.s_addr = inet_addr("10.19.85.1");peerAddr.sin_port = htons(3389);printf("WSAStartup\n");WSAStartup(MAKEWORD(2, 2), &wsaData);Sleep(2000);// UDPprintf("UDP Test:\n");printf("socket\n");s = socket(AF_INET, SOCK_DGRAM, 0);Sleep(2000);printf("bind\n");bind(s, (struct sockaddr *)&localAddr, sizeof(localAddr));Sleep(2000);for (i = 0; i < PACKCOUNT; i++) {printf("sendto = %d\n", sendto(s, buff, i * 100, 0, (SOCKADDR *) &peerAddr, sizeof(peerAddr)));Sleep(2000);}printf("closesocket\n");closesocket(s);Sleep(2000);// TCPprintf("TCP Test:\n");printf("socket\n");s = socket(AF_INET, SOCK_STREAM, 0);Sleep(2000);printf("bind\n");bind(s, (struct sockaddr *)&localAddr, sizeof(localAddr));Sleep(2000);printf("connect\n");connect(s, (SOCKADDR *) &peerAddr, sizeof(peerAddr));Sleep(2000);printf("send = %d\n", send(s, buff, sizeof(buff), 0));Sleep(2000);printf("closesocket\n");closesocket(s);Sleep(2000);printf("WSACleanup\n");WSACleanup();bWorkThreadFinish = true;}UINT _stdcall ThreadProc(PVOID pv){workerThread(pv);return 1;}//HANDLE g_hEvt = NULL;int main(int argc, char ** argv){// 启动工作线程::_beginthreadex(NULL,0,ThreadProc,NULL,0,0);//g_hEvt = ::CreateEventW(NULL,FALSE,FALSE,NULL);printf("Ctrl-C to exit\n\n");for (;;){PrintIODetails();Sleep(1000);if (bWorkThreadFinish){break;}}printf("*********************************Total*************************************\n");printf(" Reads Writes Others Read(Bytes) Write(Bytes) Other(Bytes)\n");printf("%8llu%8llu%8llu%16llu%16llu%16llu\n",g_nReadCounts,g_nWriteCounts,g_nOtherCounts,g_nReadsBytes,g_nWriteBytes,g_nOtherBytes);return 0;}
Windows IO 性能简单测试的更多相关文章
- 记一次虚拟化环境下Windows IO性能的解析
前言随着云计算技术与服务的发展和进步,越来越多的客户选择将业务部署到云端.但由于引入了虚拟化层,在业务部署过程中经常会遇到IO问题,通常也不易调试.本文主要介绍利用perf.systemtap等工具, ...
- MySQL中MyISAM引擎与InnoDB引擎性能简单测试
[硬件配置]CPU : AMD2500+ (1.8G)内存: 1G/现代硬盘: 80G/IDE[软件配置]OS : Windows XP SP2SE : PHP5.2.1DB : MySQL5.0.3 ...
- windows上测试磁盘io性能
一.问题由来 前两天搭建一套演示环境,同样的java war包,放在我们这边服务器好好的,放在那边就运行缓慢. 后来把日志改成异步之后就好了. 后边找了个程序测了下io性能,竟然差了7,8倍. 二.软 ...
- 磁盘IO性能监控(Linux 和 Windows)
磁盘IO性能监控(Linux 和 Windows) 作者:终南 <li.zhongnan@hotmail.com> 磁盘的IO性能是衡量计算机总体性能的一个重要指标.Linux提供了i ...
- Linux如何查看与测试磁盘IO性能
1. 查看磁盘 IO 性能 1.1 top 命令 top 命令通过查看 CPU 的 wa% 值来判断当前磁盘 IO 性能,如果这个数值过大,很可能是磁盘 IO 太高了,当然也可能是其他原因,例如网络 ...
- Linux 如何测试 IO 性能(磁盘读写速度)
这几天做MySQL性能测试,偌大一个公司,找几台性能测试机器都很纠结,终于协调到两台,IO的性能如何还不知道.数据库属于IO密集型的应用,所以还是先评估下Server的IO性能,看看是否能和线上的机器 ...
- 在Windows中监视IO性能
附:在Windows中监视IO性能 本来准备写一篇windows中监视IO性能的,后来发现好像可写的内容不多,windows在细节这方面做的不是那么的好,不过那些基本信息还是有的. 在Windows中 ...
- windows集群简单介绍
windows集群简单介绍仔细看过以前网友发表的一些文章,总觉得对windows集群没有详细介绍,我也是借花献佛,引用了一些技术性文档.目前应用最为广泛的集群计算技术可以分为三大类:高可用性集群技术. ...
- 在Linux中监视IO性能
dd命令 iostat命令 理解iostat的各项输出 iostat的应用实例 附:在Windows中监视IO性能 延伸阅读 dd命令 dd其实是工作于比较低层的一个数据拷贝和转换的*nix平台的工具 ...
随机推荐
- maven——添加插件和添加依赖有什么区别?
依赖:运行时开发时都需要用到的jar包,比如项目中需要一个Json的jar包,就要添加一个依赖,这个依赖在项目运行时也需要,因此在项目打包时需要把这些依赖也打包进项目里: 插件:在项目开的发时需要,但 ...
- nginx响应码
ngx.status = ngx.HTTP_CONTINUE (100) (first added in the v0.9.20 release)ngx.status = ngx.HTTP_SWITC ...
- 透视效果shader(边缘光)
思路:渲染两次. 1.第一次渲染:利用Greater进行深度测试,当目标被遮挡时,用一个边缘光的效果显示. 2.第二次渲染:正常渲染. 边缘光的思路:观察方向和顶点法向量夹角越大,边缘光越明显.边缘光 ...
- AngularJs学习笔记--Managing Service Dependencies
原版地址:http://docs.angularjs.org/guide/dev_guide.services.managing_dependencies angular允许service将其他ser ...
- 谈 Python 程序和 C 程序的整合 (转载)
http://www.ibm.com/developerworks/cn/linux/l-cn-pythonandc/ 概览 Python 是一种用于快速开发软件的编程语言,它的语法比较简单,易于掌握 ...
- unittest 几个重要概念
unittest是一个python版本的junit,junit是java中的单元测试框架,unittest实现了很多junit中的概念,比如我们非常熟悉的test case, test suite等, ...
- ES6数组新加 Buff
欢迎关注本人公众号<迈向大前端>,里面有15本前端相关的电子书,送给在前端路上迷茫的同学们! 本章篇幅很长,分开来发,这一小篇主要讲ES6数组的Array.of()和Array.from( ...
- MySQL使用全文索引(fulltext index)
1.创建全文索引(FullText index) 旧版的MySQL的全文索引只能用在MyISAM表格的char.varchar和text的字段上. 不过新版的MySQL5.6.24上InnoDB引擎也 ...
- spring 3.0 整合redis
参考文章:https://blog.csdn.net/weixin_42184707/article/details/80361464 其中遇到了问题,第一,redis的xml配置文件中的,头部地址资 ...
- 九度oj题目1555:重复子串
题目1555:重复子串 时间限制:3 秒 内存限制:256 兆 特殊判题:否 提交:738 解决:125 题目描述: 给定一个由小写字母组成的字符串,求它的所有连续子串中,出现过至少两次,且至少有一对 ...