-
-
Notifications
You must be signed in to change notification settings - Fork 25
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
Create docker.yml workflow for automated image building #19
Conversation
The docker action run seems to fail. |
The issue came from your repo's owner's username. I did some testing on another account that resembles your username pattern It's an oversight by the creators of the Here is the fix #24 |
Thanks for the fix. I'll merge it. |
Do I understand it correctly that this workflow builds the docker image for the server and uploads it to a repository so that it can be downloaded for each platform? If so, is |
This workflow builds and pushes images to GitHub's own Image Repository, opposed to Docker Hub. I though it would be less hassle for you this way because it takes the credentials from your own account (or organisation in this case). You can find your images here: https://github.com/orgs/Librum-Reader/packages. The job logs indicate that the build and push were successful but I can't see them. Can you check yourself and confirm? Maybe they are not publicly accessible. |
To answer you initial question, once the packages are public, people will be able to pull them via The docker-compose.yml in this repo must be updated with Notice the lowercase in the |
I have changed the package visibility to public. |
To ensure that all of the changes are correct, would you mind creating a PR with the |
Great! I'm really happy because this is my first time doing this workflow-ghcr-organisation combo. I'll PR the changes in a moment. I'm adding a heartbeat dependency in the docker-compose. To start the server after the database. I noticed it trips a lot of people into thinking the server isn't working for the wrong reasons. |
Did you figure out the database issue? I had not touched it. Just the startup order. |
I haven't found a solution yet, but I'm on it. In the meanwhile I'd like to understand the whole docker process since I don't have much docker experience. From what I understand:
Do I understand it correctly? |
Regarding the docker.yml, it does pretty much what you described. It takes the load off the end user to build+push the image to a public registry. It also ensures the environment has all the necessary dependencies and also pre-generates all the tags and labels, depending on the matrix, specified in the beginning of the workflow. Regarding docker container lifecycle, It depends. If the definition of the container in the docker-compose has changed, Docker will recreate the container with the necessary changes. In turn, any data in the container that is not persistent (as bind mount or volume) will be lost. But this will only happen if the definition changed. The database did not change so the most it will experience is a restart. When people update the stack via docker, they will probably delete the librum server container, delete the old image and redeploy the stack. Docker will try to find a local image but fail and then it will look in the public registry, eventually pulling the updated version. The database container could be left running during all of this. It can also be deleted and once the stack is redeployed, it will run just like before because the conditions are the same and its data is persistent in a docker volume called Now, you have the same db and an updated server. I guess it should check and skip database initialization or whatever it does on initial setup because the database setup was carried over. I don't know what other updates are carried by the server on the database. I hope I'm making sense. I'm not an expert. |
I'm trying to eliminate friction points for people that want to try selfhosting Librum.
This is a basic workflow that builds a
librum-server
image and offers tags such as:latest
.The image is pushed to
ghcr.io
. No extra credentials needed, the package becomes a part of the repo.The
docker-compose.yml
needs to be updated with the new image:The
README.md
needs to be updated with shorter instructions:Running with Docker
Librum-Server can be run with Docker.
git clone https://github.com/Librum-Reader/Librum-Server cd Librum-Server docker compose up -d