diff options
-rw-r--r-- | cmd/rr/.rr.yaml | 2 | ||||
-rw-r--r-- | cmd/rr/http/workers.go | 14 |
2 files changed, 14 insertions, 2 deletions
diff --git a/cmd/rr/.rr.yaml b/cmd/rr/.rr.yaml index 34475da7..bf4c699b 100644 --- a/cmd/rr/.rr.yaml +++ b/cmd/rr/.rr.yaml @@ -33,7 +33,7 @@ http: # worker pool configuration. pool: # number of workers to be serving. - numWorkers: 2 + numWorkers: 16 # maximum jobs per worker, 0 - unlimited. maxJobs: 0 diff --git a/cmd/rr/http/workers.go b/cmd/rr/http/workers.go index 6083f10c..9ad20be7 100644 --- a/cmd/rr/http/workers.go +++ b/cmd/rr/http/workers.go @@ -33,6 +33,7 @@ import ( "time" "github.com/dustin/go-humanize" "github.com/spiral/roadrunner/cmd/rr/utils" + "github.com/shirou/gopsutil/process" ) func init() { @@ -61,13 +62,14 @@ func workersHandler(cmd *cobra.Command, args []string) error { } tw := tablewriter.NewWriter(os.Stdout) - tw.SetHeader([]string{"PID", "Status", "Execs", "Created"}) + tw.SetHeader([]string{"PID", "Status", "Execs", "Memory", "Created"}) for _, w := range r.Workers { tw.Append([]string{ strconv.Itoa(w.Pid), renderStatus(w.Status), renderJobs(w.NumJobs), + renderMemory(w.Pid), renderAlive(time.Unix(0, w.Created)), }) } @@ -101,3 +103,13 @@ func renderJobs(number uint64) string { func renderAlive(t time.Time) string { return humanize.RelTime(t, time.Now(), "ago", "") } + +func renderMemory(pid int) string { + p, _ := process.NewProcess(int32(pid)) + i, err := p.MemoryInfo() + if err != nil { + return err.Error() + } + + return humanize.Bytes(i.RSS) +} |