this post was submitted on 14 Dec 2024
59 points (91.5% liked)

Selfhosted

40956 readers
1158 users here now

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:

  1. Be civil: we're here to support and learn from one another. Insults won't be tolerated. Flame wars are frowned upon.

  2. No spam posting.

  3. 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.

  4. Don't duplicate the full text of your blog or github here. Just post the link for folks to click.

  5. Submission headline should match the article title (don’t cherry-pick information from the title to fit your agenda).

  6. No trolling.

Resources:

Any issues on the community? Report it using the report flag.

Questions? DM the mods!

founded 2 years ago
MODERATORS
 

Good FOSS software and reliable service providers? Etc.

top 50 comments
sorted by: hot top controversial new old
[–] 2xsaiko@discuss.tchncs.de 45 points 3 weeks ago (3 children)

Any registrar worth using has an API for updating DNS entries.

I just found this with a quick search: https://github.com/qdm12/ddns-updater

[–] DynamoSunshirtSandals@possumpat.io 12 points 3 weeks ago (1 children)

exactly. I literally have a bash script that calls the API triggered by cron every 30 minutes. That's it. Are people seriously using a freaking docker container for this?

[–] jws_shadotak@sh.itjust.works 7 points 3 weeks ago (2 children)

It's easy to set up and also keeps a history

[–] DynamoSunshirtSandals@possumpat.io 9 points 3 weeks ago (1 children)

Ah, a history would be nice. I've been thinking of keeping some stats to monitor when the connection goes down, and how often my IP changes.

Fortunately I've kept the same IP since i changed ISPs a few months ago.

Personally I still think docker is overkill for something that can be done with a bash script. But I also use a Pi 4 as my home server, so I need to be a little more scrupulous of CPU and RAM and storage than most :-)

load more comments (1 replies)
[–] LaSirena@lemmy.world 2 points 3 weeks ago

I just dump the changes with timestamps to a text file. Notifications for IP changes get sent to matrix after the DNS record is updated.

[–] mhzawadi@lemmy.horwood.cloud 7 points 3 weeks ago

I would recommend OVH for DNS, they have an API and are on the list for that tool. Also you can use the API to get lets encrypt certificates

[–] sith@lemmy.zip 2 points 3 weeks ago

Looks good. Thanks!

[–] jeena@piefed.jeena.net 15 points 3 weeks ago (1 children)
[–] conrad82@lemmy.world 5 points 3 weeks ago (1 children)

Me too. I use uptime kuma to send the api request. then I also get uptime status 🙂

[–] Cyber@feddit.uk 1 points 3 weeks ago

That's a great idea, I hadn't thought of that

[–] SaltySalamander@fedia.io 13 points 3 weeks ago

cloudflare + the dynamic dns plugin for opnsense.

[–] bigdickdonkey@lemmy.ca 12 points 3 weeks ago

I use ddclient but in a docker container. Works great with minimal config

[–] ShortN0te@lemmy.ml 10 points 3 weeks ago

Have done it via bash scripts for years. Never had a problem. Since a few months i use https://github.com/qdm12/ddns-updater

[–] Shimitar@feddit.it 8 points 3 weeks ago (5 children)

Ixury for people that can have public IPs! :)

[–] sugar_in_your_tea@sh.itjust.works 4 points 3 weeks ago (2 children)
[–] chronicledmonocle@lemmy.world 4 points 3 weeks ago (7 children)

It's why IPv6 is important, but many didn't listen.

[–] Andres4NY@social.ridetrans.it 3 points 3 weeks ago

@chronicledmonocle @sugar_in_your_tea This is why I love yggdrasil. Thanks to having a VPS running it that all of my hosts globally can connect to, I can just use IPv6 for everything and reverse proxy using those IPv6 addresses where I need to. Once hosts are connected and on my private yggdrasil network, I stop caring about CGNAT or IPv4 at all other than to maybe create public IPv4 access to a service.

load more comments (6 replies)
[–] Shimitar@feddit.it 2 points 3 weeks ago (1 children)

Yeah, there are workarounds... And who knows, maybe its just safer than public ip... But definitely require some external fixture.

[–] kchr@lemmy.sdf.org 3 points 3 weeks ago (2 children)

I guess you already know about the options, but for others:

Find the cheapest VPS out there and have a Wireguard tunnel between it and your home network. Run ddclient or similar on the VPS in case the public IP changes.

load more comments (2 replies)
load more comments (4 replies)
[–] yournamehere@lemm.ee 8 points 3 weeks ago

afraid still works like a charm. cloudflare is ok. duckdns is cool.

[–] CarbonatedPastaSauce@lemmy.world 8 points 3 weeks ago (1 children)

I solve it by paying way too much for a block of static IPs.

[–] douglasg14b@lemmy.world 7 points 3 weeks ago* (last edited 3 weeks ago) (1 children)

Way too much for sure.

Just the business internet to get the foot in the door for a static IP 5x's the cost of my Internet.

It's actually cheaper to just have DC IPs and proxy through hosted containers. Which is kind of crazy.

Negative aspect is that DC IPs aren't treated very nice.

load more comments (1 replies)
[–] ryan_harg@discuss.tchncs.de 6 points 3 weeks ago* (last edited 3 weeks ago)

used a bash script and a cron job for a long time, now the whole topic is one of the projects i regularly rewrite whenever I want to get my hands dirty with a new programming language or framework.

[–] Bakkoda@sh.itjust.works 6 points 3 weeks ago

Afraid has a curl update. Cron job. It's that simple.

[–] PieMePlenty@lemmy.world 5 points 3 weeks ago

My ip updates maybe once every three months or so, but what i did was just write a script that checks the current ip and updates the domain registrar. My domain is on cloud flare, and they have an API through which I can do it. It's literally one POST request. There are solutions out there but I wanted a really simple solution I fully understand so I just did this. Script runs in cron every few hours and that's it.

[–] philthi@lemmy.world 5 points 3 weeks ago (2 children)

Have you heard of the kuadrant project? It is for kubernetes and has a dynamic DNS element. Kuadrant.io

[–] sith@lemmy.zip 5 points 3 weeks ago

Probably good, but I want to stay away from anything related to Kubernetes. My experience is that it's an overkill black hole of constant debugging. Unfortunately. Thanks though!

[–] jlh@lemmy.jlh.name 1 points 3 weeks ago (1 children)

Interesting, this seems to have better documentation and feedback than the external-dns operator

[–] philthi@lemmy.world 2 points 3 weeks ago (1 children)

It leans on the external-dns operator in it's DNS operator.

load more comments (1 replies)
[–] irotsoma@lemmy.world 5 points 3 weeks ago (1 children)

Cloudflare DDNS updated by ddclient on my OpnSense router. Cloudflare happens to be my current domain registrar. Honestly, my IPv4 doesn't change that often. And when I used to be on Comcast, they assigned a block of IPv6 addresses and the router dealt with that. Unfortunately, I now have Quantum Fiber who only assign a single IPv6 address, so I gave up on IPv6 for now.

[–] ikidd@lemmy.world 1 points 3 weeks ago

Just a practice I've had over the years with domains: separate your registrar and your DNS. If one goes down, or out of business, you can fix it if you still control the other and its accessible. If you have both of them in one place, it's really hard to get that domain transferred.

[–] downhomechunk@midwest.social 5 points 3 weeks ago (1 children)

Ddclient has done the trick for me, and my registrar supports it with an API

[–] mbfalzar@lemmy.dbzer0.com 4 points 3 weeks ago

I set it once like 6 years ago and forgot it wasn't something pre-installed and configured until I saw your comment. I was reading through the comments looking for the "you don't need to do anything, ddclient takes care of it"

[–] emax_gomax@lemmy.world 5 points 3 weeks ago

Ddns-updater and porkbun.

[–] anamethatisnt@lemmy.world 4 points 3 weeks ago* (last edited 3 weeks ago)

I would go for registering my own domain and then rent a small vps and run debian 12 server with bind9 for dns + dyndns.
If you don't want to put the whole domain on your own name servers then you can always delegate a subdomain to the debian 12 server and run your main domain on your domain registrators name servers.

edit:

https://github.com/qdm12/ddns-updater

If your registrar is supported the ddns-updater sounds a lot easier.

[–] shortwavesurfer@lemmy.zip 4 points 3 weeks ago

Tor hidden service

[–] dm_me_your_feet@lemmy.world 4 points 3 weeks ago (1 children)

Desec + Nginx Proxy Manager as a reverse proxy. Solves ddns and https with a letsencrypt wildcard cert.

[–] kchr@lemmy.sdf.org 1 points 3 weeks ago

Hadn't heard about deSec until now, seems to be run by some cool privacy minded folks in Germany:

https://desec.io/

[–] possiblylinux127@lemmy.zip 4 points 3 weeks ago

What do you mean?

[–] abeorch@friendica.ginestes.es 3 points 3 weeks ago

@sith
If this is useful we had a bit of a conversation about DynDns options a while back. Im currently using Hetzner with my subdomain names being dynamically updated.
lemmy.ml/post/18477306

[–] leisesprecher@feddit.org 3 points 3 weeks ago

If you don't need actually public DNS, something like Tailscale might be an option.

[–] Pika@sh.itjust.works 2 points 3 weeks ago

my router uses openwrt which supports dynamic DNS updating on its own for multiple providers, I currently am through namecheap on it.

[–] markstos@lemmy.world 1 points 3 weeks ago

https://www.cloudns.net/ Makes dynamic DNS very easy.

[–] GreenKnight23@lemmy.world 1 points 3 weeks ago

terraform and AWS route 53 on a self hosted gitlab pipeline.

load more comments
view more: next ›