This file is indexed.

/usr/share/gocode/src/gopkg.in/lxc/go-lxc.v2/examples/stats.go is in golang-gopkg-lxc-go-lxc.v2-dev 0.0~git20160405.0.85d46fc-0ubuntu2.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  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
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
// Copyright © 2013, 2014, The Go-LXC Authors. All rights reserved.
// Use of this source code is governed by a LGPLv2.1
// license that can be found in the LICENSE file.

// +build linux,cgo

package main

import (
	"flag"
	"log"

	"gopkg.in/lxc/go-lxc.v2"
)

var (
	lxcpath string
	name    string
)

func init() {
	flag.StringVar(&lxcpath, "lxcpath", lxc.DefaultConfigPath(), "Use specified container path")
	flag.StringVar(&name, "name", "rubik", "Name of the container")
	flag.Parse()
}

func main() {
	c, err := lxc.NewContainer(name, lxcpath)
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	}

	// mem
	memUsed, err := c.MemoryUsage()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	} else {
		log.Printf("MemoryUsage: %s\n", memUsed)
	}

	memLimit, err := c.MemoryLimit()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	} else {
		log.Printf("MemoryLimit: %s\n", memLimit)
	}

	// kmem
	kmemUsed, err := c.KernelMemoryUsage()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	} else {
		log.Printf("KernelMemoryUsage: %s\n", kmemUsed)
	}

	kmemLimit, err := c.KernelMemoryLimit()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	} else {
		log.Printf("KernelMemoryLimit: %s\n", kmemLimit)
	}

	// swap
	swapUsed, err := c.MemorySwapUsage()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	} else {
		log.Printf("MemorySwapUsage: %s\n", swapUsed)
	}

	swapLimit, err := c.MemorySwapLimit()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	} else {
		log.Printf("MemorySwapLimit: %s\n", swapLimit)
	}

	// blkio
	blkioUsage, err := c.BlkioUsage()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	} else {
		log.Printf("BlkioUsage: %s\n", blkioUsage)
	}

	cpuTime, err := c.CPUTime()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	}
	log.Printf("cpuacct.usage: %s\n", cpuTime)

	cpuTimePerCPU, err := c.CPUTimePerCPU()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	}
	log.Printf("cpuacct.usageerrpercpu: %v\n", cpuTimePerCPU)

	cpuStats, err := c.CPUStats()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	}
	log.Printf("cpuacct.stat: %v\n", cpuStats)

	interfaceStats, err := c.InterfaceStats()
	if err != nil {
		log.Fatalf("ERROR: %s\n", err.Error())
	}
	log.Printf("InterfaceStats: %v\n", interfaceStats)
}