Не удается запустить Windows WinRm с ножом на рабочей станции Mac OS X
Выполнение команды knife bootstrap windows winrm ec2box.amazonaws.com -r 'role[web]' -x Administrator -P 'mypassword'
с моей рабочей станции Mac OS X выдает вывод ниже. Запустив его с рабочей станции Windows, команда успешно запускается. Есть ли дополнительный шаг, который мне нужно предпринять, чтобы моя рабочая станция Mac OS X правильно установила связь через WinRM?
Я использую это на Windows Server 2012 AMI Amazon. Это напечатано #39
везде на моем терминале, а не артефакт переполнения стека.
WARNING: Could not load IOV methods. Check your GSSAPI C library for an update
WARNING: Could not load AEAD methods. Check your GSSAPI C library for an update
Bootstrapping Chef on ec2box.amazonaws.com
ec2box.amazonaws.com "Rendering 'C:\Users\ADMINI~1\AppData\Local\Temp\bootstrap-7738-1370535154.bat' chunk 1"
ec2box.amazonaws.com "Rendering 'C:\Users\ADMINI~1\AppData\Local\Temp\bootstrap-7738-1370535154.bat' chunk 2"
ec2box.amazonaws.com '#39' is not recognized as an internal or external command,
ec2box.amazonaws.com operable program or batch file.
ec2box.amazonaws.com "Rendering 'C:\Users\ADMINI~1\AppData\Local\Temp\bootstrap-7738-1370535154.bat' chunk 3"
ec2box.amazonaws.com "Rendering 'C:\Users\ADMINI~1\AppData\Local\Temp\bootstrap-7738-1370535154.bat' chunk 4"
ec2box.amazonaws.com '#39' is not recognized as an internal or external command,
ec2box.amazonaws.com operable program or batch file.
ec2box.amazonaws.com '#39' is not recognized as an internal or external command,
ec2box.amazonaws.com operable program or batch file.
ec2box.amazonaws.com "Rendering 'C:\Users\ADMINI~1\AppData\Local\Temp\bootstrap-7738-1370535154.bat' chunk 5"
ec2box.amazonaws.com "Rendering 'C:\Users\ADMINI~1\AppData\Local\Temp\bootstrap-7738-1370535154.bat' chunk 6"
ec2box.amazonaws.com "Rendering 'C:\Users\ADMINI~1\AppData\Local\Temp\bootstrap-7738-1370535154.bat' chunk 7"
ec2box.amazonaws.com "Rendering 'C:\Users\ADMINI~1\AppData\Local\Temp\bootstrap-7738-1370535154.bat' chunk 8"
ec2box.amazonaws.com "Rendering 'C:\Users\ADMINI~1\AppData\Local\Temp\bootstrap-7738-1370535154.bat' chunk 9"
ec2box.amazonaws.com
ec2box.amazonaws.com else was unexpected at this time.
ec2box.amazonaws.com C:\Users\Administrator>mkdir C:\chef
ec2box.amazonaws.com
ec2box.amazonaws.com C:\Users\Administrator>(
ec2box.amazonaws.com echo.url = WScript.Arguments.Named("url")
ec2box.amazonaws.com echo.path = WScript.Arguments.Named("path")
ec2box.amazonaws.com echo.proxy = null
ec2box.amazonaws.com echo.Set objXMLHTTP = CreateObject("MSXML2.ServerXMLHTTP")
ec2box.amazonaws.com echo.Set wshShell = CreateObject( "WScript.Shell" )
ec2box.amazonaws.com echo.Set objUserVariables = wshShell.Environment("USER")
ec2box.amazonaws.com echo.
ec2box.amazonaws.com echo.
ec2box.amazonaws.com echo.On Error Goto 0
ec2box.amazonaws.com echo.
ec2box.amazonaws.com echo.objXMLHTTP.open "GET", url, false
ec2box.amazonaws.com echo.objXMLHTTP.send()
ec2box.amazonaws.com echo.If objXMLHTTP.Status = 200 Then
ec2box.amazonaws.com echo.Set objADOStream = CreateObject("ADODB.Stream")
ec2box.amazonaws.com echo.objADOStream.Open
ec2box.amazonaws.com echo.objADOStream.Type = 1
ec2box.amazonaws.com echo.objADOStream.Write objXMLHTTP.ResponseBody
ec2box.amazonaws.com echo.objADOStream.Position = 0
ec2box.amazonaws.com echo.Set objFSO = Createobject("Scripting.FileSystemObject")
ec2box.amazonaws.com echo.If objFSO.Fileexists(path) Then objFSO.DeleteFile path
ec2box.amazonaws.com echo.Set objFSO = Nothing
ec2box.amazonaws.com echo.objADOStream.SaveToFile path
ec2box.amazonaws.com echo.objADOStream.Close
ec2box.amazonaws.com echo.Set objADOStream = Nothing
ec2box.amazonaws.com echo.End if
ec2box.amazonaws.com echo.Set objXMLHTTP = Nothing
ec2box.amazonaws.com ) 1>C:\chef\wget.vbs
ec2box.amazonaws.com
ec2box.amazonaws.com C:\Users\Administrator>(
ec2box.amazonaws.com echo.param(
ec2box.amazonaws.com echo. [String] $remoteUrl,
ec2box.amazonaws.com echo. [String] $localPath
ec2box.amazonaws.com echo.)
ec2box.amazonaws.com echo.
ec2box.amazonaws.com echo.$webClient = new-object System.Net.WebClient;
ec2box.amazonaws.com echo.
ec2box.amazonaws.com echo.$webClient.DownloadFile($remoteUrl, $localPath);
ec2box.amazonaws.com ) 1>C:\chef\wget.ps1
ec2box.amazonaws.com C:\Users\Administrator>) else (
4 ответа
Похоже, работает с ножом Windows 0.5.10 [протестировано с Windows Server 2008R2]
Установите его с помощью:
gem uninstall knife-windows
gem install knife-windows -v 0.5.10
проверьте ваши драгоценные камни с:
gem list|grep knife-windows
И это должно показать:
knife-windows (0.5.10)
Я столкнулся с подобной проблемой. То, что я сделал, было:
Удалите gem, а затем выполните обновление aptitude, а затем установите плагин для gem & knife windows в этой папке (/opt/chef/embedded/bin/gem install knife-windows), откройте порт 5985 и настройте winrm:
1.winrm quickconfig -q
2.winrm set winrm/config/winrs @{MaxMemoryPerShellMB="300"}
3.winrm set winrm/config @{MaxTimeoutms="1800000"}
4.winrm set winrm/config/service @{AllowUnencrypted="true"}
5.winrm set winrm/config/service/auth @{Basic="true"}
и затем загрузился:
knife bootstrap windows winrm ec2-xx-xxx-xx.compute-1.amazonaws.com -r 'recipe[cookbook]' -x Administrator -P xxxxxxxx -N "WIN-xxxxx"
У меня была точно такая же проблема с символами #39 на моем OSX, посмотрите мое описание: застрял при попытке загрузить сервер Windows с помощью Chef
В моем случае, RVM был ответственным виновником.
Мне удалось решить эту проблему, выполнив следующие действия: 1) загрузив и запустив установщик omnibus
curl -L https://www.opscode.com/chef/install.sh | sudo bash
2) Отключение rvm с помощью системного ruby:
rvm use system
3) установка ножевых окон прямо в библиотеке шеф-поваров:
sudo /opt/chef/embedded/bin/gem install knife-windows
Это, вместе с настройкой сервера Windows 2008 в соответствии с рекомендациями на https://github.com/opscode/knife-windows(команды, доступные в этом разделе: https://gist.github.com/jimcroft/3878113) сделали свое дело, и я могу загрузить свой узел:) Агата
Похоже, что проблема может быть связана с плохой совместимостью между Ruby 2.x и гемом winrm: