我们的大多数 Web 应用程序都包含一个 Deploy.ps1 Powershell 脚本。Octopus Deploy 使用它在生产部署期间配置应用程序,但我们也使用它来设置开发人员的本地 IIS 设置。在 Windows 7、Windows 8.1 和我们所有的 Win2012 生产服务器上运行良好。
它不适用于 Windows 10,这似乎是因为Set-ItemProperty
cmdlet 无效。没有错误消息或任何东西,它只是不做任何事情。
IIS 站点 api.example.com 已经存在,我们正在使用 Powershell 创建 /myapp 应用程序,然后将应用程序的物理路径更改为 D:\Projects\Demo
PS C:\> IIS:
PS IIS:\> cd Sites\api.example.com
PS IIS:\Sites\api.example.com> New-WebApplication myapp -site api.example.com -PhysicalPath C:\inetpub\wwwroot
Name Application pool Protocols Physical Path
---- ---------------- --------- -------------
myapp DefaultAppPool http C:\inetpub\wwwroot
PS IIS:\Sites\api.example.com> set-itemproperty myapp -name PhysicalPath -value D:\Projects\Demo
PS IIS:\Sites\api.example.com> get-itemproperty myapp
Name Application pool Protocols Physical Path
---- ---------------- --------- -------------
demo DefaultAppPool http C:\inetpub\wwwroot
^ THIS IS WRONG!
在 Windows 7 上运行完全相同的命令集,您将获得相同的输出,但在最后一步,PhysicalPath 属性已按预期更改:
PS IIS:\Sites\api.example.com> get-itemproperty myapp
Name Application pool Protocols Physical Path
---- ---------------- --------- -------------
demo DefaultAppPool http D:\Projects\Demo
知道发生了什么吗?IIS10 是否有一些新的管理员限制?我需要某种额外提升的权限来修改现有 Web 应用程序的设置或其他什么?
更新:如果项目是 IIS 站点,它似乎工作正常,但如果项目是 Web 应用程序则失败,这让我想知道这是否只是提供程序中的错误。有任何想法吗?