mirror of https://github.com/docker/docs.git
Merge pull request #775 from nathanleclaire/wait_for_ssh
Add generic function to wait for SSH
This commit is contained in:
commit
2486755347
41
host.go
41
host.go
|
@ -508,6 +508,10 @@ func (h *Host) Provision() error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := WaitForSSH(h); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
// install docker - until cloudinit we use ubuntu everywhere so we
|
// install docker - until cloudinit we use ubuntu everywhere so we
|
||||||
// just install it using the docker repos
|
// just install it using the docker repos
|
||||||
cmd, err := h.GetSSHCommand("if [ ! -e /usr/bin/docker ]; then curl -sSL https://get.docker.com | sh -; fi")
|
cmd, err := h.GetSSHCommand("if [ ! -e /usr/bin/docker ]; then curl -sSL https://get.docker.com | sh -; fi")
|
||||||
|
@ -704,3 +708,40 @@ func (h *Host) SaveConfig() error {
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func sshAvailableFunc(h *Host) func() bool {
|
||||||
|
return func() bool {
|
||||||
|
log.Debug("Getting to WaitForSSH function...")
|
||||||
|
hostname, err := h.Driver.GetSSHHostname()
|
||||||
|
if err != nil {
|
||||||
|
log.Debugf("Error getting IP address waiting for SSH: %s", err)
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
port, err := h.Driver.GetSSHPort()
|
||||||
|
if err != nil {
|
||||||
|
log.Debugf("Error getting SSH port: %s", err)
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if err := ssh.WaitForTCP(fmt.Sprintf("%s:%d", hostname, port)); err != nil {
|
||||||
|
log.Debugf("Error waiting for TCP waiting for SSH: %s", err)
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
cmd, err := h.GetSSHCommand("exit 0")
|
||||||
|
if err != nil {
|
||||||
|
log.Debugf("Error getting ssh command 'exit 0' : %s", err)
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
if err := cmd.Run(); err != nil {
|
||||||
|
log.Debugf("Error running ssh command 'exit 0' : %s", err)
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func WaitForSSH(h *Host) error {
|
||||||
|
if err := utils.WaitFor(sshAvailableFunc(h)); err != nil {
|
||||||
|
return fmt.Errorf("Too many retries. Last error: %s", err)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue