aboutsummaryrefslogtreecommitdiff
path: root/src/main/scala/xyz/driver/core/stats.scala
blob: dbcf6e4ede8138b24eb316cda1569b68986e5e4e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
package xyz.driver.core

import java.io.File
import java.lang.management.ManagementFactory
import java.lang.reflect.Modifier

object stats {

  final case class MemoryStats(free: Long, total: Long, max: Long)

  final case class GarbageCollectorStats(totalGarbageCollections: Long, garbageCollectionTime: Long)

  final case class FileRootSpace(path: String, totalSpace: Long, freeSpace: Long, usableSpace: Long)

  object SystemStats {

    def memoryUsage: MemoryStats = {
      val runtime = Runtime.getRuntime
      MemoryStats(runtime.freeMemory, runtime.totalMemory, runtime.maxMemory)
    }

    def availableProcessors: Int = {
      Runtime.getRuntime.availableProcessors()
    }

    def garbageCollectorStats: GarbageCollectorStats = {
      import scala.collection.JavaConverters._

      val (totalGarbageCollections, garbageCollectionTime) =
        ManagementFactory.getGarbageCollectorMXBeans.asScala.foldLeft(0L -> 0L) {
          case ((total, collectionTime), gc) =>
            (total + math.max(0L, gc.getCollectionCount)) -> (collectionTime + math.max(0L, gc.getCollectionTime))
        }

      GarbageCollectorStats(totalGarbageCollections, garbageCollectionTime)
    }

    def fileSystemSpace: Array[FileRootSpace] = {
      File.listRoots() map { root =>
        FileRootSpace(root.getAbsolutePath, root.getTotalSpace, root.getFreeSpace, root.getUsableSpace)
      }
    }

    def operatingSystemStats: Map[String, String] = {
      val operatingSystemMXBean = ManagementFactory.getOperatingSystemMXBean
      operatingSystemMXBean.getClass.getDeclaredMethods
        .map(method => { method.setAccessible(true); method })
        .filter(method => method.getName.startsWith("get") && Modifier.isPublic(method.getModifiers))
        .map { method =>
          try {
            method.getName -> String.valueOf(method.invoke(operatingSystemMXBean))
          } catch {
            case t: Throwable => method.getName -> t.getMessage
        }
      } toMap
    }
  }
}