launching adhoc docker instances: Is it recommended to launch a docker instance per request?
Is it recommended to launch a docker instance per request?
I have either lighttpd or Nginx running on my web server as a reverse proxy. I support a number of subdomains with very low usage. When a request for the subdomain arrives I want to start the docker instance. Preferable I’d like to launch them dynamically so that if more than one user arrives that I would launch one per user… and/or a shared instance (determined by configuration)
One Solution collect form web for “launching adhoc docker instances: Is it recommended to launch a docker instance per request?”
Originally I said this should work well for low traffic sites, but upon further thought, no, this is a bad idea.
Right now there is no automatic cleanup of the read-write layers — they persist even after the Docker container has exited. By default, nothing is lost.
So, even for a single low traffic site, you would find your disk use growing steadily over time. You could add your own automated cleanup.
Then there is the second problem: anything uploaded to the website would not be available to any other requests unless it was written to some out-of-container shared storage. That’s pretty easy to do with S3 or a separate and persistent database service, but it does start showing the weakness in the “one new Docker container per request” approach. If you’re going to have some persistent services, why not make the Docker containers more persistent and run them longer?