本文整理汇总了Golang中github.com/dotcloud/docker/engine.Engine.RegisterCatchall方法的典型用法代码示例。如果您正苦于以下问题:Golang Engine.RegisterCatchall方法的具体用法?Golang Engine.RegisterCatchall怎么用?Golang Engine.RegisterCatchall使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/dotcloud/docker/engine.Engine
的用法示例。
在下文中一共展示了Engine.RegisterCatchall方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: run
//.........这里部分代码省略.........
}
return engine.StatusOK
})
} else {
return job.Errorf("Failed to create host context: %v", err)
}
})
eng.Register("inspect", func(job *engine.Job) (status engine.Status) {
if ctx, err := rax.getHostContext(); err == nil {
defer ctx.Close()
return ctx.exec(job, func(client HttpClient) (status engine.Status) {
path := fmt.Sprintf("/containers/%s/json", job.Args[0])
if resp, err := client.Post(path, ""); err != nil {
return job.Errorf("Failed call %s(path:%s): %v", job.Name, path, err)
} else if _, err := io.Copy(job.Stdout, resp.Body); err != nil {
return job.Errorf("Failed to copy response body: %v", err)
}
return engine.StatusOK
})
} else {
return job.Errorf("Failed to create host context: %v", err)
}
})
eng.Register("attach", func(job *engine.Job) (status engine.Status) {
if ctx, err := rax.getHostContext(); err == nil {
defer ctx.Close()
return ctx.exec(job, func(client HttpClient) (status engine.Status) {
path := fmt.Sprintf("/containers/%s/attach?stream=%s&stdout=%s&stderr=%s", job.Args[0],
url.QueryEscape(job.Getenv("stream")),
url.QueryEscape(job.Getenv("stdout")),
url.QueryEscape(job.Getenv("stderr")))
if resp, err := client.Post(path, ""); err != nil {
return job.Errorf("Failed call %s(path:%s): %v", job.Name, path, err)
} else if _, err := io.Copy(job.Stdout, resp.Body); err != nil {
return job.Errorf("Failed to copy response body: %v", err)
}
return engine.StatusOK
})
} else {
return job.Errorf("Failed to create host context: %v", err)
}
})
eng.Register("pull", func(job *engine.Job) (status engine.Status) {
if ctx, err := rax.getHostContext(); err == nil {
defer ctx.Close()
return ctx.exec(job, func(client HttpClient) (status engine.Status) {
path := fmt.Sprintf("/images/create?fromImage=%s&tag=%s", job.Args[0], url.QueryEscape(job.Getenv("tag")))
if resp, err := client.Post(path, ""); err != nil {
return job.Errorf("Failed call %s(path:%s): %v", job.Name, path, err)
} else if _, err := io.Copy(job.Stdout, resp.Body); err != nil {
return job.Errorf("Failed to copy response body: %v", err)
}
return engine.StatusOK
})
} else {
return job.Errorf("Failed to create host context: %v", err)
}
})
eng.Register("logs", func(job *engine.Job) (status engine.Status) {
if ctx, err := rax.getHostContext(); err == nil {
defer ctx.Close()
return ctx.exec(job, func(client HttpClient) (status engine.Status) {
path := fmt.Sprintf("/containers/%s/logs?stdout=%s&stderr=%s", job.Args[0], url.QueryEscape(job.Getenv("stdout")), url.QueryEscape(job.Getenv("stderr")))
if resp, err := client.Get(path, ""); err != nil {
return job.Errorf("Failed call %s(path:%s): %v", job.Name, path, err)
} else if _, err := io.Copy(job.Stdout, resp.Body); err != nil {
return job.Errorf("Failed to copy response body: %v", err)
}
return engine.StatusOK
})
} else {
return job.Errorf("Failed to create host context: %v", err)
}
})
eng.RegisterCatchall(func(job *engine.Job) engine.Status {
log.Printf("[UNIMPLEMENTED] %s %#v %#v %#v", job.Name, *job, job.Env(), job.Args)
return engine.StatusOK
})
}
return err
}