Я пытаюсь создать автономную установку Visual Studio 2017 с сетевым ресурсом и Ansible.
Мне трудно понять, что именно происходит, так как установка проходит (?) Практически безжурналы, журналы часто расплывчаты, и более чем часто говорят мне, что загрузчик загружает файлы из Microsoft.
Мне интересно, есть ли более простые способы сделать это с Ansible.
Я использовал следующие руководства от Microsoft, чтобы попытаться разобраться в этом:
Возможно, проблемная проблема: https://github.com/MicrosoftDocs/visualstudio-docs/issues/1531
Настройка:
Я создалобщий сетевой ресурс, который доступен следующим образом: \\ Share \ VisualStudio2017 \
Общий ресурс не имеет (в настоящее время) никаких ограничений при тестировании, поэтому «каждый» может читать его содержимое.
Общий ресурс заполняется следующей командой макета
vs_enterprise.exe --layout \\<server>\Share\Development\VisualStudio2017 --lang en-US --add Microsoft.VisualStudio.Workload.ManagedDesktop --add Microsoft.VisualStudio.Workload.NativeDesktop --add Microsoft.VisualStudio.Workload.Universal --add Microsoft.VisualStudio.Workload.NetWeb Microsoft.VisualStudio.Workload.Node --add Microsoft.VisualStudio.Workload.NetCrossPlat --add Microsoft.VisualStudio.Workload.NetCoreTools --includeRecommended
Обновлен файл Response.json (в общем ресурсе) до
{
"installChannelUri": "\\<server>\\Share\\Development\\VisualStudio2017\\ChannelManifest.json",
"channelUri": "\\<server>\\Share\\Development\\VisualStudio2017\\ChannelManifest.json",
"installCatalogUri": "\\<server>\\Share\\Development\\VisualStudio2017\\Catalog.json",
"channelId": "VisualStudio.15.Release",
"productId": "Microsoft.VisualStudio.Product.Enterprise",
"add": [
"Microsoft.VisualStudio.Workload.ManagedDesktop;includeRecommended",
"Microsoft.VisualStudio.Workload.NativeDesktop;includeRecommended",
"Microsoft.VisualStudio.Workload.NetCoreTools;includeRecommended",
"Microsoft.VisualStudio.Workload.NetCrossPlat;includeRecommended",
"Microsoft.VisualStudio.Workload.NetWeb;includeRecommended",
"Microsoft.VisualStudio.Workload.Node;includeRecommended",
"Microsoft.VisualStudio.Workload.Universal;includeRecommended"
],
"addProductLang": [
"en-US"
]
}
Общий ресурс объединен сроль:
- name: Install Visual Studio 2017
win_package:
path: '\\<server>\share\Development\VisualStudio2017\vs_enterprise.exe'
state: present
product_id: Microsoft.VisualStudio.Product.Enterprise
channel_id: VisualStudio.15.Release
user_name: <DOMAIN>\<USERNAME>
user_password: <PASSWORD>
arguments:
# - --quiet
- --wait
- --norestart
# - --add Microsoft.VisualStudio.Workload.ManagedDesktop
# - --add Microsoft.VisualStudio.Workload.NativeDesktop
# - --add Microsoft.VisualStudio.Workload.Universal
# - --add Microsoft.VisualStudio.Workload.NetWeb Microsoft.VisualStudio.Workload.Node
# - --add Microsoft.VisualStudio.Workload.NetCrossPlat
# - --add Microsoft.VisualStudio.Workload.NetCoreTools
# - --includeRecommended
Я запускаю playbook с командой с подробной настройкой
ansible-playbook -i hosts utvClients.yaml -vvvv
Вывод
TASK [VisualStudio2017 : Install Visual Studio 2017] ******************************************************************************************************************************************************
task path: /mnt/d/dev/Ansible/roles/VisualStudio2017/tasks/main.yaml:2
Using module file /usr/lib/python2.7/dist-packages/ansible/modules/windows/win_package.ps1
<192.168.56.101> ESTABLISH WINRM CONNECTION FOR USER: Ansible on PORT 5986 TO 192.168.56.101
checking if winrm_host 192.168.56.101 is an IPv6 address
EXEC (via pipeline wrapper)
Журнал загрузчика на хосте впуть C: \ users \\ AppData \ Local \ Temp \ dd_bootstrapper_.log говорит об этом:
Beginning of the log. Start Time: 3/6/2019 9:43:56 AM
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: Commandline arguments = --wait,--norestart,--path cache="\\<server>\share\Development\VisualStudio2017\",--env,_SFX_CAB_EXE_PACKAGE:C:\Users\Ansible\tyzrpvdy.v4j _SFX_CAB_EXE_ORIGINALWORKINGDIR:C:\Users\Ansible
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: Parent process name = tyzrpvdy
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: Parent process product version = 15.9.28307.423
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: CampaignId =
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: ResponseId not available in 'vs_setup_bootstrapper.config'. Trying to parse filename.
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: loading config settings: -update --update --layout -offline --offline --locale --layout --originalworkingdir --installLayoutPath --env
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: DownloadURL = https://aka.ms/vs/15/release/installer
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: InstallLocation = C:\Program Files (x86)\Microsoft Visual Studio\Installer
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: OfflineFilePath =
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: LayoutLocation =
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: ExecutableArguments = /finalizeInstall install --in "C:\ProgramData\Microsoft\VisualStudio\Packages\_bootstrapper\vs_setup_bootstrapper_201903060943571796.json" --norestart "--path cache="\\<server>\share\Development\VisualStudio2017\"" --locale en-US --activityId "d3c1a7c6-22ba-42af-9ce9-7ede1608e7be"
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: OSVersion = Microsoft Windows NT 10.0.17763.0
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: Starting to detect the existing VS and .Net...
VisualStudio Bootstrapper:3/6/2019 9:43:57 AM: Finished detecting the existing VS and .Net
Во-первых: DownloadUrl все еще имеет значение aka.ms?Я не переопределяю это должным образом?Есть еще вещи, чтобы рассмотреть?