Web Deploy发布ASP.NET网站给我们提供方便,配置好后可以很方便地发布网站到IIS服务器

自安装Web Deploy一年以来,一直都用得好好地。

直到最近,Gitlab-CI自动发布出了问题,提示:

"C:\Tools\GitLab-Runner\builds\d1af4d14\0\WP\Hallhuber\src\WP.Web.Mvc\1621.WP.Web.Mvc.csproj" (default target) (1) ->
(MSDeployPublish target) ->
C:\Program Files (x86)\MSBuild\Microsoft\VisualStudio\v14.0\Web\Microsoft.Web.Publishing.targets(4295,5): msdeploy error ERROR_USER_UNAUTHORIZED: Web deployment task failed. (Connected to the remote computer ("192.168.70.62") using the Web Management Service, but could not authorize. Make sure that you are using the correct user name and password, that the site you are connecting to exists, and that the credentials represent a user who has permissions to access the site. Learn more at: http://go.microsoft.com/fwlink/?LinkId=221672#ERROR_USER_UNAUTHORIZED.) [C:\Tools\GitLab-Runner\builds\d1af4d14\0\WP\Hallhuber\src\WP.Web.Mvc\1621.WP.Web.Mvc.csproj] 17 Warning(s)
1 Error(s) Time Elapsed 00:00:43.96
Publish completed.
ERROR: Job failed: exit status 1

如图:

我在 Visual Studio 上手动发布该Web项目,点发布时,弹出了"请输入密码以连接到 Web Deploy 客户端"提示框。

我输入密码后,可以成功发布。

我感觉有点奇怪,为什么 Visual Studio 可以正常发布,而 Gitlab-CI 却发布失败,而且 Visual Studio 竟然要输入密码才能发布,我明明把密码写进pubxml发布配置文件里了。

此时我没有多想,我尝试以bat发布命令脚本形式发布Web项目,竟然发布失败了,和 Gitlab-CI 一样地提示"ERROR_USER_UNAUTHORIZED"

于是,上Bing国际版加上site:stackoverflow.com指令搜索·stackoverflow网站·上的解决方案:

有人说是要在发布命令脚本中多加两个参数/p:UserName=YourName /p:Password=YourPassword,这个我试过,不行。

有人说要使用Windows本地非管理员账户而不是IIS虚拟账户来发布,我创建了一个本地账户,管理员身份和非管理员身份都试过,也不行。

有人说是 Web Deploy 没有完整安装所致:

这里我很纳闷,因为我之前第一次安装 Web Deploy 就是完整安装模式,但安装完后,"Web Deployment Agent Service"服务起不来。

当时没有当一回事,有一次重启Windows 服务器,发现Nginx 服务器起不来了,经过一系列排查,有个叫MsDepSvc的进程占用了80端口,而MsDepSvc进程其实就是"Web Deployment Agent Service"服务。

当时很是气恼又感觉"Web Deployment Agent Service"服务没有什么卵用,想要卸掉它。所以在重新安装 Web Deploy 的时候,选择自定义安装,并且取消勾选"Remote Agent Service"的安装选项,之后一直在愉快的玩 Gitlab-CI

现在又让我装回去?好吧,只好找一找有没有能够让"Web Deployment Agent Service"服务不占用80端口,又能正常运行与Nginx服务器的方法。

在这里找到解决方案:https://stackoverflow.com/questions/5867392/can-the-web-deploy-agent-run-on-a-port-other-than-80-on-iis6

心急的我,还没看完这个帖子的所有回复,就开始按照它标记为最佳答案的教程来做。做到一半,发现Windows 服务器不能识别httpcfg命令。

百度才知道在Windows Vista以下的版本支持httpcfg,以上版本不支持httpcfg,改为netsh。也就是说Windows 2008以上的服务器只能用netsh命令而不是httpcfg命令。

认真地看完帖子的所有回复,原来已经有人给出了在Windows 7以上版本的httpcfg命令的替代命令netsh的执行语法。

按照教程:

  1. 停止"Web Deployment Agent Service"服务 (net stop msdepsvc)
  2. 编辑以下注册表值: HKLM\SYSTEM\CurrentControlSet\Services\MsDepSvc\Parameters\ListenUrl

    http://+:80/MsDeployAgentService 改为 http://+:8171/MsDeployAgentService
  3. Windows XP,Windows Server 2003以下服务器运行如下命令:
httpcfg query urlacl
httpcfg delete urlacl /u http://+:80/MsDeployAgentService/
httpcfg set urlacl /u http://+:8171/MsDeployAgentService/ /a D:(A;;GX;;;NS)

Windows Vista,Windows Server 2008以上服务器运行如下命令:

netsh http show urlacl
netsh http delete urlacl url=http://+:80/MSDEPLOYAGENTSERVICE/
netsh http add urlacl url=http://+:8171/MSDEPLOYAGENTSERVICE/ sddl=D:(A;;GX;;;NS)
  1. 启动"Web Deployment Agent Service"服务 (net start msdepsvc)

依次按照步骤做完后,在 Visual Studio 上执行发布,提示:

Web 部署任务失败。((2018/1/11 星期四 10:29:39)在远程计算机上处理请求时出错。)

(2018/1/11 星期四 10:29:39)在远程计算机上处理请求时出错。
无法执行此操作。请与服务器管理员联系,检查授权和委派设置。

再次搜索解决方案,找到了这个博文:https://www.cnblogs.com/SilenceTom/p/5582932.html

原来,安装完 Web Deploy 后,会在服务器上创建两个本地账户:WDeployConfigWriterWDeployAdmin,而这两个本地账户的密码默认设置为"过一段时间就过期"

因此,给这两个本地账户WDeployConfigWriterWDeployAdmin重设密码,并设置为"永不过期"

然后到IIS管理服务委派(Management Service Delegation)更新所有使用了WDeployConfigWriterWDeployAdmin账户的规则(Rule)凭证信息(即账户密码)

再次在 Visual Studio 上执行发布,顺利发布Web网站IIS服务器上了,并且没有弹出"请输入密码以连接到 Web Deploy 客户端"提示框。

执行bat发布命令脚本,也是顺利发布。

总算搞定。

PS:

运行环境:
GitLab 10
Windows Server 2012
Visual Studio 2015

Web Deploy 安装与配置:

https://docs.microsoft.com/en-us/iis/install/installing-publishing-technologies/installing-and-configuring-web-deploy

Web Deploy 自动备份:

https://docs.microsoft.com/en-us/iis/publish/using-web-deploy/web-deploy-automatic-backups

MS Deploy 发布时包含其它文件:

https://docs.microsoft.com/en-us/aspnet/web-forms/overview/deployment/visual-studio-web-deployment/deploying-extra-files

Web Deploy 下载地址:

https://www.iis.net/downloads/microsoft/web-deploy

直接下载地址:

English: x86 / x64

Chinese (Simplified): x86 / x64

引用与感谢以下链接的人:

https://stackoverflow.com/questions/5867392/can-the-web-deploy-agent-run-on-a-port-other-than-80-on-iis6

https://www.cnblogs.com/SilenceTom/p/5582932.html

Web Deploy 发布网站错误 检查授权和委派设置的更多相关文章

  1. Web Deploy发布网站错误 检查授权和委派设置

    web Deploy发布asp.net网站给我们提供方便,开始配置好了可以方便的发布网站,但是过久就出现无法执行此操作.请与服务器管理员联系,检查授权和委派设置.花了好长时间找到问问所在.现在解决方法 ...

  2. Web Deploy发布网站及常见问题解决方法(图文)

    Web Deploy发布网站及常见问题解决方法(图文) Windows2008R2+IIs7.5 +Web Deploy 3.5 Web Deploy 3.5下载安装 http://www.iis.n ...

  3. Web Deploy发布网站一条龙解决方案

    Web Deploy工具对于ASP.NET开发人员来说一定不陌生,没有用过也经常见到,Web Deploy发布十分方便而且在发布时会帮助用户检验发布文件的正确性.接下来介绍一下基础使用. 第一步:安装 ...

  4. VS2015 使用 Web Deploy 发布网站到 WindowsServer2008 R2服务器详解

    使用原因:由于开发期间需要将开发出的网站随时提交到服务器以便公司高层随时访问所以要求将开发出的网站每天发布到服务器,频繁度比较高,因此不能再使用之前的方式(发布到本地后再拷贝文件到服务器),所以想到了 ...

  5. Visual Studio通过Web Deploy发布网站报错:An error occurred when the request was processed on the remote computer.

    这个问题很奇怪,不管我怎么重启服务器和自己的开发机,都没有用. 在网上找了很多资料,有说可以尝试去读Windows的错误日志,然后通过日志找原因…(详见Stackoverflow:http://sta ...

  6. Visual Studio 使用 Web Deploy 发布远程站点

    Ø  简介 本文介绍 Visual Studio 如何使用 Web Deploy发布远程站点,有时候我们开发完某个功能时,需要快速将更改发布至服务器.通常 Visual Studio 可以采用两种方式 ...

  7. Visual Studio 2019 使用 Web Deploy 发布远程站点到IIS服务器

    Visual Studio 2019 使用 Web Deploy 发布远程站点到IIS服务器的方式 在开发完项目之后,我们需要把开发的项目发布到指定的服务器上,有两种方式,如下 1.把项目发布成文件系 ...

  8. Visual Studio 使用Web Deploy发布项目

    工具:Web Deploy 3.6 点击下载 (强烈推荐使用独立的Web Deploy 安装包安装) 使用 Web Platform Installer 安装 Web Deploy(3.5,3.6都安 ...

  9. VS使用WEB DEPLOY发布

    背景是这样的,公司有两台服务器,平时一台备用,另一台做为主生产机器.当有大量补丁或者安装什么东西需要重启的时候,交其中一台直接关掉IIS,然后重启即可,此时另一台负责处理用户请求. 之前一台服务器一个 ...

随机推荐

  1. JavaScript 特效之四大家族(offset/scroll/client/event)

      三大系列:offset.scroll.client 事件对象:event(事件被触动时,鼠标和键盘的状态)(通过属性控制)   三大系列都是以DOM元素节点的属性形式存在的. 类比访问关系,也是以 ...

  2. __x__(40)0909第五天__表格 table 的 css 样式 美化

    如果就向下面的代码那样,不写 tbody , 则浏览器自添加 tbody , 并将所有的 tr 移入 tbody 意味着 tr 并非 table 的子元素,而是 tbody 的子元素. 所以 以后编写 ...

  3. SQL - 2.基础语法

    一.SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL—数据控制语言(GR ...

  4. CodeForces #549 Div.2 ELynyrd Skynyrd 倍增算法

    题目 这道题目实际上可以用动态规划来做. 对于每个区间,我们从右边边界,往左边走,如果能走n-1次,那说明以右边边界为起点存在一个题目中说的子链. 利用倍增算法,实际上倍增也是动态规划.f[i][j] ...

  5. django项目同一用户不能同时登陆

    1.session认证 ..... login(request, user) #登录成功 # 登录之后获取获取最新的session_key session_key = request.session. ...

  6. 1840: Jack Straws

    1840: Jack Straws 时间限制(普通/Java):1000MS/10000MS     内存限制:65536KByte 总提交: 168            测试通过:129 描述 I ...

  7. seafile ubuntu 安装相关

    1,各种原因,需要安装 seafile,好,开始安装. 2,参考 https://github.com/haiwen/seafile-server-installer-cn 1,Ubuntu 16.0 ...

  8. OFFICE 您正试图运行的函数包含有宏或需要宏语言支持的内容。

    故障现象:打开WORD的时候,提示“您正试图运行的函数包含有宏或需要宏语言支持的内容.而在安装此软件时,您(或您的管理员)选择了不安装宏或控件的支持功能”. 提示现象: 解决办法 : 1.进入“控制面 ...

  9. python 循环 while

    count = 1while count <= 5: print("大家好!") count = count + 1 结果:while 可以进行循环, count 表示计数, ...

  10. 并发编程实战1-chap1-2-斗者6星

    一.线程安全性 1.线程安全关注点:对共享的和可变的状态的访问 2.JAVA同步机制:synchronized.volatile.显示锁.原子变量 3.无状态对象一定是线程安全的:不包含任何域,也不包 ...