-
Notifications
You must be signed in to change notification settings - Fork 3
/
c_ps.go
55 lines (51 loc) · 1.48 KB
/
c_ps.go
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
package commands
import (
"fmt"
"io/ioutil"
"os"
"text/tabwriter"
log "github.com/sirupsen/logrus"
"github.com/yourtion/ydocker/container"
)
func listContainers() {
// 找到存储容器信息的路径 /var/run/ydocker
dirURL := fmt.Sprintf(container.DefaultInfoLocation, "")
dirURL = dirURL[:len(dirURL)-1]
// 卖取该文件夹下的所有文件
files, err := ioutil.ReadDir(dirURL)
if err != nil {
log.Errorf("Read dir %s error %v", dirURL, err)
return
}
// 遍历该文件夹下的所有文件
var containers []*container.Info
for _, file := range files {
// 获取文件名
containerName := file.Name()
// 根据容器配置文件获取对应的信息,然后转换成容器信息的对象
tmpContainer, err := getContainerInfoByName(containerName)
if err != nil {
log.Errorf("Get container info error %v", err)
continue
}
containers = append(containers, tmpContainer)
}
// 使用 tabwriter.NewWriter 在控制台打印出容器信息(用于在控制台打印对齐的表格)
w := tabwriter.NewWriter(os.Stdout, 12, 1, 3, ' ', 0)
// 控制台输出的信息列
_, _ = fmt.Fprint(w, "ID\tNAME\tPID\tSTATUS\tCOMMAND\tCREATED\n")
for _, item := range containers {
_, _ = fmt.Fprintf(w, "%s\t%s\t%s\t%s\t%s\t%s\n",
item.Id,
item.Name,
item.Pid,
item.Status,
item.Command,
item.CreatedTime)
}
// 刷新标准输出流缓存区,将容器列表打印出来
if err := w.Flush(); err != nil {
log.Errorf("Flush error %v", err)
return
}
}