30
24
My computer is taking a very long time to shutdown.
How can I identify the culprit? I don't want to wait minutes for my computer to shutdown...
Is there a program I can use to track how long it takes to shutdown?
30
24
My computer is taking a very long time to shutdown.
How can I identify the culprit? I don't want to wait minutes for my computer to shutdown...
Is there a program I can use to track how long it takes to shutdown?
31
Windows provides Performance Counters as well as Event Tracing which allows applications to do performance analysis so that one can pin-point the cause of performance problems, amongst those that exist there is one outstanding toolkit: The Windows Performance Toolkit available in the Windows SDK.
In this toolkit you will find xbootmgr.exe
, meant for Windows On/Off Transition Performance Analysis.
Although the above linked document goes into all the details for every on/off transition, here is the general idea about tracing and analyzing the shutdown transition using xbootmgr
and the xperf GUI:
Download the Windows SDK, then install the Windows Performance Toolkit using it.
Open up a command prompt as an administrator, then run:
cd %ProgramFiles%\Microsoft Windows Performance Toolkit
If you want help in the future, you can type xbootmgr -help
as well as xperf /?
.
Do a reboot trace like this:
xbootmgr -trace shutdown -traceFlags BASE+DIAG+LATENCY -noPrepReboot
After the boot, it will generate a trace within two minutes.
The trace has been saved in %ProgramFiles%\Microsoft Windows Performance Toolkit
, you can drag it onto xperf.exe
and it will be opened in a GUI.
You will see a GUI with different graphs, the arrow at the left side allows you to add/remove graphs.
Look at the graphs and see if you can identify anything out of the ordinary, you can select an interval and zoom in on it if you want to. Right click and unzoom when you want to see the whole.
For each graph, you can right click to get summary tables for the currently selected interval.
In these tables, sort by weight or by time to figure out which it is spending the most to. Please note that you can drag around columns, so for example the I/O table allows you to check out the highest using process as well as the highest using path.
The divider (a yellow header column) makes it so that the columns right of it show the total for the columns left of it. So, if you have Path first and then Process, then you can open the tree for a file to see what processes have accessed it and then you get the totals for that process/file combination.
You can find more information on how the graphs and tables function here.
If you somehow need to go down to look into the stack traces; do another boot trace and append the -stackWalk profile
parameter, set the _NT_SYMBOL_PATH and right click on any graph and enable "Load Symbols". This will allow you to check what functions it's actually calling, in general you won't need this for a shutdown though; but it can allow for things like discovering that your firewall is interfering with your debugger as a programmer. Pretty nifty...
Good luck, I hope you can find the culprit. If not then drop the trace and we'll take a look for you...
Please note that DPCs are Deferred Procedure Calls and Interrupts are Software Interrupts, both are related to drivers / hardware.
@Tom Wijsman Links need to be updated – Moab – 2016-04-20T19:33:06.810
Now it is part of the Windows Assessment and Deployment Kit, a Link can be found e. g. at https://msdn.microsoft.com/en-us/windows/hardware/commercialize/test/wpt/index or simply by searching for "Windows ADK". During installation, it is possible just to select the Performance Toolkit.
– Andreas Reiff – 2016-10-04T06:50:38.283Now it is also part ..., because it is still available in the SDK. – Tamara Wijsman – 2016-10-04T19:34:03.927
1Amazing useful answer. Any tutorials on ETW are extraordinarily useful; it's an area of Windows with no documentation and no gui to guide. – Ian Boyd – 2011-10-22T17:56:02.023
22
My shutdowns where taking a long time to run. What follows is my example with Tom's answer.
The first graph shows the problem, Disk I/O:
My shutdown is taking over a minute and it's all hard-drive I/O.
The next graph, Disk Utilization shows a drive is nearly maxed at 100% usage:
The final graph shows Disk Utilization by Process:
Filtering down i realize it's all caused by WinInit.exe
:
By right-clicking any of the hard drive graphs and selecting Summary Table, i can get the details of what files were accessed by what process:
56.4 seconds of my shutdown was spent by WinInit
writing 6.7GB to C:\hiberfil.sys
.
But the question is why is Windows writing to my hibernation file on shutdown?
Then i remembered an option i had turned on to wipe that paging file on shutdown:
So i disabled the option, and run xbootmgr
again. Now my shutdown is 22 seconds:
Now 9s
of the 22s
shutdown is spent by System
writing to some unknown
file. That might be worthy of more investigation.
But for now i've solved my minute and a half shutdown.
i went further and solved my 22s slow shutdown. From t=12s
to t=21s
showed 100% Disk Utilization, but zero Disk I/O. It was baffling.
Until during one shutdown i heard the familiar sound of one of my drives spinning up. The shutdown was stalled for 9 seconds because Windows was attempting to access a disk that had gone to sleep. Nine seconds later the drive responds, and a moment later the machine turned off.
Ironic that Windows wakes up a disk to tell it that it's time to go to sleep.
That would make my actual shutdown 13.5 seconds. That might be worth more investigation. But for now i've solved my 22 second shutdown.
1+1 Glad you got it solved in your case, and nice post! – Tamara Wijsman – 2011-11-01T02:46:12.573
1These answers deserve a blog post don't you think? ;) – Ivo Flipse – 2011-11-07T18:08:36.943
Instead of troubleshooting it, here's a tip:
REGEDIT
then go to\HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager\Memory Management
- find the keyClearPageFile at Shutdown
and set it to 0. It can make a big difference. Also,HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control
- find keyWaittoKillServiceTimeout
and set it to 1000. Those two changes may change you mind about asking why. – SDsolar – 2017-09-15T19:13:34.8931We have no idea how your system is set up and what could be running in the background – random – 2011-10-10T15:43:17.737
1OK... I saw someone else asked it, then deleted it as I was composing a very long and complete answer... (felt kinda sorry for myself) – wizlog – 2011-10-10T15:45:50.093
You can always suggest it for the blog – random – 2011-10-10T15:47:10.183
2Press and hold the power button for several seconds. – Daniel R Hicks – 2011-10-10T16:05:59.863
Sorry downvoted users and Random, but I don't agree that it is a "not a real question". wizlog was wondering about Windows performance, this is the same as if he would be asking for "How can I speedup Windows Boot time?"(which could be closed as duplicated). I have the same doubt and curiosity than him, I would improve the question with an answear. Voted to reopen and +1 to question. – Diogo – 2011-10-10T16:11:00.650
5This question is valid, I can objectively answer this so his problem is resolved. There is nothing ambiguous (the problem is that his shutdown time takes to long), vague (he wants to speed up his shutdown), incomplete (details aren't necessary, of course each computer is different but that doesn't make the technique to identify the culprit any different), overly broad (you might think so, but I do not see any other question troubleshooting shutdown so this is a really valuable question to have; I think it would be broad if he wants to speed up other things) or rhetorical (It involves xperf). – Tamara Wijsman – 2011-10-16T16:46:57.593
Now that we've agreed that this is an actual question, can someone please help me find an answer? – wizlog – 2011-10-16T19:16:03.757
@TomWijsman Reopened -- go ahead. – Daniel Beck – 2011-10-16T19:54:14.207