system: more detailed system information
This commit is contained in:
parent
2fd0edbff9
commit
9226ccae31
|
@ -21,11 +21,27 @@ func getSystemInformation(c *gin.Context) {
|
||||||
i, err := system.GetSystemInformation()
|
i, err := system.GetSystemInformation()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
NewTrackedError(err).Abort(c)
|
NewTrackedError(err).Abort(c)
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if c.Query("v") == "2" {
|
||||||
c.JSON(http.StatusOK, i)
|
c.JSON(http.StatusOK, i)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
c.JSON(http.StatusOK, struct {
|
||||||
|
Architecture string `json:"architecture"`
|
||||||
|
CPUCount int `json:"cpu_count"`
|
||||||
|
KernelVersion string `json:"kernel_version"`
|
||||||
|
OS string `json:"os"`
|
||||||
|
Version string `json:"version"`
|
||||||
|
}{
|
||||||
|
Architecture: i.System.Architecture,
|
||||||
|
CPUCount: i.System.CPUThreads,
|
||||||
|
KernelVersion: i.System.KernelVersion,
|
||||||
|
OS: i.System.OSType,
|
||||||
|
Version: i.Version,
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Returns all the servers that are registered and configured correctly on
|
// Returns all the servers that are registered and configured correctly on
|
||||||
|
|
128
system/system.go
128
system/system.go
|
@ -1,17 +1,57 @@
|
||||||
package system
|
package system
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"context"
|
||||||
"runtime"
|
"runtime"
|
||||||
|
|
||||||
|
"github.com/acobaugh/osrelease"
|
||||||
|
"github.com/docker/docker/api/types"
|
||||||
|
"github.com/docker/docker/client"
|
||||||
"github.com/docker/docker/pkg/parsers/kernel"
|
"github.com/docker/docker/pkg/parsers/kernel"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Information struct {
|
type Information struct {
|
||||||
Version string `json:"version"`
|
Version string `json:"version"`
|
||||||
KernelVersion string `json:"kernel_version"`
|
Docker DockerInformation `json:"docker"`
|
||||||
|
System System `json:"system"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type DockerInformation struct {
|
||||||
|
Version string `json:"version"`
|
||||||
|
Cgroups DockerCgroups `json:"cgroups"`
|
||||||
|
Containers DockerContainers `json:"containers"`
|
||||||
|
Storage DockerStorage `json:"storage"`
|
||||||
|
Runc DockerRunc `json:"runc"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type DockerCgroups struct {
|
||||||
|
Driver string `json:"driver"`
|
||||||
|
Version string `json:"version"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type DockerContainers struct {
|
||||||
|
Total int `json:"total"`
|
||||||
|
Running int `json:"running"`
|
||||||
|
Paused int `json:"paused"`
|
||||||
|
Stopped int `json:"stopped"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type DockerStorage struct {
|
||||||
|
Driver string `json:"driver"`
|
||||||
|
Filesystem string `json:"filesystem"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type DockerRunc struct {
|
||||||
|
Version string `json:"version"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type System struct {
|
||||||
Architecture string `json:"architecture"`
|
Architecture string `json:"architecture"`
|
||||||
|
CPUThreads int `json:"cpu_threads"`
|
||||||
|
MemoryBytes int64 `json:"memory_bytes"`
|
||||||
|
KernelVersion string `json:"kernel_version"`
|
||||||
OS string `json:"os"`
|
OS string `json:"os"`
|
||||||
CpuCount int `json:"cpu_count"`
|
OSType string `json:"os_type"`
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetSystemInformation() (*Information, error) {
|
func GetSystemInformation() (*Information, error) {
|
||||||
|
@ -20,13 +60,83 @@ func GetSystemInformation() (*Information, error) {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
s := &Information{
|
version, info, err := GetDockerInfo(context.Background())
|
||||||
Version: Version,
|
if err != nil {
|
||||||
KernelVersion: k.String(),
|
return nil, err
|
||||||
Architecture: runtime.GOARCH,
|
|
||||||
OS: runtime.GOOS,
|
|
||||||
CpuCount: runtime.NumCPU(),
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return s, nil
|
release, err := osrelease.Read()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
var os string
|
||||||
|
if release["PRETTY_NAME"] != "" {
|
||||||
|
os = release["PRETTY_NAME"]
|
||||||
|
} else if release["NAME"] != "" {
|
||||||
|
os = release["NAME"]
|
||||||
|
} else {
|
||||||
|
os = info.OperatingSystem
|
||||||
|
}
|
||||||
|
|
||||||
|
var filesystem string
|
||||||
|
for _, v := range info.DriverStatus {
|
||||||
|
if v[0] != "Backing Filesystem" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
filesystem = v[1]
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
return &Information{
|
||||||
|
Version: Version,
|
||||||
|
Docker: DockerInformation{
|
||||||
|
Version: version.Version,
|
||||||
|
Cgroups: DockerCgroups{
|
||||||
|
Driver: info.CgroupDriver,
|
||||||
|
Version: info.CgroupVersion,
|
||||||
|
},
|
||||||
|
Containers: DockerContainers{
|
||||||
|
Total: info.Containers,
|
||||||
|
Running: info.ContainersRunning,
|
||||||
|
Paused: info.ContainersPaused,
|
||||||
|
Stopped: info.ContainersStopped,
|
||||||
|
},
|
||||||
|
Storage: DockerStorage{
|
||||||
|
Driver: info.Driver,
|
||||||
|
Filesystem: filesystem,
|
||||||
|
},
|
||||||
|
Runc: DockerRunc{
|
||||||
|
Version: info.RuncCommit.ID,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
System: System{
|
||||||
|
Architecture: runtime.GOARCH,
|
||||||
|
CPUThreads: runtime.NumCPU(),
|
||||||
|
MemoryBytes: info.MemTotal,
|
||||||
|
KernelVersion: k.String(),
|
||||||
|
OS: os,
|
||||||
|
OSType: runtime.GOOS,
|
||||||
|
},
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetDockerInfo(ctx context.Context) (types.Version, types.Info, error) {
|
||||||
|
// TODO: find a way to re-use the client from the docker environment.
|
||||||
|
c, err := client.NewClientWithOpts(client.FromEnv, client.WithAPIVersionNegotiation())
|
||||||
|
if err != nil {
|
||||||
|
return types.Version{}, types.Info{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
dockerVersion, err := c.ServerVersion(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return types.Version{}, types.Info{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
dockerInfo, err := c.Info(ctx)
|
||||||
|
if err != nil {
|
||||||
|
return types.Version{}, types.Info{}, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return dockerVersion, dockerInfo, nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user