本文整理匯總了Golang中github.com/docker/engine-api/types.Info.DriverStatus方法的典型用法代碼示例。如果您正苦於以下問題:Golang Info.DriverStatus方法的具體用法?Golang Info.DriverStatus怎麽用?Golang Info.DriverStatus使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/docker/engine-api/types.Info
的用法示例。
在下文中一共展示了Info.DriverStatus方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: getInfo
// GET /info
func getInfo(c *context, w http.ResponseWriter, r *http.Request) {
info := apitypes.Info{
Images: len(c.cluster.Images().Filter(cluster.ImageFilterOptions{})),
NEventsListener: c.eventsHandler.Size(),
Debug: c.debug,
MemoryLimit: true,
SwapLimit: true,
CPUCfsPeriod: true,
CPUCfsQuota: true,
CPUShares: true,
CPUSet: true,
IPv4Forwarding: true,
BridgeNfIptables: true,
BridgeNfIP6tables: true,
OomKillDisable: true,
ServerVersion: "swarm/" + version.VERSION,
OperatingSystem: runtime.GOOS,
Architecture: runtime.GOARCH,
NCPU: int(c.cluster.TotalCpus()),
MemTotal: c.cluster.TotalMemory(),
HTTPProxy: os.Getenv("http_proxy"),
HTTPSProxy: os.Getenv("https_proxy"),
NoProxy: os.Getenv("no_proxy"),
SystemTime: time.Now().Format(time.RFC3339Nano),
ExperimentalBuild: experimental.ENABLED,
}
// API versions older than 1.22 use DriverStatus and return \b characters in the output
status := c.statusHandler.Status()
if c.apiVersion != "" && versionpkg.Version(c.apiVersion).LessThan("1.22") {
for i := range status {
if status[i][0][:1] == " " {
status[i][0] = status[i][0][1:]
} else {
status[i][0] = "\b" + status[i][0]
}
}
info.DriverStatus = status
} else {
info.SystemStatus = status
}
kernelVersion := "<unknown>"
if kv, err := kernel.GetKernelVersion(); err != nil {
log.Warnf("Could not get kernel version: %v", err)
} else {
kernelVersion = kv.String()
}
info.KernelVersion = kernelVersion
for _, c := range c.cluster.Containers() {
info.Containers++
if c.Info.State.Paused {
info.ContainersPaused++
} else if c.Info.State.Running {
info.ContainersRunning++
} else {
info.ContainersStopped++
}
}
hostname := "<unknown>"
if hn, err := os.Hostname(); err != nil {
log.Warnf("Could not get hostname: %v", err)
} else {
hostname = hn
}
info.Name = hostname
w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(info)
}