██████╗ ██████╗ ██████╗ ███╗ ██╗███████╗
██╔════╝ ██╔═══██╗██╔══██╗████╗ ██║██╔════╝
██║ ███╗██║ ██║██║ ██║██╔██╗ ██║███████╗
██║ ██║██║ ██║██║ ██║██║╚██╗██║╚════██║
╚██████╔╝╚██████╔╝██████╔╝██║ ╚████║███████║
╚═════╝ ╚═════╝ ╚═════╝ ╚═╝ ╚═══╝╚══════╝
GoDNS is a dynamic DNS (DDNS) client tool, it is based on my early open source project: DynDNS.
Now I rewrite DynDNS by Golang and call it GoDNS.
Supported DNS Providers
- Linux
- MacOS
- ARM Linux (Raspberry Pi, etc...)
- Windows
- MIPS32 platform
To compile binaries for MIPS (mips or mipsle):
GOOS=linux GOARCH=mips/mipsle GOMIPS=softfloat go build -a
And the binary can run well on routers.
Pre-condition
Get it
Build it from source code
- Get source code from Github:
git clone https://github.com/jmbayu/godns.git
- Go into the godns directory, get related library and then build it:
cd cmd/godns
go get -v
go build
Download from releases
Download compiled binaries from releases
Get help
$ ./godns -h
Usage of ./godns:
-c string
Specify a config file (default "./config.json")
-h Show help
Config it
- Get config_sample.json from Github.
- Rename it to config.json.
- Configure your provider, domain/subdomain info, username and password, etc.
- Configure the SMTP options if you want, a mail notification will sent to your mailbox once the IP is changed.
- Save it in the same directory of GoDNS, or use -c=your_conf_path command.
Config fields
- provider: The providers that GoDNS supports, available values are:
Cloudflare
, Google
, DNSPod
, AliDNS
, HE
, DuckDNS
, Dreamhost
.
- email: Email or account name of your DNS provider.
- password: Password of your account.
- login_token: API token of your account.
- domains: Domains list, with your sub domains.
- ip_url: A site helps you to get your public IPv4 IP address.
- ipv6_url: A site helps you to get your public IPv6 address.
- ip_type: To configure GoDNS under IPv4 mode or IPv6 mode, available values are:
IPv4
, IPv6
.
- interval: The interval
seconds
that GoDNS check your public IP.
- socks5_proxy: Socks5 proxy server.
- resolver: The address of the public DNS server. For example, to run GoDNS in
IPv4
mode, you can set resolver as 8.8.8.8
, to GoDNS in IPv6
mode, you can set resolver as 2001:4860:4860::8888
.
IPv6 support
Supported provider(s):
- Cloudflare
- DNSPod
- Dreamhost
- DuckDNS
- Google Domains
- HE.net
- No-IP
To enable the IPv6
support of GoDNS, there are 2 solutions you can choose:
- Get IPv6 address online
- Get IPv6 address from your network interface
To get IPv6 address online:
- Set the
ip_type
as IPv6
, and make sure the ipv6_url
is configured.
- Add one
AAAA
record to your provider.
For example:
{
"domains": [
{
"domain_name": "example.com",
"sub_domains": [
"ipv6"
]
}
],
"resolver": "2001:4860:4860::8888",
"ipv6_url": "https://api-ipv6.ip.sb/ip",
"ip_type": "IPv6"
}
To get IPv6 address from your interface:
It is quite simple, just left "ip_url" & "ipv6_url" as empty. Please note that an IPv6 address configured for your interface is the prerequisite for this feature.
Config example for Cloudflare
For Cloudflare, you need to provide the email & Global API Key as password (or to use the API token) and config all the domains & subdomains.
- Using email & Global API Key
{
"provider": "Cloudflare",
"email": "you@example.com",
"password": "Global API Key",
"domains": [{
"domain_name": "example.com",
"sub_domains": ["www","test"]
},{
"domain_name": "example2.com",
"sub_domains": ["www","test"]
}
],
"resolver": "8.8.8.8",
"ip_url": "https://myip.biturl.top",
"interval": 300,
"socks5_proxy": ""
}
{
"provider": "Cloudflare",
"login_token": "API Token",
"domains": [{
"domain_name": "example.com",
"sub_domains": ["www","test"]
},{
"domain_name": "example2.com",
"sub_domains": ["www","test"]
}
],
"resolver": "8.8.8.8",
"ip_url": "https://myip.biturl.top",
"interval": 300,
"socks5_proxy": ""
}
Config example for DNSPod
For DNSPod, you need to provide your API Token(you can create it here), and config all the domains & subdomains.
{
"provider": "DNSPod",
"login_token": "your_id,your_token",
"domains": [{
"domain_name": "example.com",
"sub_domains": ["www","test"]
},{
"domain_name": "example2.com",
"sub_domains": ["www","test"]
}
],
"resolver": "8.8.8.8",
"ip_url": "https://myip.biturl.top",
"ip_type": "IPV4",
"interval": 300,
"socks5_proxy": ""
}
Config example for Dreamhost
For Dreamhost, you need to provide your API Token(you can create it here), and config all the domains & subdomains.
{
"provider": "Dreamhost",
"login_token": "your_api_key",
"domains": [{
"domain_name": "example.com",
"sub_domains": ["www","test"]
},{
"domain_name": "example2.com",
"sub_domains": ["www","test"]
}
],
"resolver": "8.8.8.8",
"ip_url": "https://myip.biturl.top",
"ip_type": "IPV4",
"interval": 300,
"resolver": "ns1.dreamhost.com",
"socks5_proxy": ""
}
Config example for Google Domains
For Google Domains, you need to provide email & password, and config all the domains & subdomains.
{
"provider": "Google",
"email": "Your_Username",
"password": "Your_Password",
"domains": [{
"domain_name": "example.com",
"sub_domains": ["www","test"]
},{
"domain_name": "example2.com",
"sub_domains": ["www","test"]
}
],
"resolver": "8.8.8.8",
"ip_url": "https://myip.biturl.top",
"interval": 300,
"socks5_proxy": ""
}
Config example for AliDNS
For AliDNS, you need to provide AccessKeyID
& AccessKeySecret
as email
& password
, and config all the domains & subdomains.
{
"provider": "AliDNS",
"email": "AccessKeyID",
"password": "AccessKeySecret",
"login_token": "",
"domains": [{
"domain_name": "example.com",
"sub_domains": ["www","test"]
},{
"domain_name": "example2.com",
"sub_domains": ["www","test"]
}
],
"resolver": "8.8.8.8",
"ip_url": "https://myip.biturl.top",
"interval": 300,
"socks5_proxy": ""
}
Config example for DuckDNS
For DuckDNS, only need to provide the token
, config 1 default domain & subdomains.
{
"provider": "DuckDNS",
"password": "",
"login_token": "3aaaaaaaa-f411-4198-a5dc-8381cac61b87",
"domains": [
{
"domain_name": "www.duckdns.org",
"sub_domains": [
"myname"
]
}
],
"resolver": "8.8.8.8",
"ip_url": "https://myip.biturl.top",
"interval": 300,
"socks5_proxy": ""
}
Config example for No-IP
{
"provider": "NoIP",
"email": "mail@example.com",
"password": "YourPassword",
"domains": [
{
"domain_name": "ddns.net",
"sub_domains": ["timothyye6"]
}
],
"ip_type": "IPv4",
"ip_url": "https://myip.biturl.top",
"resolver": "8.8.8.8",
"interval": 300,
"socks5_proxy": ""
}
Config example for HE.net
For HE, email is not needed, just fill DDNS key to password, and config all the domains & subdomains.
{
"provider": "HE",
"password": "YourPassword",
"login_token": "",
"domains": [{
"domain_name": "example.com",
"sub_domains": ["www","test"]
},{
"domain_name": "example2.com",
"sub_domains": ["www","test"]
}
],
"resolver": "8.8.8.8",
"ip_url": "https://myip.biturl.top",
"interval": 300,
"socks5_proxy": ""
}
HE.net DDNS configuration
Add a new "A record", make sure that "Enable entry for dynamic dns" is checked:
Fill your own DDNS key or generate a random DDNS key for this new created "A record":
Remember the DDNS key and fill it as password to the config.json.
NOTICE: If you have multiple domains or subdomains, make sure their DDNS key are the same.
Get an IP address from the interface
For some reasons if you want to get an IP directly from the interface, say eth0
for Linux or Local Area Connection
for Windows, update config file like this:
"ip_url": "",
"ip_interface": "eth0",
If you set both ip_url
and ip_interface
, it first tries to get an IP address online, and if not succeed, gets
an IP address from the interface as a fallback.
Email notification support
Update config file and provide your SMTP options, a notification mail will be sent to your mailbox once the IP is changed and updated.
"notify": {
"mail": {
"enabled": true,
"smtp_server": "smtp.example.com",
"smtp_username": "user",
"smtp_password": "password",
"smtp_port": 25,
"send_to": "my_mail@example.com"
}
}
Notification mail example:
Telegram notification support
Update config file and provide your Telegram options, a notification message will be sent to your telegram channel once the IP is changed and updated.
"notify": {
"telegram": {
"enabled": true,
"bot_api_key": "11111:aaaa-bbbb",
"chat_id": "-123456",
"message_template": "Domain *{{ .Domain }}* is updated to %0A{{ .CurrentIP }}",
"use_proxy": false
},
}
Markdown is supported in message template, and use %0A
for newline.
Slack notification support
Update config file and provide your Slack options, a notification message will be sent to your slack channel once the IP is changed and updated.
"notify": {
"slack": {
"enabled": true,
"bot_api_token": "xoxb-xxx",
"channel": "your_channel",
"message_template": "Domain *{{ .Domain }}* is updated to \n{{ .CurrentIP }}",
"use_proxy": false
},
}
Markdown is supported in message template, and use \n
for newline.
SOCKS5 proxy support
You can also use SOCKS5 proxy, just fill SOCKS5 address to the socks5_proxy
item:
"socks5_proxy": "127.0.0.1:7070"
"use_proxy": true
Now all the queries will go through the specified SOCKS5 proxy.
Run it as a daemon manually
nohup ./godns &
Run it as a daemon, manage it via Upstart
- Install
upstart
first
- Copy
./upstart/godns.conf
to /etc/init
- Start it as a system service:
sudo start godns
Run it as a daemon, manage it via Systemd
- Modify
./systemd/godns.service
and config it.
- Copy
./systemd/godns.service
to /lib/systemd/system
- Start it as a systemd service:
sudo systemctl enable godns
sudo systemctl start godns
Run it with docker
Now godns supports to run in docker.
docker run -d --name godns --restart=always \
-v /path/to/config.json:/usr/local/godns/config.json timothyye/godns:latest
Run it as a Windows service
After creating your config.json file:
- Get the latest NSSM for create a windows service.
- Open the command prompt (as administrator) in the folder where you downloaded NSSM (e.g. C:\Downloads\nssm\ win64) and run:
nssm install YOURSERVICENAME
You will have an interface to configure your service, it is very simple in the "Application" tab just indicate where your godns.exe
file is. Optionally you can also define a description on the "Details" tab and define a log file on the "I/O" tab.
- Finish using the "Install service" button.
- Done. Now whenever windows start your service will be loaded.
- To uninstall:
nssm remove YOURSERVICENAME
Special Thanks
Thanks JetBrains for sponsoring this project with free open source license.
I like GoLand, it is an amazing and productive tool.