Erro do Docker Toolbox “não é possível abrir o arquivo”

Erro do Docker Toolbox “não é possível abrir o arquivo”

Tenho lutado para colocar uma imagem do Docker em funcionamento no Windows 10 Home, usando o Docker Toolbox. Aqui está o erro que vejo no Kitematic:

python: can't open file 'src/__main__.py': [Errno 2]   
No such file or directory

Este comando Python que está falhando é o ponto de entrada para o contêiner Docker de 'notas'.

Após Docker/up.sh o processo termina sem erros.

Successfully built f59c275721cf
Successfully tagged docker_mysql:latest
Creating mysql ... done
Creating notes ... done

Além disso, este é um projeto de grupo no qual outros usuários de Macs não conseguem duplicar esse erro. Depois de atualizar o Dockerfile abaixo e executar:

Successfully built 42a95cd419f2
Successfully tagged docker_mysql:latest
Creating mysql ... done
Creating notes ... done

User@DESKTOP-EBUI9GE MINGW64 /c/users/user/Desktop/6440/Procedure-Notes-Application (master)
$ docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                     NAMES
68f60fdba6f5        docker_mysql        "docker-entrypoint.s…"   15 seconds ago      Up 9 seconds        0.0.0.0:23306->3306/tcp   mysql

User@DESKTOP-EBUI9GE MINGW64 /c/users/user/Desktop/6440/Procedure-Notes-Application (master)
$ docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                      PORTS                     NAMES
e7fbd5b73189        docker_notes        "python /app/src/__m…"   23 seconds ago      Exited (2) 17 seconds ago                             notes
68f60fdba6f5        docker_mysql        "docker-entrypoint.s…"   23 seconds ago      Up 17 seconds               0.0.0.0:23306->3306/tcp   mysql

Dockerfile atualizado:

### Use an official Python runtime as a parent image 
FROM python:2.7-slim

### set working directory to the code location
WORKDIR /app

### copy the code base over (redone by the compose file)
COPY . .

### Install any needed packages specified in requirements.txt
RUN pip install --trusted-host pypi.python.org -r requirements.txt

### Make port available to the world outside this container
EXPOSE 5000

### start the application
CMD ["python", "/app/src/__main__.py"]

Agora estou recebendo outro erro:

 * Serving Flask app "__main__" (lazy loading)
 * Environment: production
   WARNING: Do not use the development server in a production environment.
   Use a production WSGI server instead.
 * Debug mode: on
 * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
 * Restarting with stat
Traceback (most recent call last):
  File "/app/src/__main__.py", line 57, in <module>
    app.run(debug=True, host='0.0.0.0')
  File "/usr/local/lib/python2.7/site-packages/flask/app.py", line 943, in run
    run_simple(host, port, self, **options)
  File "/usr/local/lib/python2.7/site-packages/werkzeug/serving.py", line 988, in run_simple
    run_with_reloader(inner, extra_files, reloader_interval, reloader_type)
  File "/usr/local/lib/python2.7/site-packages/werkzeug/_reloader.py", line 332, in run_with_reloader
    sys.exit(reloader.restart_with_reloader())
  File "/usr/local/lib/python2.7/site-packages/werkzeug/_reloader.py", line 176, in restart_with_reloader
    exit_code = subprocess.call(args, env=new_environ, close_fds=False)
  File "/usr/local/lib/python2.7/subprocess.py", line 172, in call
    return Popen(*popenargs, **kwargs).wait()
  File "/usr/local/lib/python2.7/subprocess.py", line 394, in __init__
    errread, errwrite)
  File "/usr/local/lib/python2.7/subprocess.py", line 1047, in _execute_child
    raise child_exception
OSError: [Errno 8] Exec format error

Responder1

Minha primeira observação, que deu início ao processo, foi:

Você não precisa do mkdir, pois o WORKDIR irá criá-lo. Também é melhor usar referências absolutas, como WORKDIR /appe CMD ["python", "/app/src/__main__.py"].

O script Python agora inicia e interrompe o erro:

  File "/usr/local/lib/python2.7/subprocess.py", line 1047, in _execute_child
    raise child_exception

Normalmente, isso é um erro no script Python. Uma possibilidade está descrita no post python subprocess.call() não funciona como esperado:

Por padrão, subprocess.callnão usa um shell para executar nossos comandos, portanto, não é possível executar comandos como cd.

Para usar um shell para executar seus comandos, use shell=Truecomo parâmetro. Nesse caso é recomendado passar seus comandos como uma única string ao invés de uma lista. E como é executado por um shell, você ~/também pode usar no seu caminho:

subprocess.call("(cd ~/catkin_ws/src && catkin_make)", shell=True)

informação relacionada