MsDeploy - 无法更新应用程序池

Posted

技术标签:

【中文标题】MsDeploy - 无法更新应用程序池【英文标题】:MsDeploy - Can't update Application Pool 【发布时间】:2013-08-02 08:27:49 【问题描述】:

我已经浏览了几十个站点来帮助我使用 MsDeploy 将 Web 服务部署到 IIS。 我需要创建应用程序,修改应用程序池并启用协议,并更新 appSetting(包含连接字符串,不要问我为什么)。

我可以做所有这些,除了应用好的应用程序池。

这是我添加到项目中的 parameters.xml 文件:

<parameters>
  <parameter tags="IisApp" defaultValue="Default Web Site/MyWebService" name="IIS Web Application Name">
    <parameterEntry match="@defaultValue" scope="IisApp" kind="ProviderPath"/>
    <parameterEntry match="@defaultValue" scope="setAcl" kind="ProviderPath"/>
  </parameter>
  <parameter name="Configuration Connection String" defaultValue="Some real Connection String in there" tags="">
    <parameterEntry kind="XmlFile" scope="\\web.config$" match="/configuration/appSettings/add[@key='ConfigurationSQLConnectionString']/@value" />
  </parameter>
  <parameter name="Application Pool" defaultValue="MyOwnAppPool" description="Application pool for this site">
    <parameterEntry kind="DeploymentObjectAttribute" scope="application" match="/application/@applicationPool" />
  </parameter>
</parameters>

这是我生成包的方式:

MsBuild MyWebService.csproj /T:Package /P:PackageLocation="c:\somewhere\package.zip" /P:IncludeAppPool=true /P:IncludeIisSettings=true

这是生成的 archive.xml 文件:

<sitemanifest MSDeploy.ObjectResolver.dirPath="Microsoft.Web.Deployment.DirPathObjectResolver" MSDeploy.ObjectResolver.filePath="Microsoft.Web.Deployment.FilePathObjectResolver">
  <appHostConfig path="Default Web Site/MyWebService" MSDeploy.path="2" MSDeploy.MSDeployLinkName="Child1" MSDeploy.MSDeployKeyAttributeName="path" MSDeploy.MSDeployProviderOptions="some stuff">
    <application path="/MyWebService" MSDeploy.path="2" applicationPool="DefaultAppPool" MSDeploy.applicationPool="1" enabledProtocols="http" MSDeploy.enabledProtocols="1" serviceAutoStartEnabled="false" MSDeploy.serviceAutoStartEnabled="1" serviceAutoStartProvider="" MSDeploy.serviceAutoStartProvider="1" MSDeploy.MSDeployLinkName="PathElement" MSDeploy.MSDeployKeyAttributeName="path">
      <virtualDirectoryDefaults path="" MSDeploy.path="1" physicalPath="" MSDeploy.physicalPath="9" userName="" MSDeploy.userName="1" password="" MSDeploy.password="1" logonMethod="ClearText" MSDeploy.logonMethod="1" allowSubDirConfig="true" MSDeploy.allowSubDirConfig="1" MSDeploy.MSDeployLinkName="virtualDirectoryDefaults" />
      <virtualDirectory path="/" MSDeploy.path="2" physicalPath="C:\somewhere\MyWebService" MSDeploy.physicalPath="8" userName="" MSDeploy.userName="1" password="" MSDeploy.password="1" logonMethod="ClearText" MSDeploy.logonMethod="1" allowSubDirConfig="true" MSDeploy.allowSubDirConfig="1" MSDeploy.MSDeployKeyAttributeName="path" />
    </application>
  </appHostConfig>
  <contentPath path="C:\somewhere\MyWebService\obj\Debug\Package\PackageTmp" MSDeploy.path="2" MSDeploy.MSDeployLinkName="Child2" MSDeploy.MSDeployKeyAttributeName="path" MSDeploy.MSDeployProviderOptions="some other stuff">
    <MSDeploy.dirPath path="C:\somewhere\MyWebSerivce\obj\Debug\Package\PackageTmp" MSDeploy.MSDeployLinkName="contentPath" />
  </contentPath>
  <setAcl path="C:\somewhere\MyWebService\obj\Debug\Package\PackageTmp" MSDeploy.path="2" isDest="AA==" MSDeploy.isDest.Type="Microsoft.Web.Deployment.DeploymentObjectBooleanAttributeValue" setAclUser="" MSDeploy.setAclUser="1" setAclAccess="Read" MSDeploy.setAclAccess="1" MSDeploy.MSDeployLinkName="Child3" MSDeploy.MSDeployKeyAttributeName="path" MSDeploy.MSDeployProviderOptions="still some stuff" />
  <setAcl path="C:\somewhere\MyWebService\obj\Debug\Package\PackageTmp" MSDeploy.path="2" isDest="AA==" MSDeploy.isDest.Type="Microsoft.Web.Deployment.DeploymentObjectBooleanAttributeValue" setAclUser="anonymousAuthenticationUser" MSDeploy.setAclUser="1" setAclAccess="Read" MSDeploy.setAclAccess="1" MSDeploy.MSDeployLinkName="Child4" MSDeploy.MSDeployKeyAttributeName="path" MSDeploy.MSDeployProviderOptions="final stuff I guess" />
</sitemanifest>

这是生成的parameters.xml:

<parameters>
  <parameter name="IIS Web Application Name" defaultValue="Default Web Site/MyWebService" tags="IisApp">
    <parameterEntry kind="ProviderPath" scope="AppHostConfig" match="^Default\ Web\ Site/MyWebService$" />
    <parameterEntry kind="ProviderPath" scope="contentPath" match="^C:\\somewhere\\MyWebService\\obj\\Debug\\Package\\PackageTmp$" />
    <parameterEntry kind="ProviderPath" scope="setAcl" match="^C:\\somewhere\\MyWebService\\obj\\Debug\\Package\\PackageTmp$" />
    <parameterEntry kind="ProviderPath" scope="IisApp" match="@defaultValue" />
    <parameterEntry kind="ProviderPath" scope="setAcl" match="@defaultValue" />
  </parameter>
  <parameter name="IIS Web Application Pool Name" defaultValue="DefaultAppPool">
    <parameterEntry kind="DeploymentObjectAttribute" scope="application" match="application[@applicationPool='DefaultAppPool']/@applicationPool" />
  </parameter>
  <parameter name="IisVirtualDirectoryPhysicalPath" defaultValue="C:\somewhere\MyWebService" tags="PhysicalPath">
    <parameterEntry kind="DestinationVirtualDirectory" scope=".*" match="^C:\\somewhere\\MyWebService$" />
  </parameter>
  <parameter name="Configuration Connection String" defaultValue="Some real Connection String in there">
    <parameterEntry kind="XmlFile" scope="\\web.config$" match="/configuration/appSettings/add[@key='ConfigurationSQLConnectionString']/@value" />
  </parameter>
  <parameter name="Application Pool" description="Application pool for this site" defaultValue="MyOwnAppPool">
    <parameterEntry kind="DeploymentObjectAttribute" scope="application" match="/application/@applicationPool" />
  </parameter>
</parameters>

最后,这是我用来部署包的命令:

msdeploy.exe -verb:sync -allowUntrusted -enableLink:AppPoolExtension -source:package="c:\somewhere\Package.zip" -dest:auto,computerName="https://destinationserver:8172/MsDeploy.axd?site=WebSite_Deployment",userName="destinationserver\deploymentUser",password="shouldKeepItSecret",authType="basic" -setParam:name="IIS Web Application Name",value="WebSite_Deployment/MyWebService" -setParam:name="Configuration Connection String",value="The Real Connection String" -setParam:name="Application Pool",value="FinalAppPool" -setParam:name="IIS Web Application Pool Name",value="FinalAppPool" -verbose

我得到以下日志:

Verbose: Parameter entry 'IIS Web Application Pool Name/1' is applicable to 'sitemanifest/appHostConfig[@path='Default Web Site/MyWebService']/application[@path='/MyWebService']' because of its scope.
Verbose: Parameter entry 'Application Pool/1' is applicable to 'sitemanifest/appHostConfig[@path='Default Web Site/MyWebService']/application[@path='/MyWebService']' because of its scope.

但最后,设置的应用程序池 DefaultAppPool(而不是预期的 FinalAppPool)。我首先认为 msdeploy 为参数“IIS Web 应用程序池名称”采用了默认应用程序池值。但它总是需要 DefaultAppPool。 我只是不明白为什么。

如您所见,我使用的是非管理员帐户的基本身份验证。我已在destinationServer 上激活管理委托服务,将contentPath、iisApp 和setAcl 委托给当前用户,并将createApp 和appHostConfig 委托给WDeployConfigWriter。

我添加参数“应用程序池”的事实是because I found this here。 但即使我只保留这两个参数中的一个(应用程序池和 IIS Web 应用程序池名称),由于 msbuild 包参数 IncludeIisSettings=true,第二个总是在 archive.xml 中。结果是一样的。

这似乎不是一个正确的问题,只要应用程序池真的由 msdeploy 设置。只是它没有占用提供的应用程序池。

Enable Protocols 也有类似的问题。

抱歉,篇幅较长,但我想详尽无遗。

【问题讨论】:

您完全手动完成所有这些操作。是否可以选择使用 VSTS 来完成这项工作?您将在幕后使用 msdeploy,而且工作量要少得多,而且最重要的是……工作。 您到底想用应用程序池更新什么,为什么?我认为知道这将有助于我们更好地了解您的情况。 如果我的理解正确,您想基本上将应用程序部署到服务器并在 iis 中创建指向您刚刚创建/部署的应用程序目录的站点/应用程序池?如果是这种情况,使用 powershell 会容易得多。您可以远程使用 powershell 远程处理并复制应用程序,然后创建您需要的任何应用程序池并对其进行修改。在我看来,尝试通过 msbuild 来做到这一点会困难得多,因为它不是为这样的任务而构建的。 【参考方案1】:

不知道你是如何部署的,但也许你可以使用那里提到的脚本(带有 postSync 参数):

.net WebDeploy is there any way to run command/script on the target machine after deploy

在这个脚本中,你可以用 appcmd 做任何你想做的事情:

https://docs.microsoft.com/en-us/iis/get-started/getting-started-with-iis/getting-started-with-appcmdexe

【讨论】:

以上是关于MsDeploy - 无法更新应用程序池的主要内容,如果未能解决你的问题,请参考以下文章

进程池工作程序忽略全局变量更新

如何使用MSDeploy更新服务器中的Nuget包

尝试列出应用程序池或站点时 IIS 管理器冻结

IIS6配置完PHP环境后 应用程序池无法启动

连接池异常:无法获取连接,池错误超时等待空闲对象

我们可以通知 .net 应用程序从数据库更新数据而不是池化概念吗?