WIP: app errors
This commit is contained in:
parent
e839f100df
commit
58a24a50e1
|
@ -1,12 +1,14 @@
|
||||||
package app
|
package app
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
abraFormatter "coopcloud.tech/abra/cli/formatter"
|
||||||
"coopcloud.tech/abra/cli/internal"
|
"coopcloud.tech/abra/cli/internal"
|
||||||
"coopcloud.tech/abra/pkg/autocomplete"
|
"coopcloud.tech/abra/pkg/autocomplete"
|
||||||
"coopcloud.tech/abra/pkg/client"
|
"coopcloud.tech/abra/pkg/client"
|
||||||
|
stack "coopcloud.tech/abra/pkg/upstream/stack"
|
||||||
"github.com/docker/docker/api/types"
|
"github.com/docker/docker/api/types"
|
||||||
"github.com/docker/docker/api/types/filters"
|
"github.com/docker/docker/api/types/filters"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
|
@ -34,6 +36,15 @@ by "abra app logs <app>".
|
||||||
logrus.Fatal(err)
|
logrus.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
isDeployed, _, err := stack.IsDeployed(c.Context, cl, app.StackName())
|
||||||
|
if err != nil {
|
||||||
|
logrus.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
if !isDeployed {
|
||||||
|
logrus.Fatalf("%s is not deployed?", app.Name)
|
||||||
|
}
|
||||||
|
|
||||||
filters := filters.NewArgs()
|
filters := filters.NewArgs()
|
||||||
filters.Add("name", app.StackName())
|
filters.Add("name", app.StackName())
|
||||||
|
|
||||||
|
@ -42,38 +53,50 @@ by "abra app logs <app>".
|
||||||
logrus.Fatal(err)
|
logrus.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
// tableCol := []string{"status", "error", "healthcheck", "healthcheck logs"}
|
tableCol := []string{"app name", "status", "error", "out of memory", "restart count", "healthcheck"}
|
||||||
// table := abraFormatter.CreateTable(tableCol)
|
table := abraFormatter.CreateTable(tableCol)
|
||||||
|
|
||||||
for _, container := range containers {
|
for _, container := range containers {
|
||||||
fmt.Println("service: ", strings.Join(container.Names, ""))
|
serviceName := getServiceName(container.Names)
|
||||||
|
|
||||||
containerState, err := cl.ContainerInspect(c.Context, container.ID)
|
containerState, err := cl.ContainerInspect(c.Context, container.ID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
logrus.Fatal(err)
|
logrus.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Println("restarted no. times: ", containerState.RestartCount)
|
errMsg := "N/A"
|
||||||
fmt.Println("status: ", containerState.State.Status)
|
hcStat := "N/A"
|
||||||
fmt.Println("oom killed: ", containerState.State.OOMKilled)
|
var hcLogs []string
|
||||||
fmt.Println("error: ", containerState.State.Error)
|
|
||||||
|
|
||||||
if containerState.State.Health != nil {
|
if containerState.State.Health != nil {
|
||||||
fmt.Println("healthcheck status: ", containerState.State.Health.Status)
|
hcStat = containerState.State.Health.Status
|
||||||
fmt.Println("failed no. times: ", containerState.State.Health.FailingStreak)
|
|
||||||
for _, log := range containerState.State.Health.Log {
|
for _, log := range containerState.State.Health.Log {
|
||||||
fmt.Println("output: ", log.Output)
|
hcLogs = append(hcLogs, log.Output)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Println("---")
|
if containerState.State.Error != "" {
|
||||||
|
errMsg = containerState.State.Error
|
||||||
// table.Append([]string{containerState.State.Status, containerState.State.Error, healthCheckState, healthCheckLogs})
|
}
|
||||||
|
|
||||||
|
table.Append([]string{
|
||||||
|
serviceName,
|
||||||
|
containerState.State.Status,
|
||||||
|
errMsg,
|
||||||
|
strconv.FormatBool(containerState.State.OOMKilled),
|
||||||
|
strconv.Itoa(containerState.RestartCount),
|
||||||
|
hcStat,
|
||||||
|
strings.Join(hcLogs, "\n"),
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// table.Render()
|
table.Render()
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func getServiceName(names []string) string {
|
||||||
|
containerName := strings.Join(names, " ")
|
||||||
|
trimmed := strings.TrimPrefix(containerName, "/")
|
||||||
|
return strings.Split(trimmed, ".")[0]
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue