summaryrefslogtreecommitdiff
path: root/pkg/process/state.go
diff options
context:
space:
mode:
authorValery Piashchynski <[email protected]>2021-04-19 16:42:28 +0300
committerValery Piashchynski <[email protected]>2021-04-19 16:42:28 +0300
commitbaa12b092578d41218585d918fb7e1425700272d (patch)
tree91881bd0ac32c609ea01fafe3bbc15a13a67c392 /pkg/process/state.go
parent112b7b60bbc045f4935e1766be9d2266abf68b31 (diff)
- Add tests, update Informer implementation
Signed-off-by: Valery Piashchynski <[email protected]>
Diffstat (limited to 'pkg/process/state.go')
-rw-r--r--pkg/process/state.go71
1 files changed, 71 insertions, 0 deletions
diff --git a/pkg/process/state.go b/pkg/process/state.go
new file mode 100644
index 00000000..462dd47e
--- /dev/null
+++ b/pkg/process/state.go
@@ -0,0 +1,71 @@
+package process
+
+import (
+ "github.com/shirou/gopsutil/process"
+ "github.com/spiral/errors"
+ "github.com/spiral/roadrunner/v2/pkg/worker"
+)
+
+// State provides information about specific worker.
+type State struct {
+ // Pid contains process id.
+ Pid int `json:"pid"`
+
+ // Status of the worker.
+ Status string `json:"status"`
+
+ // Number of worker executions.
+ NumJobs uint64 `json:"numExecs"`
+
+ // Created is unix nano timestamp of worker creation time.
+ Created int64 `json:"created"`
+
+ // MemoryUsage holds the information about worker memory usage in bytes.
+ // Values might vary for different operating systems and based on RSS.
+ MemoryUsage uint64 `json:"memoryUsage"`
+
+ CPUPercent float64
+}
+
+// WorkerProcessState creates new worker state definition.
+func WorkerProcessState(w worker.BaseProcess) (State, error) {
+ const op = errors.Op("worker_process_state")
+ p, _ := process.NewProcess(int32(w.Pid()))
+ i, err := p.MemoryInfo()
+ if err != nil {
+ return State{}, errors.E(op, err)
+ }
+
+ percent, err := p.CPUPercent()
+ if err != nil {
+ return State{}, err
+ }
+
+ return State{
+ CPUPercent: percent,
+ Pid: int(w.Pid()),
+ Status: w.State().String(),
+ NumJobs: w.State().NumExecs(),
+ Created: w.Created().UnixNano(),
+ MemoryUsage: i.RSS,
+ }, nil
+}
+
+func GeneralProcessState(pid int) (State, error) {
+ const op = errors.Op("process_state")
+ p, _ := process.NewProcess(int32(pid))
+ i, err := p.MemoryInfo()
+ if err != nil {
+ return State{}, errors.E(op, err)
+ }
+ percent, err := p.CPUPercent()
+ if err != nil {
+ return State{}, err
+ }
+
+ return State{
+ CPUPercent: percent,
+ Pid: pid,
+ MemoryUsage: i.RSS,
+ }, nil
+}