dnsc

command module
v0.3.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 4, 2020 License: MIT Imports: 0 Imported by: 0

README

dnsc

Submit query against a list of DNS servers and display summary of results

Latest Release GoDoc Validate Codebase Validate Docs Lint and Build using Makefile Quick Validation

Project home

See our GitHub repo for the latest code, to file an issue or submit improvements for review and potential inclusion into the project.

Overview

Run a DNS query concurrently against all servers in a list and provide summary of results. This is most useful after moving servers between subnets when an IP Address change is expected, but where the change may not have propagated between all DNS servers. The summary output is useful for spotting systems lagging behind the others.

Command-line flags are supported for all options, though for some settings (e.g., DNS servers), specifying values via configuration file is easier for repeat use.

Features

Current
  • A mix of command-line flags and configuration file options may be used for all options

  • Query just one server or as many as are provided

    • Note: A configuration file is recommended for providing multiple DNS servers
  • Multiple query types supported

    • CNAME
    • A
    • AAAA
    • MX
  • User configurable logging levels

  • User configurable logging format

  • User configurable query timeout

Planned

See our GitHub repo for planned future work.

Changelog

See the CHANGELOG.md file for the changes associated with each release of this application. Changes that have been merged to master, but not yet an official release may also be noted in the file under the Unreleased section. A helpful link to the Git commit history since the last official release is also provided for further review.

Requirements

  • Go 1.13+ (for building)
  • GCC
    • if building with custom options (as the provided Makefile does)
  • make
    • if using the provided Makefile

Tested using:

  • Go 1.13+
  • Windows 10 Version 1903
    • native
    • WSL
  • Ubuntu Linux 16.04+

How to install it

  1. Download Go
  2. Install Go
  3. Clone the repo
    1. cd /tmp
    2. git clone https://github.com/atc0005/dnsc
    3. cd dnsc
  4. Install dependencies (optional)
    • for Ubuntu Linux
      • sudo apt-get install make gcc
    • for CentOS Linux
      1. sudo yum install make gcc
  5. Build
    • for current operating system
      • go build -mod=vendor ./cmd/dnsc/
        • forces build to use bundled dependencies in top-level vendor folder
    • for all supported platforms (where make is installed)
      • make all
    • for Windows
      • make windows
    • for Linux
      • make linux
  6. Copy the applicable binary to whatever systems needs to run it
    • if using Makefile: look in /tmp/dnsc/release_assets/dnsc/
    • if using go build: look in /tmp/dnsc/

Configuration

Precedence

The priority order is:

  1. Command line flags (highest priority)
  2. Configuration file
  3. Default settings (lowest priority)

The intent of this behavior is to provide a feathered layering of configuration settings; if a configuration file provides nearly all settings that you want, specify just the settings that you wish to override via command-line flags and use the configuration file for the other settings.

Command-line arguments
  • Flags marked as required must be set via CLI flag or within a TOML-formatted configuration file.
  • Flags not marked as required are for settings where a useful default is already defined.
Flag Required Default Repeat Possible Description
h, help No false No h, help Show Help text along with the list of supported flags.
ds, dns-server Yes empty string Yes one valid IP Address per flag invocation DNS server to submit query against. This flag may be repeated for each additional DNS server to query.
cf, config-file Yes empty string No valid file name characters Full path to TOML-formatted configuration file. See config.example.toml for a starter template.
v, version No false No v, version Whether to display application version and then immediately exit application.
def, dns-errors-fatal No false No def, dns-errors-fatal Whether DNS-related errors should force this application to immediately exit.
q, query Yes empty string No any valid FQDN string Fully-qualified system to lookup from all provided DNS servers.
ll, log-level No info No fatal, error, warn, info, debug Log message priority filter. Log messages with a lower level are ignored.
lf, log-format No text No cli, json, logfmt, text, discard Use the specified apex/log package "handler" to output log messages in that handler's format.
t, type No A Yes A, AAAA, MX, CNAME DNS query type to use when submitting a DNS query to each provided server. This flag may be repeated for each additional DNS record type you wish to request.
to, timeout No 10 No any positive whole number Maximum number of seconds allowed for a DNS query to take before timing out.
Configuration file

Configuration file settings have the lowest priority and are overridden by settings specified in other configuration sources, except for default values. See the Command-line Arguments table for more information, including the available values for the listed configuration settings.

Flag Name Config file Setting Name Notes
dns-server dns_servers Multi-line array
query query While supported, having a fixed query in the config file is not a normal use case.
dns-errors-fatal dns_errors_fatal Opt-in setting. Useful to leave as-is for most use cases.
log-level log_level
log-format log_format
type dns_request_types Multi-line array
timeout timeout

The config.example.toml file is intended as a starting point for your own config.toml configuration file and attempts to illustrate working values for the available command-line flags.

Once reviewed and potentially adjusted, your copy of the config.toml file can be placed in one of the following locations to be automatically detected and used by this application:

  • alongside the dnsc (or dnsc.exe) binary (as config.toml)
  • at $HOME/.config/dnsc/config.toml on a UNIX-like system (e.g., Linux distro, Mac)
  • at C:\Users\YOUR_USERNAME\AppData\dnsc\config.toml on a Windows system

Feel free to place the file wherever you like and refer to it using the -cf (short flag name) or -config-file (full-length flag name). See the Examples and Command-line arguments sections for usage details.

Examples

Our config file

These examples assume that the referenced config.example.toml file has the following contents:


dns_servers = [

    # https://developers.google.com/speed/public-dns
    "8.8.8.8",
    "8.8.4.4",

    # https://www.opendns.com/setupguide/
    "208.67.222.222",
    "208.67.220.220",

    # https://blog.cloudflare.com/announcing-1111/
    "1.1.1.1",
]

dns_query_types = [
    "A",
    "AAAA",
    "MX",
    "CNAME",
]

See the Configuration file section for additional information, including supported locations for this file.

Flags only, no config file

Here the dnsc application attempted to load a config file using the locations mentioned in the Configuration file section, but one was not found:

$ ./dnsc.exe -ds 8.8.8.8 -ds 8.8.4.4 -ds 208.67.220.220 -ds 208.67.222.222 -q www.yahoo.com
  INFO[0000] User-specified config file not provided
  INFO[0000] Trying to load config file "T:\\github\\dnsc\\config.toml"
  WARN[0000] Config file "T:\\github\\dnsc\\config.toml" not found or unable to load
  INFO[0000] Trying to load config file "C:\\Users\\adam\\AppData\\Roaming\\dnsc\\config.toml"
  WARN[0000] Config file "C:\\Users\\adam\\AppData\\Roaming\\dnsc\\config.toml" not found or unable to load
  WARN[0000] Failed to load config files, relying only on provided flag settings


Server            Query            Type    Answers                                                                                                            TTL
---               ---              ---     ---                                                                                                                ---
208.67.220.220    www.yahoo.com    A       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)    1304, 18, 18, 18, 18
208.67.222.222    www.yahoo.com    A       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)    1433, 40, 40, 40, 40
8.8.4.4           www.yahoo.com    A       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A)                                            591, 31, 31
8.8.8.8           www.yahoo.com    A       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)    98, 32, 32, 32, 32

Since we did not specify a record query type, only A records were requested in the query to each DNS server. Since we have recursion enabled and the dnsc application does not exclude them, the initial CNAME record found by each query is also listed in the Answers section above for each DNS server that had it.

Use config file for DNS servers list and query types

As can be seen below, this example produces quite a bit of output.

$ dnsc -config-file ./config.example.toml -q www.yahoo.com

  INFO[0000] User-specified config file provided, will attempt to load it
  INFO[0000] Trying to load config file "./config.example.toml"
  INFO[0000] Config file successfully loaded config_file=./config.example.toml


Server            Query            Type     Answers                                                                                                                                                       TTL
---               ---              ---      ---                                                                                                                                                           ---
1.1.1.1           www.yahoo.com    CNAME    atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1082
1.1.1.1           www.yahoo.com    A        atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)                                               1082, 41, 41, 41, 41
1.1.1.1           www.yahoo.com    AAAA     atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 2001:4998:58:1836::11 (AAAA), 2001:4998:44:41d::3 (AAAA), 2001:4998:44:41d::4 (AAAA), 2001:4998:58:1836::10 (AAAA)    1082, 33, 33, 33, 33
1.1.1.1           www.yahoo.com    MX       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1082
208.67.220.220    www.yahoo.com    A        atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)                                               1137, 38, 38, 38, 38
208.67.220.220    www.yahoo.com    MX       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1047
208.67.220.220    www.yahoo.com    AAAA     atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 2001:4998:58:1836::10 (AAAA), 2001:4998:58:1836::11 (AAAA), 2001:4998:44:41d::3 (AAAA), 2001:4998:44:41d::4 (AAAA)    1047, 60, 60, 60, 60
208.67.220.220    www.yahoo.com    CNAME    atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        679
208.67.222.222    www.yahoo.com    MX       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        679
208.67.222.222    www.yahoo.com    AAAA     atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 2001:4998:58:1836::10 (AAAA), 2001:4998:58:1836::11 (AAAA), 2001:4998:44:41d::3 (AAAA), 2001:4998:44:41d::4 (AAAA)    1047, 60, 60, 60, 60
208.67.222.222    www.yahoo.com    CNAME    atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1524
208.67.222.222    www.yahoo.com    A        atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)                                               679, 55, 55, 55, 55
8.8.4.4           www.yahoo.com    AAAA     atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 2001:4998:58:1836::10 (AAAA), 2001:4998:44:41d::4 (AAAA), 2001:4998:44:41d::3 (AAAA), 2001:4998:58:1836::11 (AAAA)    569, 9, 9, 9, 9
8.8.4.4           www.yahoo.com    MX       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1121
8.8.4.4           www.yahoo.com    A        atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)                                               1008, 35, 35, 35, 35
8.8.4.4           www.yahoo.com    CNAME    atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        806
8.8.8.8           www.yahoo.com    MX       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        927
8.8.8.8           www.yahoo.com    AAAA     atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 2001:4998:58:1836::11 (AAAA), 2001:4998:44:41d::3 (AAAA), 2001:4998:44:41d::4 (AAAA), 2001:4998:58:1836::10 (AAAA)    924, 23, 23, 23, 23
8.8.8.8           www.yahoo.com    CNAME    atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        903
8.8.8.8           www.yahoo.com    A        atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)                                               576, 38, 38, 38, 38
Specify DNS servers list via flags

You can also specify the DNS servers via CLI flags, though it is a bit more verbose:

$ dnsc -ds 8.8.8.8 -ds 8.8.4.4 -ds 208.67.220.220 -ds 208.67.222.222 -q www.yahoo.com

  INFO[0000] User-specified config file not provided
  INFO[0000] Trying to load config file "T:\\github\\dnsc\\config.toml"
  WARN[0000] Config file "T:\\github\\dnsc\\config.toml" not found or unable to load
  INFO[0000] Trying to load config file "C:\\Users\\adam\\AppData\\Roaming\\dnsc\\config.toml"
  INFO[0000] Config file successfully loaded config_file=C:\Users\adam\AppData\Roaming\dnsc\config.toml


Server            Query            Type     Answers                                                                                                                                                       TTL
---               ---              ---      ---                                                                                                                                                           ---
208.67.220.220    www.yahoo.com    AAAA     atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 2001:4998:58:1836::10 (AAAA), 2001:4998:58:1836::11 (AAAA), 2001:4998:44:41d::3 (AAAA), 2001:4998:44:41d::4 (AAAA)    1339, 11, 11, 11, 11
208.67.220.220    www.yahoo.com    A        atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)                                               1339, 40, 40, 40, 40
208.67.220.220    www.yahoo.com    CNAME    atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1775
208.67.220.220    www.yahoo.com    MX       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1339
208.67.222.222    www.yahoo.com    CNAME    atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        395
208.67.222.222    www.yahoo.com    AAAA     atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 2001:4998:58:1836::10 (AAAA), 2001:4998:58:1836::11 (AAAA), 2001:4998:44:41d::3 (AAAA), 2001:4998:44:41d::4 (AAAA)    1339, 11, 11, 11, 11
208.67.222.222    www.yahoo.com    MX       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        858
208.67.222.222    www.yahoo.com    A        atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A), 98.138.219.231 (A), 98.138.219.232 (A)                                               858, 35, 35, 35, 35
8.8.4.4           www.yahoo.com    AAAA     atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 2001:4998:58:1836::11 (AAAA), 2001:4998:58:1836::10 (AAAA)                                                            1500, 55, 55
8.8.4.4           www.yahoo.com    MX       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1297
8.8.4.4           www.yahoo.com    A        atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A)                                                                                       1581, 18, 18
8.8.4.4           www.yahoo.com    CNAME    atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1580
8.8.8.8           www.yahoo.com    AAAA     atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 2001:4998:58:1836::11 (AAAA), 2001:4998:58:1836::10 (AAAA)                                                            1587, 37, 37
8.8.8.8           www.yahoo.com    MX       atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1483
8.8.8.8           www.yahoo.com    A        atsv2-fp-shed.wg1.b.yahoo.com. (CNAME), 72.30.35.9 (A), 72.30.35.10 (A)                                                                                       1616, 53, 53
8.8.8.8           www.yahoo.com    CNAME    atsv2-fp-shed.wg1.b.yahoo.com. (CNAME)                                                                                                                        1580

No errors here since www.yahoo.com had records for all of the requested query types.

It's also worth pointing out that I have a local copy of the config.toml file which was automatically detected and loaded.

Force exit on first DNS error

As of v0.3.0, this application ignores query errors by default in order to allow the results to be processed from all servers. This can be useful if you have one DNS server from the group unreachable or providing invalid results. If however you wish to restore the previous behavior you can specify either the dns-errors-fatal or def flags, or set dns_errors_fatal = true in the config.toml config file.

Example:

$ dnsc -config-file ./config.example.toml -q www.penzoil.com

  INFO[0000] User-specified config file provided, will attempt to load it
  INFO[0000] Trying to load config file "./config.example.toml"
  INFO[0000] Config file successfully loaded config_file=./config.example.toml


Server     Query              Type    Answers                       TTL
---        ---                ---     ---                           ---
8.8.4.4    www.penzoil.com    A       65.52.64.201 (A)              751
1.1.1.1    www.penzoil.com    A       65.52.64.201 (A)              753
8.8.8.8    www.penzoil.com    A       65.52.64.201 (A)              899
1.1.1.1    www.penzoil.com    AAAA    no records found for query

Here the process bailed when the first AAAA request failed. This is due to the dns_errors_fatal = true config file setting (not shown here).

Inspiration

This project was inspired by a small script that I used for many years to quickly spot outliers with DNS servers after moving virtual servers between subnets. The shell script is usable, but crude. It is provided as-is and can be found here:

dns_query.sh

This project also owes its existence to the miekg/dns package and the Black Hat Go authors whose example code got me started. See the References section for links to both resources. Many thanks to the authors of both!

References

Documentation

Overview

Submit query against a list of DNS servers and display summary of results

PROJECT HOME

See our GitHub repo (https://github.com/atc0005/dnsc) for the latest code, to file an issue or submit improvements for review and potential inclusion into the project.

PURPOSE

Run a DNS query concurrently against all servers in a list and provide summary of results. This is most useful after moving servers between subnets when an IP Address change is expected, but where the change may not have propagated between all DNS servers. The summary output is useful for spotting systems lagging behind the others.

Command-line flags are supported for all options, though for some settings (e.g., DNS servers), specifying values via configuration file is easier for repeat use.

FEATURES

• single binary, no outside dependencies

• User configurable logging levels

• User configurable logging format

USAGE

Help output is below. See the README for examples.

$ ./dnsc.exe -h

dnsc dev build
https://github.com/atc0005/dnsc

Usage of "dnsc.exe":
-cf string
    Full path to TOML-formatted configuration file. See config.example.toml for a starter template. (shorthand)
-config-file string
    Full path to TOML-formatted configuration file. See config.example.toml for a starter template.
-dns-server value
    DNS server to submit query against. This flag may be repeated for each additional DNS server to query.
-ds value
    DNS server to submit query against. This flag may be repeated for each additional DNS server to query. (shorthand)
-ide
    Whether DNS-related errors with one server should be ignored in order to try other DNS servers in the list. (shorthand)
-ignore-dns-errors
    Whether DNS-related errors with one server should be ignored in order to try other DNS servers in the list.
-lf string
    Log messages are written in this format (default "text")
-ll string
    Log message priority filter. Log messages with a lower level are ignored. (default "info")
-log-format string
    Log messages are written in this format (default "text")
-log-level string
    Log message priority filter. Log messages with a lower level are ignored. (default "info")
-q string
    Fully-qualified system to lookup from all provided DNS servers. (shorthand)
-query string
        Fully-qualified system to lookup from all provided DNS servers.
-t value
    DNS query type to use when submitting DNS queries. The default is the 'A' query type. This flag may be repeated for each additional DNS record type you wish to request. (shorthand)
-type value
    DNS query type to use when submitting DNS queries. The default is the 'A' query type. This flag may be repeated for each additional DNS record type you wish to request.
-v
    Whether to display application version and then immediately exit application. (shorthand)
-version
    Whether to display application version and then immediately exit application.

Directories

Path Synopsis
cmd
Package config provides types and functions to collect, validate and apply user-provided settings.
Package config provides types and functions to collect, validate and apply user-provided settings.
Package dqrs provides types and functions used by this application to collect and process DNS queries and responses.
Package dqrs provides types and functions used by this application to collect and process DNS queries and responses.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL