Home > Backend Development > Golang > Why can't the file be found after copying it to the container?

Why can't the file be found after copying it to the container?

王林
Release: 2024-02-09 08:24:10
forward
643 people have browsed it

Why cant the file be found after copying it to the container?

php Xiaobian Yuzai may encounter a common problem when using container technology: files cannot be found after they are copied to the container. This problem usually occurs when using containerization platforms such as Docker. The reason may be that the file path is set incorrectly, or the file system inside the container is inconsistent with the host. There are many ways to solve this problem, such as using an absolute path or copying the file into the container through a shared folder. Before solving this problem, we need to first understand the mapping relationship between the container's file system and file path, and how to correctly configure the file path.

Question content

I have a dockerfile as shown below:

from golang:1.19 as builder
workdir /app
copy . .
run cgo_enabled=0 go build -v -o "hello-bin"


#from scratch
from alpine
copy --from=builder /app/hello-bin /app/hello-bin
copy --from=builder /app/start.sh /app/start.sh
workdir /app
entrypoint  [ "./start.sh" ]
Copy after login

It just builds a binary from the hello-world go file. However, when I try to run this container with the following docker-compose settings, it says exec ./start.sh: no such file or directory.

version: "3"

services:
  hello:
    restart: always
    build:
      context: .
      dockerfile: dockerfile
Copy after login

The directory structure is

❯ tree .
.
├── dockerfile
├── docker-compose.yaml
├── go.mod
├── hello
├── init.go
└── start.sh
Copy after login

Therefore start.sh should be loaded into the builder<code> container via copy. The same goes for the . line, which should be passed to the second container via copy --from=builder /app/start.sh /app/start.sh.

Context, the contents of start.sh are as follows:

#!/bin/bash

_main() {
  echo "start"
}

_main "$@"
Copy after login

The part that confuses me the most is that if I change it in the dockerfile to cmd [ "ls", "-l" ] it will actually print out

awesomeproject3-hello-1  | -rwxr-xr-x    1 root     root       1819562 May 19 02:41 hello-bin
awesomeproject3-hello-1  | -rwxrwxrwx    1 root     root            51 May 19 02:39 start.sh
Copy after login

If I change it to entrypoint [ './hello-bin' ] in the dockerfile, the binary also runs successfully. I just don't understand why it says there is no ./start.sh.

Update: Inspired by @larsks, I noticed that if I change the header of ./start.sh from #!/bin/bash to # !/bin/sh and it will work magically. I'm still confused what is the underlying issue here, how should I fix the docker file if I want to keep the bash headers?

Solution

The error occurs because you used #!/bin/bash in start.sh.

The Alpine docker image does not have bash installed by default. It uses the Busybox shell instead.

You can install bash in a container. See Docker: How to use bash with Alpine based docker image?

Or you can change #!/bin/bash to #!/bin/sh as mentioned in your question comments.

The above is the detailed content of Why can't the file be found after copying it to the container?. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:stackoverflow.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template