I am having a really hard time getting ddclient
(which updates OpenDNS with my current IP address) to work. I have it running as a daemon, but it never succeeds in updating my IP address at openDNS
.
To troubleshoot, I am running ddclient
from the command line as follows.
(In these examples, values in square brackets [] are stand-ins for the real values for security reasons)
My /etc/ddclient.conf
contains:
use=web, web=checkip.dyndns.org/, web-skip='IP Address'
server=updates.opendns.com
protocol=dyndns2
login=[my login]
password=[my password]
Home
When I run:
sudo ddclient -daemon=0 -debug -verbose -noquiet
I get:
WARNING: file /var/cache/ddclient/ddclient.cache, line 3: Invalid Value for keyword 'ip' = ''
...
WARNING: skipping update of Home from <nothing> to [my real ip].
WARNING: last updated <never> but last attempt on Tue Oct 4 08:38:32 2011 failed.
If I rm
the cache file, ddclient
does work once, but then it fails on subsequent times.
Known bug - fixed upstream - get the latest version from a PPA
This is/was from a known "bug" -- it's caused by the dynamic DNS provider using the dyndns2 protocol incorrectly and sending malformed responses to
ddclient
.The problem has long since been fixed in ddclient (based on one of the patches linked in the trac), but Ubuntu's ddclient is so ancient (inherited from upstream) that it can't even be patched manually. (Ubuntu is on rev. 106/Jan-2009, while the latest is r130/Nov-2011).
Solution:
sudo apt-add-repository ppa:nathan-renniewaldock/ppa
sudo apt-get update && sudo apt-get install ddclient
(will upgrade if necessary)The PPA has the latest versions for 10.04, 11.10 and 12.04.
For the curious, here's the patch/buggy bit:
You want the newer ddclient package from ppa:nathan-renniewaldock/ppa but beware that this PPA contains many other packages that you might not want if all you want to do is get ddclient working. Use these steps to only upgrade ddclient.
Now, as root, create the file
/etc/apt/preferences.d/nathan-prefs
and edit it to look like this (including the blank line which is important):This tells apt-get to ignore packages from the PPA other than ddclient. So now it should be safe to do this to install it:
Or if you have already installed it, do this:
Just check that only ddclient is going to be upgraded.
skipping update of @ from to 71.422.000.000.
Most of the time when I get this warning after setting up my ddclient
WARNING: file /var/cache/ddclient/ddclient.cache, line 3: Invalid Value for keyword 'ip' = ''
it's because of a typo or just a small tweek in the ddclient.conf file. I need to stop and check it against my domain providers examples line by line.
I use NameCheap because I like the security of their password system which is tied to each domain individually, generated automatically and can be changed quickly and easily.
My latest problem was something that NameCheap does not show in their Knowledgebase example but was something I remembered having to do before. That is that I have to put a comma between the Host Names that I want updated (The name that comes before the Domain Name). So below is my example that currently works with my domain provider.
daemon=3600
ssl=yes
protocol=namecheap
use=web, web=dynamicdns.park-your-domain.com/getip
server=dynamicdns.park-your-domain.com
login=yourdomainname.com
password=0fc0ur5ethi5i5n0tmypa55w0rdfoob
@, hostname1
missing this tiny little comma throws an error