usage

package
v0.0.0-...-23e6066 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 3, 2018 License: Apache-2.0 Imports: 9 Imported by: 0

Documentation

Overview

Package usage provides representations of resource usage.

Index

Constants

This section is empty.

Variables

View Source
var IncrementalMappedAccounting = false

IncrementalMappedAccounting controls whether host mapped memory is accounted incrementally during map translation. This may be modified during early initialization, and is read-only afterward.

View Source
var MemoryAccounting = newMemoryLocked()

MemoryAccounting is the global memory stats.

There is no need to save or restore the global memory accounting object, because individual frame kinds are saved and charged only when they become resident.

View Source
var MinimumTotalMemoryBytes uint64 = 2 << 30 // 2 GB

MinimumTotalMemoryBytes is the minimum reported total system memory.

View Source
var RTMemoryStatsSize = unsafe.Sizeof(RTMemoryStats{})

RTMemoryStatsSize is the size of the RTMemoryStats struct.

Functions

func TotalMemory

func TotalMemory(memSize, used uint64) uint64

TotalMemory returns the "total usable memory" available.

This number doesn't really have a true value so it's based on the following inputs and further bounded to be above some minimum guaranteed value (2GB), additionally ensuring that total memory reported is always less than used.

memSize should be the platform.Memory size reported by platform.Memory.TotalSize() used is the total memory reported by MemoryLocked.Total()

Types

type CPUStats

type CPUStats struct {
	// UserTime is the amount of time spent executing application code.
	UserTime time.Duration

	// SysTime is the amount of time spent executing sentry code.
	SysTime time.Duration

	// VoluntarySwitches is the number of times control has been voluntarily
	// ceded due to blocking, etc.
	VoluntarySwitches uint64
}

CPUStats contains the subset of struct rusage fields that relate to CPU scheduling.

func (*CPUStats) Accumulate

func (s *CPUStats) Accumulate(s2 CPUStats)

Accumulate adds s2 to s.

type IO

type IO struct {
	// CharsRead is the number of bytes read by read syscalls.
	CharsRead uint64

	// CharsWritten is the number of bytes written by write syscalls.
	CharsWritten uint64

	// ReadSyscalls is the number of read syscalls.
	ReadSyscalls uint64

	// WriteSyscalls is the number of write syscalls.
	WriteSyscalls uint64

	// BytesRead is the number of bytes actually read into pagecache.
	BytesRead uint64

	// BytesWritten is the number of bytes actually written from pagecache.
	BytesWritten uint64

	// BytesWriteCancelled is the number of bytes not written out due to
	// truncation.
	BytesWriteCancelled uint64
}

IO contains I/O-related statistics.

func (*IO) AccountReadIO

func (i *IO) AccountReadIO(bytes int64)

AccountReadIO does the accounting for a read IO into the file system.

func (*IO) AccountReadSyscall

func (i *IO) AccountReadSyscall(bytes int64)

AccountReadSyscall does the accounting for a read syscall.

func (*IO) AccountWriteIO

func (i *IO) AccountWriteIO(bytes int64)

AccountWriteIO does the accounting for a write IO into the file system.

func (*IO) AccountWriteSyscall

func (i *IO) AccountWriteSyscall(bytes int64)

AccountWriteSyscall does the accounting for a write syscall.

func (*IO) Accumulate

func (i *IO) Accumulate(io *IO)

Accumulate adds up io usages.

type MemoryKind

type MemoryKind int

MemoryKind represents a type of memory used by the application.

For efficiency reasons, it is assumed that the Memory implementation is responsible for specific stats (documented below), and those may be reported in aggregate independently. See the platform.Memory interface as well as the control.Usage.Collect method for more information.

const (
	// System represents miscellaneous system memory. This may include
	// memory that is in the process of being reclaimed, system caches,
	// page tables, swap, etc.
	//
	// This memory kind is backed by platform memory.
	System MemoryKind = iota

	// Anonymous represents anonymous application memory.
	//
	// This memory kind is backed by platform memory.
	Anonymous

	// PageCache represents memory allocated to back sandbox-visible files that
	// do not have a local fd. The contents of these files are buffered in
	// memory to support application mmaps.
	//
	// This memory kind is backed by platform memory.
	PageCache

	// Tmpfs represents memory used by the sandbox-visible tmpfs.
	//
	// This memory kind is backed by platform memory.
	Tmpfs

	// Ramdiskfs represents memory used by the ramdiskfs.
	//
	// This memory kind is backed by platform memory.
	Ramdiskfs

	// Mapped represents memory related to files which have a local fd on the
	// host, and thus can be directly mapped. Typically these are files backed
	// by gofers with donated-fd support. Note that this value may not track the
	// exact amount of memory used by mapping on the host, because we don't have
	// any visibility into the host kernel memory management. In particular,
	// once we map some part of a host file, the host kernel is free to
	// abitrarily populate/decommit the pages, which it may do for various
	// reasons (ex. host memory reclaim, NUMA balancing).
	//
	// This memory kind is backed by the host pagecache, via host mmaps.
	Mapped
)

type MemoryLocked

type MemoryLocked struct {

	// MemoryStats records the memory stats.
	MemoryStats
	// RTMemoryStats records the memory stats that need to be exposed through
	// shared page.
	*RTMemoryStats
	// File is the backing file storing the memory stats.
	File *os.File
	// contains filtered or unexported fields
}

MemoryLocked is Memory with access methods.

func (*MemoryLocked) Copy

func (m *MemoryLocked) Copy() (MemoryStats, uint64)

Copy returns a copy of the structure with a total.

This method is thread-safe.

func (*MemoryLocked) Dec

func (m *MemoryLocked) Dec(val uint64, kind MemoryKind)

Dec remove a usage of 'val' bytes from memory category 'kind'.

This method is thread-safe.

func (*MemoryLocked) Inc

func (m *MemoryLocked) Inc(val uint64, kind MemoryKind)

Inc adds an additional usage of 'val' bytes to memory category 'kind'.

This method is thread-safe.

func (*MemoryLocked) Move

func (m *MemoryLocked) Move(val uint64, to MemoryKind, from MemoryKind)

Move moves a usage of 'val' bytes from 'from' to 'to'.

This method is thread-safe.

func (*MemoryLocked) Total

func (m *MemoryLocked) Total() uint64

Total returns a total memory usage.

This method is thread-safe.

type MemoryStats

type MemoryStats struct {
	System    uint64
	Anonymous uint64
	PageCache uint64
	Tmpfs     uint64
	// Lazily updated based on the value in RTMapped.
	Mapped    uint64
	Ramdiskfs uint64
}

MemoryStats tracks application memory usage in bytes. All fields correspond to the memory category with the same name. This object is thread-safe if accessed through the provided methods. The public fields may be safely accessed directly on a copy of the object obtained from Memory.Copy().

type RTMemoryStats

type RTMemoryStats struct {
	RTMapped uint64
}

RTMemoryStats contains the memory usage values that need to be directly exposed through a shared memory file for real-time access. These are categories not backed by platform memory. For details about how this works, see the memory accounting docs.

N.B. Please keep the struct in sync with the API. Noteably, changes to this struct requires a version bump and addition of compatibility logic in the control server. As a special-case, adding fields without re-ordering existing ones do not require a version bump because the mapped page we use is initially zeroed. Any added field will be ignored by an older API and will be zero if read by a newer API.

func RTMemoryStatsPointer

func RTMemoryStatsPointer(b []byte) *RTMemoryStats

RTMemoryStatsPointer casts the address of the byte slice into a RTMemoryStats pointer.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL