Use -m
and limit the build job's memory so it doesn't kill the docker daemon.
Selfhosted
A place to share alternatives to popular online services that can be self-hosted without giving up privacy or locking you into a service you don't control.
Rules:
-
Be civil: we're here to support and learn from one another. Insults won't be tolerated. Flame wars are frowned upon.
-
No spam posting.
-
Posts have to be centered around self-hosting. There are other communities for discussing hardware or home computing. If it's not obvious why your post topic revolves around selfhosting, please include details to make it clear.
-
Don't duplicate the full text of your blog or github here. Just post the link for folks to click.
-
Submission headline should match the article title (don’t cherry-pick information from the title to fit your agenda).
-
No trolling.
Resources:
- selfh.st Newsletter and index of selfhosted software and apps
- awesome-selfhosted software
- awesome-sysadmin resources
- Self-Hosted Podcast from Jupiter Broadcasting
Any issues on the community? Report it using the report flag.
Questions? DM the mods!
Fair enough. But I don't want a bandaid fix solution. Even more that I do all my docker through portainer and the option isn't there.
It could also be useful if a container got a memory leak and is unbounded
The other person may have responded with a fair amount of hostility, but they're absolutely correct. I run Kubernetes clusters hosting millions of containers across hundreds of thousands of VMs at my job, and OOMKills are just a fact of life. Apps will leak memory, and you're powerless to fix it unless you're willing to debug the app and fix the leak. It's better for the container to run out of memory and trigger a cgroup-scoped OOM kill. A system-wide OOM kill will murder the things you love, shit in your hat, and lick your face like David Tennant licked Krysten Ritter.
Oh that's not a problem to let a container get killed. It's perfectly fine. What I want is just not crippling my whole server because one container did a funny.
If it keeps docker and the portainer VM I'll be 100% ok, because I can just restart it. I don't want to have remote access to my server outside of my home for security reasons, so this is just the bare minimum
Those remote access fears can be solved with a wireguard VPN
I don't want to have remote access to my server outside of my home for security reasons, so this is just the bare minimum
What are your security concerns?
This is not a bandaid, this is the solution. What you try is, at least for this scenario, the band aid.
??? Your original proposed solution is literally a bandaid fix.
Systemd has config options for automatic restart of crashed services. https://www.freedesktop.org/software/systemd/man/latest/systemd.service.html#Restart=
Do you have your services set up with restart=unless-stopped
? I wonder if that would auto restart them after OOM.
I don't know the best way but I would use cron and start docker every minute (if it's not running).
I don't know the best way
Apparently...
Don't do this. Either don't go OOM to begin with (somebody else told you how to limit container memory usage} and/or configure systemd to restart docker if it quits. I'm surprised systemd isn't already.
It's usually good to state why something is good or bad :)
It's fairly obvious I feel.
You're saying rather than use a system tool that does the exact thing that you want you should bodge together a cron job that accomplishes your goal but doesn't actually do what you want.
Like say you want to stop the docker service for some reason? systemctl stop docker
will do that. Then your cron job will restart it. That's not the desired outcome. You want the service running IF the service SHOULD be running. Which is a different thing than "always running". And its' exactly what you get for free with systemd without any silly custom BS.
Seems like the best solution. I'll look into it
Seems like the best solution.
Over using a system tool designed to monitor and restart services that stop?
? I'm agreeing with you?
Sorry - was ambiguous and thought you were saying the "cron" thing sounded best.
I'll try that. I know that systemctl has a start-or-reload command, but is there any "start-or-ignore" commands? Or start flags?
You should be able to make docker exempt from early oom. Check it's github for instructions.
But can it prevent killing only docker, and not the build/big containers processes?