How To Efficiently Input Files With Docker
Solution 1:
Why are volume mounts not practical?
I would argue that Dockerising your application is not practical, but you've chosen to do so for, presumably very good, reasons. Volume mounts are simply an extension to this. If you want to get data in/out of your container, the 'normal' way to do this is by using volume mounts as you have done. Sure, you could use docker cp
to copy the files manually, but that's not really practical either.
As far as the process exiting goes, normally, once the main process exits, the container exits. docker ps -a
shows stopped containers as well as running ones. You should see that it says Exited n minutes(hours, days etc) ago
. This means that your container has run and exited, correctly. You can remove it with docker rm <containerid>
.
docker ps
(no -a
) will only show the running ones, btw.
If you use the --rm
flag in your Docker run command, it will be removed when it exits, so you won't see it in the ps -a
output. Stopped containers can be started again, but that's rather unusual.
Another solution might be to change your script to wait for incoming files and process them as they are received. Then you can leave the container running, and it will just process them as needed. If doing this, make sure that your idle loop has a sleep or something in it to ensure that you don't consume too many resources.
Solution 2:
I have a python code (let's call it process.py) that takes as an input a single .jpg image, does some operations on this image, and then output the processed .jpg image.
That's most efficiently done without Docker; just run the python
command you already have. If your application has interesting Python library dependencies, you can install them in a virtual environment to avoid conflicts with the system Python installation.
When I run the Docker image...
...the container runs its main command (docker run
command arguments, Dockerfile CMD
, possibly combined with an entrypoint from the some sources), and when that command exits, the container exits. It will be listed in docker ps -a
output, but as "Stopped" (probably with status 0 for a successful completion). You can docker run --rm
to have the container automatically delete itself.
Is there a more practical way of having a container running continuously and on which I can query to run the program process.py on demand with a given input ?
Wrap it in a network service, like a Flask application. As long as this is running, you can use a tool like curl
to do an HTTP POST with the input JPEG file as the body, and get the output JPEG file as the response. Avoid using local files and Docker together whenever that's an option (prefer network I/O for process inputs and outputs; prefer a database to local-file storage).
Post a Comment for "How To Efficiently Input Files With Docker"