-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Building a Wordpress production image with a custom theme. #567
Comments
What about bind-mounting the An approach to using a directory that's not a Other discussions on removing inherent volumes in images docker-library/mongo#306, redis/docker-library-redis#140, docker-library/postgres#404 |
With #557, you can theoretically run completely stateless as long as you've got the appropriate environment variables and don't try to add anything that goes into |
Thanks for all the feedback and suggestions, however the question as to why this 'VOLUME' directive is there in the first place is still unclear to me? Running with a bind mounted directory, you don't use the volume. Running a production image, you have the data copied in /usr/src/wordpress, which is copied to /var/www/html on init - to me it seems, at this point the VOLUME is just in the way. If someone still wants to mount something on /var/www/html, they can do it; you don't need to VOLUME directive for that. The only thing the VOLUME directive does is: In case of b, if you want to persist, you can mount a volume regardless. If you don't mount a volume, you'll end up with an unnamed volume (exactly my problem), for which I can not come up with a use case. |
The volume is the only reliable way to let users know where the mutable state is stored. WordPress was not designed for containers and, as such, considers all of its installation mutable state (and applies security updates automatically). So we designed the WordPress image to reflect that; the initial start will fill the volume (whether a bind-mount or named/unnamed docker volume) with the install and WordPress would then take care of updates. You can even update the container around WordPress to get newer PHP without it effecting the WordPress install. In the early days of docker, volumes did not exist without a contianer and so tools like |
I understand, however if the only reason is to point out where the "mutable state" is, is it worth the problems it introduces? As I described in my (which I think are the common use-cases) use-cases:
If you do not mount a volume on /var/www/html, an unnamed volume will be mounted on it by Docker - which results in pollution. In case of a named volume, the volume is useless - since when you add the data to /usr/src/wordpress, it's copied to /var/www/html (your volume), meaning any new versions of your extended image (changes to themes etc.) are not copied to /var/www/html anymore. So, what's a real use-case for wanting to persist /var/www/html, considering that it will be populated by the content of /usr/src/wordpress when it's empty? Can we add a separate folder, let's say /usr/src/wordpress/themes or /themes (and plugins) that is always copied to /var/www/html upon startup to the default image? I can easily add this in my image, but I think this might benefit others as well. |
@darkl0rd do you mind sharing your custom Dockerfile with the script that copies data from /usr/src/wordpress to /var/www/html on startup? Thanks in advance |
Dockerfile
docker-entrypoint-override.sh
|
I have one questions to you. Isn't one big (or the) feature of "using docker for a WordPress project" to reflect tested changes in code (new features) directly in a production website (live)?
But if the updated theme file does not get copied anymore ... whats the point of using docker? Just for having a WordPress with an initial theme-setting running in a container? Or am I missing something? @wglambert you asked "What about bind-mounting the /var/www/html/wp-content/themes/ folder?" Yes, I could do that, but how do I get my theme code into there? I need to |
@ILCAI I am not sure whether your question was directed at me? In case it was - this is exactly what I am requesting and achieving with my customisations as I see no way to do exactly that with the 'stock' image (see my earlier post and script customisations) - now it's of course entirely possible I'm not using the image correctly or missing something, which is why I raised this question. If I am, please enlighten me, because I would prefer using the community provided image rather than having to roll my own. Developers mount /var/www/html/wp-content. The question I had, at least with my workflow, is what's the use-case for the VOLUME instruction in the Dockerfile? If you bind mount a directory on '/var/www/html/wp-content' it's not used (you can mount anything on everything regardless of a VOLUME instruction). The only thing the VOLUME instruction here does is create a unnamed docker volume when you do not pass in a volume mapping - which is actually annoying in the case where you build production images which have their content copied into them (as each deployment will result in a new unnamed volume). |
I am currently attempting to promote my image including custom theme to Production using a custom Dockerfile, like so:
The resulting image will have the wp-content directory in the "distribution" directory, which is copied to /var/www/html on initialisation when the right conditions are met.
The right conditions being that the following files do not exist in /var/www/html:
The first time, this works as expected as the target volume mounted on /var/www/html will be empty still. However, any subsequent updates will detect that /var/www/html has content in it and therefore initialisation will be skipped. With it, any changes made to my custom theme are not applied.
The simplest solution would be to not map a volume on /var/www/html, so that initialisation takes place every time - as each startup would effectively end up with an empty directory. However, the downside of this is that I end up with tons of dangling volumes, as the provided Wordpress image has a VOLUME directive set for this directory, which results in Docker creating an unnamed Volume to map on the directory. This is the approach I'm currently taking, together with a cleanup script running on the hosts to remove the volumes.
This is obviously less than ideal. Why is /var/www/html a Volume in the first place? Considering that in a local development environment the necessary content is bind mounted and in a production image the data is copied to /usr/src/wordpress.
The text was updated successfully, but these errors were encountered: