Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

-pass-fd does not allow specifying container descriptors 1 or 2 #11349

Closed
stepancheg opened this issue Jan 10, 2025 · 6 comments · Fixed by #11371
Closed

-pass-fd does not allow specifying container descriptors 1 or 2 #11349

stepancheg opened this issue Jan 10, 2025 · 6 comments · Fixed by #11371
Assignees
Labels
type: enhancement New feature or request

Comments

@stepancheg
Copy link

stepancheg commented Jan 10, 2025

Description

Open a file descriptor:

$ exec 9> ~/9
$ cat ~/9

(empty as expected)

Passing file descriptor 5, works correctly:

$ runsc exec -pass-fd 9:5 my-container-id sh -c 'echo test 5 >&5'
$ cat ~/9
test 5

Passing file descriptor 2: identical command, but 2 instead of 5:

$ runsc exec -pass-fd 9:2 my-container-id sh -c 'echo test 2 >&2'
test 2
$ cat ~/9
test 5

Stderr is forwarded to runsc stderr rather than into provided file descriptor.

Update: the last command is actually flaky: in about 1 in 20 invocations redirect actually happens.

Use case

Separate error messages from the runsc itself, and from the process inside the container. For example, one can be shown in UI, and another only sent to logs.

Is this feature related to a specific bug?

No response

Do you have a specific solution in mind?

Either:

  • make redirect of descriptors 1, 2 work, or
  • explicitly error early to make it clear to a user this is not meant to work
@stepancheg stepancheg added the type: enhancement New feature or request label Jan 10, 2025
@EtiennePerot
Copy link
Contributor

I believe runsc exec uses FD 1 and 2 from its own invocation. So runsc exec my-container-id sh -c 'echo test 2 >&2' 2>&9 would do the trick (although from my testing this is actually flaky...)
Is the bug suggesting that this behavior should be ignored when -pass-fd is specified for FDs 1 and 2?

@stepancheg
Copy link
Author

stepancheg commented Jan 10, 2025

Incorrect comment, deleted.

@stepancheg
Copy link
Author

although from my testing this is actually flaky

Flaky on my machine too.

But also I don't understand what is going on there. This command you posted is not supposed to print anything to stderr, because we have redirected the stderr of outer command to 9.

@stepancheg
Copy link
Author

It is even funnier. The command I mentioned initially

runsc exec -pass-fd 9:2 my-container-id sh -c 'echo test 2 >&2'

in about 1 in 20 invocations actually does redirect container stderr into the descriptor 9 (does not print into stderr, but output gets into the file).

@stepancheg
Copy link
Author

stepancheg commented Jan 10, 2025

The issue about non-determinism: #11350.

@stepancheg
Copy link
Author

I think this issue is a duplicate of #11350, because redirect -pass-fd 9:2 works properly if stdin is redirected as < /dev/null:

runsc exec -pass-fd 9:2 my-container-id sh -c 'echo test 3 >&2' < /dev/null

This command 100% of time redirects to a provided descriptor.

copybara-service bot pushed a commit that referenced this issue Jan 16, 2025
Previously we were only looking at stdin, which could be a pty but other stdio
fds might be redirected. In that case, we can incorrectly end up using the
stdin fd as *the* console fd, and sending all stdout/stderr to that FD,
ignoring the redirect.

Note that the behavior was actually flaky because the mechanism for choosing
which stdio fd to treat as *the* pty fd is non-deterministic, and so sometimes
we would choose the correct one.

This CL also cleans up `argsFromProcess` and `argsFromCLI`, which were setting
their `FilePayload` unnecessarily, since it is always set in `Execute`.

Fixes #11350
Fixes #11349

PiperOrigin-RevId: 716400006
copybara-service bot pushed a commit that referenced this issue Jan 17, 2025
Previously we were only looking at stdin, which could be a pty but other stdio
fds might be redirected. In that case, we can incorrectly end up using the
stdin fd as *the* console fd, and sending all stdout/stderr to that FD,
ignoring the redirect.

Note that the behavior was actually flaky because the mechanism for choosing
which stdio fd to treat as *the* pty fd is non-deterministic (due to the map
iteration in fdimport/fdimport.go:Import) and so sometimes we would choose
the correct one.

This CL also cleans up `argsFromProcess` and `argsFromCLI`, which were setting
their `FilePayload` unnecessarily, since it is always set in `Execute`.

Fixes #11350
Fixes #11349

PiperOrigin-RevId: 716400006
@nlacasse nlacasse self-assigned this Jan 17, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type: enhancement New feature or request
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants