The key was to get a better handle on the error. Testing externally I kept getting the generic 500 error. I tried adjusting how the error is shown under ASP for IIS7, but this didn't work.
I read on Experts Exchange to add IUSR to the security of the site and allow it view, read, and write. This didn't work either and I had to revert back.
After further reading, I saw that if I test from the browser locally on the server hosting the site, I should get a better error. BINGO!
Now I get: http error 500.22 0x80070032
This can be due to attributes in web.config being invalid (apparently security and other things were changed in IIS7, so certain attributes will BREAK when carried over from IIS6 to IIS7). Fret not! You don't have to manually go through and change things to get it to work. You can use an application to do that for you. :)
Here's a link that sums up how to do this nicely: http://www.prolificnotion.co.uk/use-appcmd-to-migrate-web-config-from-iis6-to-iis7/
For those who don't want to click, here it is below:
Run this to get the site identifier from your troubled site:
%systemroot%\system32\inetsrv\APPCMD list sites
This will dump info about your sites, you want to look for whatever is in between quotes (the identifier).
Ex.
SITE "MyMostAwesomeSite" (id:2,bindings:http/*:82,state,Stopped)
So in this case the site identifier is MyMostAwesomeSite.
The next step is to run the command that fixes the attributes in web.config:
%systemroot%\system32\inetsrv\APPCMD migrate config "MyMostAwesomeSite/"
If all goes well, you'll get the following response:
Successfully migrated section "system.web/httpModules"
Successfully migrated section "system.web/httpHandlers"
That's it! Test, and hopefully all is back to normal again.
No comments:
Post a Comment