mirror of
https://github.com/vbatts/go-cgroup.git
synced 2025-01-18 19:50:08 +00:00
Merge pull request #1 from SjonHortensius/master
2 Bugfixes plus minor readability fix in main
This commit is contained in:
commit
4c1b10f991
2 changed files with 16 additions and 18 deletions
14
cg.go
14
cg.go
|
@ -21,7 +21,7 @@ Structure describing one or more control groups. The structure is opaque to
|
||||||
applications.
|
applications.
|
||||||
*/
|
*/
|
||||||
type Cgroup struct {
|
type Cgroup struct {
|
||||||
g *C.struct_group
|
g *C.struct_cgroup
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewCgroup(name string) Cgroup {
|
func NewCgroup(name string) Cgroup {
|
||||||
|
@ -482,12 +482,14 @@ func GetAllControllers() (controllers []ControllerData, err error) {
|
||||||
controllers = append(controllers, fromCControllerData(cd))
|
controllers = append(controllers, fromCControllerData(cd))
|
||||||
for {
|
for {
|
||||||
err = _err(C.cgroup_get_all_controller_next(&handle, &cd))
|
err = _err(C.cgroup_get_all_controller_next(&handle, &cd))
|
||||||
if err != nil && err != ECGEOF {
|
if err != nil {
|
||||||
|
if err == ECGEOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
return controllers, err
|
return controllers, err
|
||||||
}
|
} else {
|
||||||
controllers = append(controllers, fromCControllerData(cd))
|
controllers = append(controllers, fromCControllerData(cd))
|
||||||
if err == ECGEOF {
|
|
||||||
break
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return controllers, nil
|
return controllers, nil
|
||||||
|
|
20
main.go
20
main.go
|
@ -1,34 +1,30 @@
|
||||||
// cmpout
|
// cmpout
|
||||||
|
|
||||||
// +build ignore
|
// +build ignore
|
||||||
|
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"."
|
"."
|
||||||
"fmt"
|
"fmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
cgroup.Init()
|
cgroup.Init()
|
||||||
fmt.Println(cgroup.DeleteIgnoreMigration)
|
|
||||||
fmt.Println(cgroup.DeleteIgnoreMigration|cgroup.DeleteEmptyOnly)
|
|
||||||
|
|
||||||
g := cgroup.NewCgroup("foo")
|
g := cgroup.NewCgroup("foo")
|
||||||
c := g.AddController("bar")
|
c := g.AddController("bar")
|
||||||
fmt.Printf("%#v\n", c)
|
fmt.Printf("%#v\n", c)
|
||||||
c = g.GetController("bar")
|
c = g.GetController("bar")
|
||||||
fmt.Printf("%#v\n", c)
|
fmt.Printf("%#v\n", c)
|
||||||
|
|
||||||
g.SetPermissions(cgroup.Mode(0777), cgroup.Mode(0777), cgroup.Mode(0777))
|
g.SetPermissions(cgroup.Mode(0777), cgroup.Mode(0777), cgroup.Mode(0777))
|
||||||
|
|
||||||
//fmt.Println(cgroup.GetSubSysMountPoint("cpu"))
|
|
||||||
ctls, err := cgroup.GetAllControllers()
|
ctls, err := cgroup.GetAllControllers()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println(err)
|
fmt.Println(err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
for i := range ctls {
|
for i := range ctls {
|
||||||
fmt.Println(ctls[i])
|
fmt.Printf("Hierarchy=%d Enabled=%d NumCgroups=%d Name=%s\n", ctls[i].Hierarchy, ctls[i].Enabled, ctls[i].NumCgroups, ctls[i].Name)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue