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 /app
eCMD ["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.call
não usa um shell para executar nossos comandos, portanto, não é possível executar comandos comocd
.Para usar um shell para executar seus comandos, use
shell=True
como 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)