-
Notifications
You must be signed in to change notification settings - Fork 472
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
Consolidate to fewer templates #299
Comments
Hi BryanQuigley, we don't have a clear roadmap yet ..
As I understand - the project has some constraints: 1.) The project ~ have to use the upstream (
2.) The Debian postgis packaged versions is very limited ; so no postgis 3.0 , 3.1 ( 3.3 ) package for debians
3.) Long time support for the current users ( ~ debian based images , and if it is easy )
4.) The project's current https://github.com/postgis/docker-postgis/blob/master/update.sh scripts have some limitations
Workarounds for 4.)
now my recommended images based on my: #295 Debian based:
not easy to create more variations - with supported base images. Alpine based: ( now in 3.15 .. )
Test images ( planned )
My opinion:
And Later we can add multiple alpine images:
etc ..
I do not fully understand your proposal, can you give me a simple example? honestly I prefer recommendations that are compatible with the upstream (
and the upstream repo is pre-generating Dockerfiles
it has a very long build time ( X86-64 ~ 30-40 min ) so without a strong hardware CI support - I don't recommend in the first iteration. |
Thanks for the detailed response! 2.) Understood. Postgis 3.1 is packaged with Postgres 13 in the stock Debian repos, but that might be to divergent to try using. jq templating seems similar - but maybe better than what I was proposing.. Will investigate it more. Happy to help however I can be useful - if that's the jq bit, sure :). |
In the limited time I've had to think about some of these things, I thought that maybe it could be helpful to start working on a newer build framework in parallel to the one that exists now. The limitations we've had thus far have been constraining things for too long. The constraints have been accepted/tolerated mostly to prevent breaking compatibility for the existing user base. Maybe a new framework could be established in parallel to develop/modernize things? Traditionally we modeled things after the docker-library postgresql repo in hopes of some day becoming the definitive top-level postgis image, but the postgresql repo has since evolved to use jq to parse richer build metadata for configurations. Maybe a separate branch needs to be created and development started on an updated framework? Github actions supports multiple workflow configurations. We could start development to modernize things without breaking compatibility for existing users, pushing images to dockerhub with different tag naming schemes, and making them available for the community to test with? |
It looks like the jq parser in postgres may be refactored once stretch is EOL (end of this month), will approach doing something then. I think it should be quite possible to refactor and maintain the existing images (once stretch is gone). |
I was wondering if there was any interest in generating more of the Docker files from templates at build time? This could make it easier to update, add more archs, or support more versions of PostGIS.
(we were doing something similar here.)
Designing this does somewhat require a better understanding of how many different variations to build/support at a time. This might overlap with @ImreSamu WIP PR where a recommended versions is specified - I really like the idea of a recommended version.
As I see the overall variants right now:
OSes: Alpine (1 version at a time). Debian (maybe more than one, right now we have stretch - very unsupported {maybe drop} to support postgis 2.5 and bullseye/stable)
Postgres: Clearly says all supported versions, could see the argument for dropping the oldest supported one
PostGIS: 3 versions (2.5, 3.2 and master), but it might be helpful to be able to support 3.1/3.3 as well
Archs: amd64 (but interest in more)
We could support newer releases with more options - like only arm for 14-3.2, or 14-master.
What would the ideal matrix of variants look like?
The text was updated successfully, but these errors were encountered: