DDNS - Kein IPv6 für "Anbieter Anpassen"?

Meeshaw

Benutzer
Mitglied seit
18. Jan 2017
Beiträge
24
Punkte für Reaktionen
1
Punkte
9
Hallo zusammen,

ich würde gerne mein AAAA Record über DDNS des Synology NAS aktualisieren, nur leider sehe ich keine IPv6 Variable dafür.
Kann mir jemand helfen?

Ich will sicherstellen das, sollte sich der Network Prefix mal ändern, ich mein NAS noch von extern erreichen kann.

Danke euch.


2023-07-22_23h11_56.png
 
Zuletzt bearbeitet:

Benares

Benutzer
Sehr erfahren
Mitglied seit
27. Sep 2008
Beiträge
13.131
Punkte für Reaktionen
3.403
Punkte
468
Es ist ein m.E. großes Manko beim DDNS-Client der Synology, dass dieser wohl nur IPv4 kann. Lediglich bei synology.me als DDNS-Provider kann man auch IPv6 updaten. Oder man braucht halt einen DDNS-Provider, bei dem in der Update-URL einfach gar nichts zu IP-Adressen angibt, und der dann die IP nimmt, über die die Verbindung reinkommt.
 
  • Like
Reaktionen: Meeshaw

Meeshaw

Benutzer
Mitglied seit
18. Jan 2017
Beiträge
24
Punkte für Reaktionen
1
Punkte
9
Alles klar, danke. Ich hatte die leise Hoffnung, dass es hier noch irgendein Trick gibt. Mein DNS Provider unterstützt zwar das Autodetect der IP Adressen, bei IPv6 wird allerdings nur die temporäre öffentlich angezeigt. Das bringt mir somit also nichts.
Dann werde ich wohl auf ein Cronjob ausweichen. Schade..
 

Meeshaw

Benutzer
Mitglied seit
18. Jan 2017
Beiträge
24
Punkte für Reaktionen
1
Punkte
9
Ich habe das jetzt mit einem Skript gelöst welches ich alle paar Stunden im Aufgabenplaner ausführe.

Quelle vom Skript

Bash:
#!/bin/bash

# Get public ipv6 address
ip=$(ip -6 addr list scope global $device | grep -v " fd" | sed -n 's/.*inet6 \([0-9a-f:]\+\).*/\1/p' | head -n 1)
USER=XXXXXX
PASSWORD=XXXXXX
URL=my.domain.com

# Exiting if ip address is empty
if [ -z $ip ];then
    echo "IP address is empty. Exiting!"
    exit 1
fi

# Exiting if ip address is unchanged
if [ $(cat address.txt) == "$ip" ];then
    echo "IP address is unchanged. Ending."
    exit 0
fi

#Make request to dns provider and set new ipv6
RESPONSE=$(curl "https://$URL:$PASSWORD@dyn.dns.he.net/nic/update?hostname=$URL&myip=$ip")

#echo $RESPONSE

# Return with code 0 if everything is ok and everything is ok, if ip address is in response
if [[ $RESPONSE =~ $ip ]];then
    echo "Finished. Everything is ok."
    
    #save ip address to address.txt to prevent updates on unchanged ip
    echo $ip > address.txt

    exit 0
else
    echo "Finished with errors!"
    exit 1
fi
 
  • Like
Reaktionen: nachrichten

Benares

Benutzer
Sehr erfahren
Mitglied seit
27. Sep 2008
Beiträge
13.131
Punkte für Reaktionen
3.403
Punkte
468
Ich würde sicherheitshalber noch die Variable "device" setzen. Sonst nimmt er immer die erste IPv6, die er findet.
 

Meeshaw

Benutzer
Mitglied seit
18. Jan 2017
Beiträge
24
Punkte für Reaktionen
1
Punkte
9
Danke für den Hinweis! Sieht jetzt so aus.

Bash:
#!/bin/bash

USER=XXXXXX
PASSWORD=XXXXXX
URL=my.domain.com
DEVICE=bond0

# Get public ipv6 address
ip=$(ip -6 addr list $DEVICE scope global | grep -v " fd" | sed -n 's/.*inet6 \([0-9a-f:]\+\).*/\1/p' | head -n 1)

# Exiting if ip address is empty
if [ -z $ip ];then
    echo "IP address is empty. Exiting!"
    exit 1
fi

# Exiting if ip address is unchanged
if [ $(cat address.txt) == "$ip" ];then
    echo "IP address is unchanged. Ending."
    exit 0
fi

#Make request to dns provider and set new ipv6
RESPONSE=$(curl "https://$URL:$PASSWORD@dyn.dns.he.net/nic/update?hostname=$URL&myip=$ip")

#echo $RESPONSE

# Return with code 0 if everything is ok and everything is ok, if ip address is in response
if [[ $RESPONSE =~ $ip ]];then
    echo "Finished. Everything is ok."
   
    #save ip address to address.txt to prevent updates on unchanged ip
    echo $ip > address.txt

    exit 0
else
    echo "Finished with errors!"
    exit 1
fi
 
Zuletzt bearbeitet:

Benares

Benutzer
Sehr erfahren
Mitglied seit
27. Sep 2008
Beiträge
13.131
Punkte für Reaktionen
3.403
Punkte
468
Wie kommst du auf "mngtmpaddr\ dynamic"? Ich dachte da eher an "eth0", "eth1" etc., je nachdem welcher LAN-Port genutzt wird.
 
  • Like
Reaktionen: Meeshaw

Meeshaw

Benutzer
Mitglied seit
18. Jan 2017
Beiträge
24
Punkte für Reaktionen
1
Punkte
9
(y)Habe ich im letzten Post nochmal angepasst.
Ich wollte damit nur erreichen das immer die globale Adresse gezogen wird und nicht die link local.
Da es aber eh nur eine globale gibt, macht das von dir genannte natürlich mehr Sinn, auf den Netzwerkport (bei mir bond0) einzuschränken.

1690372879543.png
 
Zuletzt bearbeitet:

Benares

Benutzer
Sehr erfahren
Mitglied seit
27. Sep 2008
Beiträge
13.131
Punkte für Reaktionen
3.403
Punkte
468
Meine DS1522+ hat beispielsweise 5 LAN-Ports. LAN1-4 (eth0-3) sind 1GBit, LAN5 (eth4) ist 10GBit. Angeschlossen sind LAN1 und LAN5.
Ohne die Device-Angabe hat das Script die IPv6 von LAN1 ermittelt.
 
Zuletzt bearbeitet:
  • Like
Reaktionen: Meeshaw

superwallah

Benutzer
Mitglied seit
08. Jun 2023
Beiträge
17
Punkte für Reaktionen
1
Punkte
3
Bash:
#Make request to dns provider and set new ipv6
RESPONSE=$(curl "https://$URL:$PASSWORD@dyn.dns.he.net/nic/update?hostname=$URL&myip=$ip")

Braucht he.net tatsächlich $URL:$PASSWORD vor der Update-URL und nicht $USER:$PASSWORD?
Bei Selfhost.de ist das anders.
 

Gunduran

Benutzer
Mitglied seit
19. Apr 2015
Beiträge
1
Punkte für Reaktionen
0
Punkte
1
Hallo Zusammen,
dafür braucht man mittlerweile kein Script mehr

DDNS-Einstellungen>
  • IPv4 deaktivieren
  • Bei IPv6 auf automatisch.
Falls das nicht funktioniert, ist nicht die richtige IPv6 Adresse im Netzwerkadapter eingestellt!
Man muss sicherstellen, dass man die wirklich globale Adresse auch sehen kann. Dies darf also nicht mit fd oder fe anfangen sondern wie bei mir z. B. 2a00: ....

Und so klappt es dann auch mit myds.me oder anderen synology Domänen
 

Benares

Benutzer
Sehr erfahren
Mitglied seit
27. Sep 2008
Beiträge
13.131
Punkte für Reaktionen
3.403
Punkte
468
Ja, aber halt nur bei Synology-DDNS.
 


 

Kaffeautomat

Wenn du das Forum hilfreich findest oder uns unterstützen möchtest, dann gib uns doch einfach einen Kaffee aus.

Als Dankeschön schalten wir deinen Account werbefrei.

:coffee:

Hier gehts zum Kaffeeautomat 

 
 
  AdBlocker gefunden!

Du bist nicht hier, um Support für Adblocker zu erhalten. Dein Adblocker funktioniert bereits ;-)

Klar machen Adblocker einen guten Job, aber sie blockieren auch nützliche Funktionen.

Das Forum wird mit hohem technischen, zeitlichen und finanziellen Aufwand kostenfrei zur Verfügung gestellt. Wir zeigen keine offensive Werbung und bemühen uns um eine dezente Integration.

Bitte unterstütze dieses Forum, in dem du deinen Adblocker für diese Seite deaktivierst.

Du kannst uns auch über unseren Kaffeautomat einen Kaffe ausgeben oder ein PUR Abo abschließen und das Forum so werbefrei nutzen.

Vielen Dank für Deine Unterstützung!