Skip to content

Commit

Permalink
Merge pull request #1724 from knight42/feat/log-stream
Browse files Browse the repository at this point in the history
feat: retrieve specific log stream of a container
  • Loading branch information
k8s-ci-robot authored Dec 30, 2024
2 parents a30b670 + 7d81898 commit 9a6db87
Showing 1 changed file with 35 additions and 1 deletion.
36 changes: 35 additions & 1 deletion cmd/crictl/logs.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import (
"context"
"errors"
"fmt"
"io"
"os"
"strconv"
"strings"
Expand All @@ -35,6 +36,11 @@ import (
"k8s.io/klog/v2"
)

const (
streamStdout = "stdout"
streamStderr = "stderr"
)

var logsCommand = &cli.Command{
Name: "logs",
Usage: "Fetch the logs of a container",
Expand Down Expand Up @@ -75,6 +81,11 @@ var logsCommand = &cli.Command{
Aliases: []string{"t"},
Usage: "Show timestamps",
},
&cli.StringFlag{
Name: "stream",
Aliases: []string{"s"},
Usage: "Show specified stream (stdout or stderr). Defaults to both.",
},
},
Action: func(c *cli.Context) (retErr error) {
containerID := c.Args().First()
Expand Down Expand Up @@ -108,6 +119,17 @@ var logsCommand = &cli.Command{
}
timestamp := c.Bool("timestamps")
previous := c.Bool("previous")
stream := c.String("stream")

switch stream {
case streamStdout, streamStderr, "":
default:
return fmt.Errorf(`invalid stream %q, must be "stdout" or "stderr"`, stream)
}
if c.IsSet("tail") && c.IsSet("stream") {
return errors.New("--tail and --stream are mutually exclusive")
}

logOptions := logs.NewLogOptions(&v1.PodLogOptions{
Follow: c.Bool("follow"),
TailLines: &tailLines,
Expand Down Expand Up @@ -153,7 +175,19 @@ var logsCommand = &cli.Command{
cancelFn()
}()
logger := klog.Background()
return logs.ReadLogs(readLogCtx, &logger, logPath, status.GetStatus().GetId(), logOptions, runtimeService, os.Stdout, os.Stderr)

var (
stdoutStream io.Writer = os.Stdout
stderrStream io.Writer = os.Stderr
)
switch stream {
case streamStdout:
stderrStream = nil
case streamStderr:
stdoutStream = nil
}

return logs.ReadLogs(readLogCtx, &logger, logPath, status.GetStatus().GetId(), logOptions, runtimeService, stdoutStream, stderrStream)
},
}

Expand Down

0 comments on commit 9a6db87

Please sign in to comment.