Hi all
When developing BizTalk 2009 solutions using Visual Studio .NET 2008 on Windows Server
2008, you run into issues when deploying from within Visual Studio .NET.
Now, first of all, as long as there are issues
with BizTalk 2009 on Visual Studio .NET 2008, you should refrain from deploying
from within Visual Studio .NET.
Secondly, when deploying on Windows Server 2008, you might run into this series of
errors:
First error:
Access is denied. (Exception from HRESULT: 0x80070005 (E_ACCESSDENIED)), followed
by
Second error:
at Microsoft.BizTalk.Gac.Fusion.IAssemblyCache.InstallAssembly(AssemblyCacheInstallFlag
flags, String manifestFilePath, FusionInstallReference referenceData)
at Microsoft.BizTalk.Gac.Gac.InstallAssembly(String assemblyPathname,
Boolean force)
at Microsoft.BizTalk.Deployment.BizTalkAssembly.GacInstall(String assemblyLocation)
at Microsoft.BizTalk.Deployment.BizTalkAssembly.PrivateDeploy(String
server, String database, String assemblyPathname, String applicationName)
at Microsoft.BizTalk.Deployment.BizTalkAssembly.Deploy(Boolean redeploy,
String server, String database, String assemblyPathname, String group, String applicationName,
ApplicationLog log)
Third error:
Unspecified exception: "
Access is denied. (Exception from HRESULT: 0x80070005 (E_ACCESSDENIED))"
Access is denied. (Exception from HRESULT: 0x80070005 (E_ACCESSDENIED))
Fourth error:
Access is denied. (Exception from HRESULT: 0x80070005 (E_ACCESSDENIED))
Fifth error:
Failed to add resource(s). Change requests failed for some resources. BizTalkAssemblyResourceManager
failed to complete end type change request. Access is denied. (Exception from HRESULT:
0x80070005 (E_ACCESSDENIED))
Now, usually, I must confess that my developer machines are usually virtual PCs, where
I just login as the local administrator. If you do that, everything works fine. But
in Windows Server 2008, Microsoft have introduced a new security system, where you
need to approve it every time you start up some program that requires administrator
rights – even if you are a member of the local administrators group.
So for instance, starting up BizTalk Server Administration console will cause this
to appear:
And you have to click “Continue” to start it up.
The error above is because suddenly, even if you are a member of the local administrators
group, you cannot add assemblies to the GAC.
You have three choices to fix it:
-
Login with your username, but run Visual Studio .NET as an administrator. This is
done by right clicking on the short cut for VS.NET and choosing “Run as administrator”. - Login as administrator
-
Turn off the “User Account Control”. This is done by entering “Control Panel” =>
“User Accounts”. Click on “Turn User Account Control on or off” – and in here you
can turn it off. Now, when logged in as a user that i not the administrator, but who
is a member of the local administrators group, you get the rights you usually have.
Hope this helps someone
—
eliasen