class ElasticAPM::Metrics::JVMSet

@api private

def collect

def collect
  read!
  super
end

def initialize(*args)

def initialize(*args)
  super
  @error_count = 0
end

def platform_bean

def platform_bean
  @platform_bean ||= java.lang.management.ManagementFactory.getPlatformMXBean(
    java.lang.management.MemoryMXBean.java_class
  )
end

def pool_beans

def pool_beans
  @pool_beans ||= java.lang.management.ManagementFactory.getMemoryPoolMXBeans()
end

def read!

def read!
  return if disabled?
  heap = platform_bean.get_heap_memory_usage
  non_heap = platform_bean.get_non_heap_memory_usage
  gauge(:"jvm.memory.heap.used").value = heap.get_used
  gauge(:"jvm.memory.heap.committed").value = heap.get_committed
  gauge(:"jvm.memory.heap.max").value = heap.get_max
  gauge(:"jvm.memory.non_heap.used").value = non_heap.get_used
  gauge(:"jvm.memory.non_heap.committed").value = non_heap.get_committed
  gauge(:"jvm.memory.non_heap.max").value = non_heap.get_max
  pool_beans.each do |bean|
    next unless bean.type.name == "HEAP"
    tags = { name: bean.get_name }
    gauge(:"jvm.memory.heap.pool.used", tags: tags).value = bean.get_usage.get_used
    gauge(:"jvm.memory.heap.pool.committed", tags: tags).value = bean.get_usage.get_committed
    gauge(:"jvm.memory.heap.pool.max", tags: tags).value = bean.get_usage.get_max
  end
rescue Exception => e
  error("JVM metrics encountered error: %s", e)
  debug("Backtrace:") { e.backtrace.join("\n") }
  @error_count += 1
  if @error_count >= MAX_TRIES
    disable!
    error("Disabling JVM metrics after #{MAX_TRIES} errors", e)
  end
end