Merge branch 'b-config-handshake'
This commit is contained in:
commit
dbbf10472b
@ -15,13 +15,14 @@ type Config struct {
|
|||||||
Type string `mapstructure:"communicator"`
|
Type string `mapstructure:"communicator"`
|
||||||
|
|
||||||
// SSH
|
// SSH
|
||||||
SSHHost string `mapstructure:"ssh_host"`
|
SSHHost string `mapstructure:"ssh_host"`
|
||||||
SSHPort int `mapstructure:"ssh_port"`
|
SSHPort int `mapstructure:"ssh_port"`
|
||||||
SSHUsername string `mapstructure:"ssh_username"`
|
SSHUsername string `mapstructure:"ssh_username"`
|
||||||
SSHPassword string `mapstructure:"ssh_password"`
|
SSHPassword string `mapstructure:"ssh_password"`
|
||||||
SSHPrivateKey string `mapstructure:"ssh_private_key_file"`
|
SSHPrivateKey string `mapstructure:"ssh_private_key_file"`
|
||||||
SSHPty bool `mapstructure:"ssh_pty"`
|
SSHPty bool `mapstructure:"ssh_pty"`
|
||||||
SSHTimeout time.Duration `mapstructure:"ssh_timeout"`
|
SSHTimeout time.Duration `mapstructure:"ssh_timeout"`
|
||||||
|
SSHHandshakeAttempts int `mapstructure:"ssh_handshake_attempts"`
|
||||||
|
|
||||||
// WinRM
|
// WinRM
|
||||||
WinRMUser string `mapstructure:"winrm_username"`
|
WinRMUser string `mapstructure:"winrm_username"`
|
||||||
@ -72,6 +73,10 @@ func (c *Config) prepareSSH(ctx *interpolate.Context) []error {
|
|||||||
c.SSHTimeout = 5 * time.Minute
|
c.SSHTimeout = 5 * time.Minute
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if c.SSHHandshakeAttempts == 0 {
|
||||||
|
c.SSHHandshakeAttempts = 10
|
||||||
|
}
|
||||||
|
|
||||||
// Validation
|
// Validation
|
||||||
var errs []error
|
var errs []error
|
||||||
if c.SSHUsername == "" {
|
if c.SSHUsername == "" {
|
||||||
|
@ -149,8 +149,10 @@ func (s *StepConnectSSH) waitForSSH(state multistep.StateBag, cancel <-chan stru
|
|||||||
handshakeAttempts += 1
|
handshakeAttempts += 1
|
||||||
}
|
}
|
||||||
|
|
||||||
if handshakeAttempts < 10 {
|
if handshakeAttempts < s.Config.SSHHandshakeAttempts {
|
||||||
// Try to connect via SSH a handful of times
|
// Try to connect via SSH a handful of times. We sleep here
|
||||||
|
// so we don't get a ton of authentication errors back to back.
|
||||||
|
time.Sleep(2 * time.Second)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user