MSBUILD publish ERROR_USER_UNAUTHORIZED



摘要

我在Windows Server 2016上使用9.2.0 Gitlab的CI多运行器。在我通过 MSBUILD 发布项目的步骤中 ASP.NET 我收到来自 IISERROR_USER_UNAUTHORIZED的身份验证错误。但是当我在构建机器上使用CMD窗口时,我会运行相同的发布命令 - 所有内容都已发布。不管我使用的是SYSTEM还是ADMINISTRATOR帐户。

重现步骤

  1. 设置 IIS 发布。
  2. 设置 Gitlab 的构建代理。
  3. 创建 Gitlab 的 YAML 构建脚本(见下文)。
  4. 运行生成。

实际行为

在发布步骤中,我遇到了ERROR_USER_UNAUTHORIZED错误。

预期行为

在发布步骤中,我已将 ASP.NET 发布到服务器。

相关日志和/或屏幕截图

C:Program Files (x86)Microsoft Visual Studio2017BuildToolsMSBuildMicrosoftVisualStudiov15.0WebMicrosoft.Web.Publishing.targets(4292,5): msdeploy error ERROR_USER_UNAUTHORIZED: Не удалось выполнить задачу Web Deploy. (Выполнено подключение к удаленному компьютеру ("192.168.1.66") с использованием службы веб-управления, но не удалось авторизовать. Убедитесь, что вы используете правильные имя пользователя и пароль, что существует сайт, к которому выполняется подключение, и что учетные данные представляют пользователя, у которого есть разрешения на доступ к сайту.  Дополнительные сведения: http://go.microsoft.com/fwlink/?LinkId=221672#ERROR_USER_UNAUTHORIZED.) [C:Gitlab_Build_Agents1builds2378ccf8rushydroaisaSourcesMvcMvc.csproj]

环境描述

我在Windows 2016上使用共享运行器(gitlab-ci-multi-runner-windows-386,版本9.2.0)。MSBUILD是Visual Studio 2017 Microsoft的一部分。

亚姆林脚本

variables:
solution: SourcesFaso.sln
msbuild: C:Program Files (x86)Microsoft Visual Studio2017BuildToolsMSBuild15.0BinMSBuild.exe
nunit: C:NUnitNUnit.Framework-3.7.0binnet-4.5nunitlite-runner.exe
nuget: C:NuGetnuget.exe
before_script:
- echo Setting encoding...
- echo %solution%
- echo Restoring NuGet packages...
- '"%nuget%" restore "%solution%"'
stages:
- build-test
- deploy-5023
build-test:
stage: build-test
script:  
- chcp 65001
- echo Building...
- '"%msbuild%" "%solution%" /t:Build /p:Configuration=Release /p:TargetFramework=v4.5.2'
- echo Testing...
- dir /s /b *.Tests.dll | findstr /r Tests\*\bin\ > testcontainers.txt
- 'for /f %%f in (testcontainers.txt) do "%nunit%" "%%f"'
except:
- tags
deploy-5023:
stage: deploy-5023
script:
- chcp 65001
- echo Deploying...
- '"%msbuild%" "%solution%" /p:DeployOnBuild=True /p:DeployTarget=MSDeployPublish /p:MsDeployServiceUrl=https://192.168.1.66:8172/msdeploy.axd /p:username=user /p:password=password /p:Configuration=Release /p:TargetFramework=v4.5.2 /p:AllowUntrustedCertificate=True /p:DeployIisAppPath=Faso /p:MSDeployPublishMethod=WMSVC /p:SkipExtraFilesOnServer=True /p:ExcludeFilesFromDeployment="Web.config;ConnectionStrings.config;system.config"'
when: manual
except:
- tags
artifacts:
expire_in: 1 week
paths:
- SourcesMvcApp_Data
- SourcesMvcbin
- SourcesMvcContent
- SourcesMvcfavicon.ico
- SourcesMvcGlobal.asax
- SourcesMvcWeb.config

通过更改 MSBUILD 的参数顺序和格式来解决。

- '"%msbuild%" "%solution%" /p:DeployOnBuild=True;Username=username;Password=password;DeployTarget=MSDeployPublish;MsDeployServiceUrl=https://192.168.1.66:8172/msdeploy.axd;Configuration=Release;TargetFramework=v4.5.2;AllowUntrustedCertificate=True;DeployIisAppPath=Faso;MSDeployPublishMethod=WMSVC;SkipExtraFilesOnServer=True;ExcludeFilesFromDeployment="Web.config;ConnectionStrings.config;system.config"'

相关内容

  • 没有找到相关文章

最新更新