-
Notifications
You must be signed in to change notification settings - Fork 3.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
windows-restart provisioner does not respect restart_check_command when using SSH communicator #6055
Comments
I'm not sure if this is a bug or unclear documentation -- If you provide your own restart check command, the provisioner runs both yours and our default one; this is because we've found that if we don't run our default, we run into an issue where windows will restart and start running the next provisioner before powershell modules are fully loaded. Can you please provide your debug logs (set PACKER_LOG=1 in your environment) and show me what you're seeing? |
My JSON is pretty much what I pasted above. {
"builders": [
{
"type": "virtualbox-ovf",
"source_path": "output-stage2/output-stage2.ovf",
"shutdown_command": "shutdown /s /t 10 /f /d p:4:1 /c Packer_Provisioning_Shutdown",
"guest_additions_mode": "disable",
"output_directory": "output-stage3",
"vm_name": "output-stage3",
"ssh_timeout": "10m",
"ssh_username": "owner",
"ssh_password": "owner"
}
],
"provisioners": [
{
"type": "windows-restart",
"restart_command": "echo restart",
"restart_check_command": "echo check"
}
]
} Here's the first part of the log, the rest are just repetition of the "shutdown help" from default shutdown.exe command because of escape issue
|
This looks like the normal logs, not the debug logs. Did you set the env var PACKER_LOG=1? |
Oops, sorry. Had to jump thru hoops to get Windows to pipe both stdout and stderr to the same file, Didn't realize the context I was running from didn't inherit it. 500 lines
|
Thanks for the updated logs! |
@leonyu upon revisiting this ticket, I'm confused... why are you trying to use the |
packer.zip |
The Linux target was solely for debugging to see what SSH command was being pass in. I will try the new build when I get home. |
It would appear 1.2.2 or the .zip build provided is unusable for my attempted configuration -- Using SSH instead of WinRM as communicator for Windows on VirtualBox
I assume If I get a chance will try produce a JSON fie based on trial ISOs that I can publish publicly. The reason I am trying to use SSH on Windows is because I need to transfer large files in latter steps of my build, which takes a long time in WinRM. |
Sorry, that's a known bug I've been meaning to fix. I'll prioritize it for the next release. Are you trying to upload .vbox_version into a directory? If so, you can work around it in the meantime by being explicit about ending the destination directory with a |
oh, nevermind -- this is a bug specific to virtualbox. Fixing now. |
Okay, sorry about that. Can you try this one? |
Doesn't appear to fix the issue of the "shutdown help" spam. I have created a stripped down version of my build here: You should be able to reproduce the problem with Right now the default shell is set to PowerShell, but the error existed with CMD, at least in previous version. NOTE: First stage takes half an hour to an hour to build. It also download the Windows 2008 evaluation ISO and a few big updates (.NET 4.7, WMF 5, Rollup update) |
Thanks. |
Hmm... I'm unable to get your repro case working because the openssh install fails:
In the meantime though, I'm wondering whether this is really the root issue. it isn't RestartCheckCommand that's failing, by the way -- it's an internal value, TryCheckReboot. TryCheckReboot is spammy by nature because it should eventually get cut off when the computer actually, successfully, reboots. In your example case above, this never happens because "echo restart" isn't a valid restart command. My guess is that the restart_command you're overwriting "for real" isn't valid either, though I can't vet it since you didn't share it. |
Looks like .NET 4.7 upgrade didn't go through, Windows 2008 R2 only comes with TLS 1.0 support for PowerShell/.NET. GitHub has disabled TLS 1.0 last year (minimum TLS 1.1). I can upload my |
Here's a prebuilt stage one You can untar it in the same folder (should create a
|
Thanks, I can repro based on that. Unfortunately, I also did some research and realized this is ultimately not going to work for you; the windows-restart provisioner was written specifically for winRM, in order to work around the fact that it can't handle disconnects. However, Packer's ssh communicator, which you're using, can handle restarts. See this thread for context. Linked there is an example of how reboots are managed before OpenSSH is connected (though you've managed this with your stage-1 build). When you're connected via SSH, your best option is unfortunately the one outlined in #1983 (comment) |
I'm going to close this for now, since nothing's really changed since Mitchell closed #1983. HOWEVER, if you're able to successfully work around the "restart_command" double-escaping madness and find something that actually works... (a) I'd love to hear about it so I can implement it for the SSH communicator and make windows-restart more useful to SSH-sers, and (b) it will make the spamminess from that "TryCheckReboot" command not actually an issue. It'll be annoying, but it isn't the root problem. The fact that the restart_command is generating the same help menu instead of actually restarting the computer is the problem. All this said, I've built you a new Packer binary that'll reduce the spamminess from the TryCheckReboot command to make it easier for you to find and focus on the restart_check command. |
Thank you for the investigation!! Really appreciate it.
I will try with suggestion in linked ticket.
…On Tue, Apr 10, 2018, 2:14 PM M. Marsh ***@***.***> wrote:
I'm going to close this for now, since nothing's really changed since
Mitchell closed #1983 <#1983>.
HOWEVER, if you're able to successfully work around the "restart_command"
double-escaping madness and find something that actually works...
(a) I'd love to hear about it so I can implement it for the SSH
communicator and make windows-restart more useful to SSH-sers, and
(b) it will make the spamminess from that "TryCheckReboot" command not
actually an issue. It'll be annoying, but it isn't the root problem. The
fact that the restart_command is generating the same help menu instead of
actually restarting the computer is the problem.
All this said, I've built you a new Packer binary that'll reduce the
spamminess from the TryCheckReboot command to make it easier for you to
find and focus on the restart_check command.
packer.zip <https://github.com/hashicorp/packer/files/1895854/packer.zip>
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#6055 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AASnBs-vhxVV6aqRLK1CRgzF34W5v-opks5tnPaYgaJpZM4S6UAm>
.
|
I've just made a PR I think may actually fix this. See the above link. |
I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues. If you have found a problem that seems similar to this, please open a new issue and complete the issue template so we can capture all the details necessary to investigate further. |
windows-restart
provisioner does not respectrestart_check_command
when using SSH communicator.Instead of trying to execute provided
restart_check_command
in a loop, it would attempt to execute the default command, and flooded the console with its infinite attempts to executeshutdown.exe
.Sample JSON
Context:
Due to command escape bug in the current Win32-OpenSSH server implementation (PowerShell/Win32-OpenSSH#1082), I have to override the built-in
windows-restart
commands when using SSH communicator on a guest with Win32-OpenSSH; however, this Packer bug is preventing me from doing so.The text was updated successfully, but these errors were encountered: