Can't break in global.asax / Application_Start

jgauffin picture jgauffin · May 30, 2012 · Viewed 15.6k times · Source

I got a break point on the first line of Application_Start(), but Visual Studio wont break on it.

Visual Studio have attached itself to the IIS working process:

Auto-attach to process '[2092] w3wp.exe' on machine 'SRD00510' succeeded.

My breakpoint in the home controller do work.

update

I've tried:

  • iisreset
  • restarted visual studio
  • Rebooted.
  • Tried to reinstall aspnet (aspnet_regiis -i)

Answer

Jochen picture Jochen · Oct 1, 2014

Reading your question, I assume you are using IIS for debugging, not Visual Studio Development Server.

In this case, debugging application start is tricky, because it is only called once when the application pool is started or recycled. When Visual Studio attaches to the process, Application_Start has already been running.

The trick is to make the application pool recycle without killing the process you are attached to.

Do the following:

  1. In Visual Studio (must be run as Administrator) set your breakpoint in global.asax.cs and start debugging as usual (F5). The page opens in your web browser, but the breakpoint isn't hit.
  2. Now the trick: With a text editor, open web.config from where it is served by IIS, change it (e.g. enter a blank line somewhere) and save it. In contrast to recycling the application pool in IIS, this lets the application pool recycle (and thus running through Application_Start in global.asax.cs the next time the web site is called) without killing the process you are attached to.
  3. In your web browser, reload the page. The breakpoint should be hit now!

That works for me (IIS 7.5, VS2015).