Skip to content

Commit

Permalink
feat: export metrics related to new limits
Browse files Browse the repository at this point in the history
  • Loading branch information
smlx committed Oct 15, 2024
1 parent 7a3fa0c commit 2f7b64c
Showing 1 changed file with 14 additions and 0 deletions.
14 changes: 14 additions & 0 deletions internal/sshserver/sessionhandler.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,14 @@ var (
Name: "sshportal_sessions_total",
Help: "The total number of ssh-portal sessions started",
})
execSessions = promauto.NewGauge(prometheus.GaugeOpts{
Name: "sshportal_exec_sessions",
Help: "Current number of ssh-portal exec sessions",
})
logsSessions = promauto.NewGauge(prometheus.GaugeOpts{
Name: "sshportal_logs_sessions",
Help: "Current number of ssh-portal logs sessions",
})
)

// authCtxValues extracts the context values set by the authhandler.
Expand Down Expand Up @@ -246,6 +254,9 @@ func startClientKeepalive(ctx context.Context, cancel context.CancelFunc,

func doLogs(ctx ssh.Context, log *slog.Logger, s ssh.Session, deployment,
container string, follow bool, tailLines int64, c K8SAPIService) {
// update metrics
logsSessions.Inc()
defer logsSessions.Dec()
// Wrap the ssh.Context so we can cancel goroutines started from this
// function without affecting the SSH session.
childCtx, cancel := context.WithCancel(ctx)
Expand Down Expand Up @@ -280,6 +291,9 @@ func doLogs(ctx ssh.Context, log *slog.Logger, s ssh.Session, deployment,
func doExec(ctx ssh.Context, log *slog.Logger, s ssh.Session, deployment,
container string, cmd []string, c K8SAPIService, pty bool,
winch <-chan ssh.Window) {
// update metrics
execSessions.Inc()
defer execSessions.Dec()
err := c.Exec(ctx, s.User(), deployment, container, cmd, s,
s.Stderr(), pty, winch)
if err != nil {
Expand Down

0 comments on commit 2f7b64c

Please sign in to comment.