Skip to content

Commit

Permalink
Merge pull request #912 from dcantah/improve-shimdiag
Browse files Browse the repository at this point in the history
Add shimdiag flag to find shim process ID for shims
  • Loading branch information
dcantah authored Jan 20, 2021
2 parents 3d95010 + e6272de commit 99c7fb3
Show file tree
Hide file tree
Showing 5 changed files with 421 additions and 34 deletions.
16 changes: 16 additions & 0 deletions cmd/containerd-shim-runhcs-v1/service.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package main

import (
"context"
"os"
"runtime"
"strings"
"sync"
Expand Down Expand Up @@ -474,3 +475,18 @@ func (s *service) DiagStacks(ctx context.Context, req *shimdiag.StacksRequest) (
}
return resp, nil
}

func (s *service) DiagPid(ctx context.Context, req *shimdiag.PidRequest) (*shimdiag.PidResponse, error) {
if s == nil {
return nil, nil
}
defer panicRecover()
ctx, span := trace.StartSpan(ctx, "DiagPid")
defer span.End()

span.AddAttributes(trace.StringAttribute("tid", s.tid))

return &shimdiag.PidResponse{
Pid: int32(os.Getpid()),
}, nil
}
30 changes: 28 additions & 2 deletions cmd/shimdiag/list.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@ package main

import (
"fmt"
"os"
"text/tabwriter"

"github.com/Microsoft/hcsshim/internal/appargs"
"github.com/urfave/cli"
Expand All @@ -11,15 +13,39 @@ var listCommand = cli.Command{
Name: "list",
Usage: "Lists running shims",
ArgsUsage: " ",
Before: appargs.Validate(),
Flags: []cli.Flag{
cli.BoolFlag{
Name: "pids",
Usage: "Shows the process IDs of each shim",
},
},
Before: appargs.Validate(),
Action: func(ctx *cli.Context) error {
pids := ctx.Bool("pids")
shims, err := findShims("")
if err != nil {
return err
}

w := new(tabwriter.Writer)
w.Init(os.Stdout, 0, 8, 0, '\t', 0)

if pids {
fmt.Fprintln(w, "Shim \t Pid")
}

for _, shim := range shims {
fmt.Println(shim)
if pids {
pid, err := getPid(shim)
if err != nil {
return err
}
fmt.Fprintf(w, "%s \t %d\n", shim, pid)
} else {
fmt.Fprintln(w, shim)
}
}
w.Flush()
return nil
},
}
17 changes: 17 additions & 0 deletions cmd/shimdiag/shimdiag.go
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
package main

import (
"context"
"fmt"
"os"
"path/filepath"
"sort"
"strings"

"github.com/Microsoft/go-winio"
"github.com/Microsoft/hcsshim/internal/shimdiag"
"github.com/containerd/ttrpc"
"github.com/urfave/cli"
"golang.org/x/sys/windows"
Expand Down Expand Up @@ -102,3 +104,18 @@ func getShim(name string) (*ttrpc.Client, error) {
}
return ttrpc.NewClient(conn), nil
}

func getPid(shimName string) (int32, error) {
shim, err := getShim(shimName)
if err != nil {
return 0, err
}
defer shim.Close()

svc := shimdiag.NewShimDiagClient(shim)
resp, err := svc.DiagPid(context.Background(), &shimdiag.PidRequest{})
if err != nil {
return 0, err
}
return resp.Pid, nil
}
Loading

0 comments on commit 99c7fb3

Please sign in to comment.