-
Notifications
You must be signed in to change notification settings - Fork 390
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
Cannot run cross
in Docker in Docker in WSL
#728
Comments
Ok I was probably wrong regarding expectations of finding root@c80df52385bc:/hello-world# cross build -v
+ "rustc" "--print" "sysroot"
+ "rustup" "toolchain" "list"
+ "rustup" "target" "list" "--toolchain" "stable-x86_64-unknown-linux-gnu"
+ "rustup" "component" "list" "--toolchain" "stable-x86_64-unknown-linux-gnu"
+ "rustup" "component" "add" "rust-src" "--toolchain" "stable-x86_64-unknown-linux-gnu"
info: downloading component 'rust-src'
info: installing component 'rust-src'
+ "/usr/bin/docker" "run" "--userns" "host" "-e" "PKG_CONFIG_ALLOW_CROSS=1" "--rm" "--user" "0:0" "-e" "XARGO_HOME=/xargo" "-e" "CARGO_HOME=/cargo" "-e" "CARGO_TARGET_DIR=/target" "-e" "USER=root" "-e" "CROSS_RUNNER=" "-v" "/var/lib/docker/overlay2/b738b0420860126166e5b690beed1707a5c188debf66652ae271860785047119/merged/root/.xargo:/xargo:Z" "-v" "/var/lib/docker/overlay2/b738b0420860126166e5b690beed1707a5c188debf66652ae271860785047119/merged/root/.cargo:/cargo:Z" "-v" "/cargo/bin" "-v" "/var/lib/docker/overlay2/b738b0420860126166e5b690beed1707a5c188debf66652ae271860785047119/merged/hello-world:/project:Z" "-v" "/var/lib/docker/overlay2/b738b0420860126166e5b690beed1707a5c188debf66652ae271860785047119/merged/root/.rustup/toolchains/stable-x86_64-unknown-linux-gnu:/rust:Z,ro" "-v" "/var/lib/docker/overlay2/b738b0420860126166e5b690beed1707a5c188debf66652ae271860785047119/merged/hello-world/target:/target:Z" "-w" "/project" "-i" "-t" "rustembedded/cross:x86_64-unknown-linux-gnu-0.2.1" "sh" "-c" "PATH=$PATH:/rust/bin cargo build -v"
Compiling hello-world v0.1.0 (/project)
Running `rustc --crate-name hello_world --edition=2021 src/main.rs --error-format=json --json=diagnostic-rendered-ansi,artifacts,future-incompat --crate-type bin --emit=dep-info,link -C embed-bitcode=no -C debuginfo=2 -C metadata=24ded0f759cf8b5b -C extra-filename=-24ded0f759cf8b5b --out-dir /target/debug/deps -C incremental=/target/debug/incremental -L dependency=/target/debug/deps`
Finished dev [unoptimized + debuginfo] target(s) in 0.41s stat /var/lib/docker/
stat: cannot stat '/var/lib/docker/': No such file or directory And also confirming that just running the following will work: docker run --rm -it \
-v "/var/lib/docker/overlay2/b738b0420860126166e5b690beed1707a5c188debf66652ae271860785047119/merged/root/.cargo:/cargo:Z" \
rustembedded/cross:x86_64-unknown-linux-gnu-0.2.1 stat /cargo/bin/cargo
File: '/cargo/bin/cargo'
Size: 15690192 Blocks: 30648 IO Block: 4096 regular file
Device: 2ch/44d Inode: 792675 Links: 12
Access: (0755/-rwxr-xr-x) Uid: ( 0/ root) Gid: ( 0/ root)
Access: 2022-05-30 15:09:20.657129255 +0000
Modify: 2022-05-30 15:09:01.355426167 +0000
Change: 2022-05-30 15:09:01.355426167 +0000
Birth: - So I guess I'll have to read up on the whole |
Ok so I read up a bit and the whole The The reason why this works on macOS, Linux and Windows but not WSL is because the $ cygpath.exe -w /var/run/docker.sock\;C/
C:\Program Files\git\var\run\docker.sock;C\ This is what I use when I from Windows run: -v //var/run/docker.sock:/var/run/docker.sock That is not the same as -v "/mnt/c/Program Files/git/var/run/docker.sock\;C/:/var/run/docker.sock" However I don't really know how to properly mount this socket properly given the magic going on with the appended Either way I don't think this is an issue with |
This is reproducing, but has some interesting quirks. I'll be commenting here and trying to debug. Current information:
Note how the |
Continuation of #260 (comment) and #260 (comment).
Description of the problem
Running
cross
from a Docker container (e.g. Docker in Docker) that runs in WSL does not work,it seems like the root cause is how Docker and volumes are created and mounted in WSL but this is so far just a guess.Running with
CROSS_DOCKER_IN_DOCKER=true
(which I should have to) will discover a volume path that is not mounted in the current container.Runing with
CROSS_DOCKER_IN_DOCKER=false
won't work because mounting a directory from a Docker container to another does not work afaik.Setup
cross
0.2.1cargo
1.61.0How to reproduce
Start build container that includes Docker
Install Rust and
cross
, create projectTry to build with cross
Quicker repro without
cross
Start DinD container and create file
Mount the
MergedDir
directoryThis will work on macOS and Linux but not WSL.
docker run --rm -it \ -v /var/run/docker.sock:/var/run/docker.sock \ -v $(docker inspect $HOSTNAME | jq -r .[0].GraphDriver.Data.MergedDir)/test:/workdir \ docker:latest cat /workdir/file.md
Troubleshooting root cause
Show more
UPDATE: This seems to be incorrect and irrelevant
I'm not very familiar with WSL and Docker but I noticed that if I start the container like in the first step from WSL, install
jq
and look at the same path as what the code found here does, I get:I guess this is not expected since the output from
cross build -v
refers to this directory for the whole toolchain:I would guess this has to do with how Docker Desktop and Rancher Desktop sets up data volumes separate from each other and separate from WSL:
wsl --list -v NAME STATE VERSION * Ubuntu-20.04 Running 2 rancher-desktop Running 2 rancher-desktop-data Running 2
The text was updated successfully, but these errors were encountered: