Recently, when I was doing performance assessment of one innodb feature
using sysbench standard tool then I observed performance drop in the feature.
I had some hands on experience with codeanalyst (AMD's tool) so I did sampling profiling.
I attached profiler vsperf to mysqld when sysbench client was doing transaction with some
concurrent threads and captured the data for 1 minute.
Just for information, there are 2 technique of profiling -1 sampling and instrumentation.
For instrumentation, I had limitation because a)our test framework starts mysqld in instrumentation
profiler needs to start mysqld
b) in-between framework does shutdown for some clean-up of data and
c) instrumentation profiling requires debug build.
The codeanalyst does not provide very detailed data like 'vsperf' provides.
Using visual studio IDE, we can profile (sampling or instrumentation).
In my sampling profiling I measured CPU clocks and it was quite easy to do through IDE.
It saves session so that we can refer profiled data and compare with another saved session profiled data.
The list of events for your hardware, you can find by running:
vsperfcmd /querycounters (note: in my installation vsperfcmd was
@C:\Program Files (x86)\Microsoft Visual Studio 10.0\Team Tools\Performance Tools\x64)
‘Event based profiling’ like profiling for event 'L2 cachemiss' using IDE was giving me trouble and I got no data
for L2CacheMiss event-profiling.
I could not figure out like why event-profiling through IDE is not able to capture any data.
So, I thought of trying command-line option for this and command-line approach worked out and I got the data I needed.
Here, a sample batch file I wrote to do event (L2CacheMiss) based profiling:
cd C:\Program Files (x86)\Microsoft Visual Studio 10.0\Team Tools\Performance Tools\x64
rem VSPerfCmd.exe /attach:%1 /Output:"C:\amrendra\wl6906_analysis\report\baseline_L2LinesOut.vsp" /Start:SAMPLE /COUNTER:L2Misses,1000
rem VSPerfCmd.exe /attach:%1 /Output:"C:\amrendra\wl6906_analysis\report\baseline_L2LinesOut_2.vsp" /Start:SAMPLE /COUNTER:L2LinesOut,100
VSPerfCmd.exe /attach:%1 /Output:"C:\amrendra\wl6658\baseline\baseline_cpu.vsp" /Start:SAMPLE
rem ping 220.127.116.11 -n 1 -w 60000 >NUL
rem wscript c:\amrendra\wait.vbs 60
timeout /T 60 /NOBREAK
rem do not use vsperfcmd /admin:service,start
rem vsperfcmd /querycounters
Some reference links can be useful, found on msdn: