I am a new Linux and command line user. How do I use host command line utility to verify DNS settings on Linux and Unix-like operating systems? How do I use dig command to find the IP address of a host name or host Name of an IP address?
|host command details|
|Estimated completion time||15m|
- Performing DNS name lookups.
- Finding the IP address of a host or vice versa.
- List and validate various types of DNS resource records such as as NS and MX names.
- Verify ISP dns server and Internet connectivity.
- Verify spam and blacklisting records.
- Verifying and troubleshooting dns server problems.
Use host command to resolve a host name into an Internet Protocol (IP) address or an IP address into a host name.
The basic syntax:
host host-name-here [DNS-Server-Name-Here]
host [options] IPAddress | Hostname [DNS-Server-Name-Here]
Before you use the host command you should aware of common types of resource records of the DNS. Here are most common resource records:
|A||IPv4 IP address||192.168.1.5 or 188.8.131.52|
|AAAA||IPv6 IP address||2607:f0d0:1002:51::4|
|CNAME||Canonical name record (Alias)||s0.cyberciti.org is an alias
|MX||Email server host names||smtp.cyberciti.biz or mx1.nixcraft.com|
|NS||Name (DNS) server names||ns1.cyberciti.biz or ns-243.awsdns-30.com|
|PTR||Pointer to a canonical name.
Mostly used for implementing reverse DNS lookups
|SOA||Authoritative information about a DNS zone||see below|
|TXT||Text record||see below|
By default, host command looks for A, AAAA, and MX records only.
Let us see how to use host command on Linux and Unix. You need to give a hostname or an IP address as an argument to get various information about that host. Open the Terminal applications and type the following commands.
To find the address of a host machine called wks05, run:
cyberciti.biz has address 192.168.1.5
To show the address of a for the domain named google.com or cyberciti.biz, type:
www.cyberciti.biz has address 184.108.40.206 www.cyberciti.biz has IPv6 address 2607:f0d0:1002:51::4
To find the host whose address is 192.168.1.254, type:
254.1.168.192.in-addr.arpa domain name pointer router.localdomain.
In this example, find the domain name whois address is 220.127.116.11, run:
18.104.22.168.in-addr.arpa domain name pointer www.cyberciti.biz.
Pass the -t option as follows to specifies the query type:
host -t query Hostname|IPAddress
To query NS record type for the domain cyberciti.biz, enter:
host -t ns cyberciti.biz
cyberciti.biz name server ns-1075.awsdns-06.org. cyberciti.biz name server ns-1947.awsdns-51.co.uk. cyberciti.biz name server ns-243.awsdns-30.com. cyberciti.biz name server ns-866.awsdns-44.net.
To query CNAME record type, type
host -t CNAME s0.cyberciti.org
host -t CNAME s0.cyberciti.org
To query SOA record type for the domain, enter
host -t SOA cyberciti.biz
cyberciti.biz has SOA record ns-1075.awsdns-06.org. awsdns-hostmaster.amazon.com. 1 7200 900 1209600 86400
To query TXT record type for the domain, enter
host -t txt google.com
google.com descriptive text "v=spf1 include:_spf.google.com ip4:22.214.171.124/31 ip4:126.96.36.199/31 ~all"
Tip: Query of type ANY record for the domain, enter:
host -a cyberciti.biz
host -v cyberciti.biz
Pass the -C option to display the SOA records for zone name from all the listed authoritative name servers for that zone. This is useful to compare SOA records on authoritative nameservers. The syntax is:
$ host -C cyberciti.biz
Nameserver 188.8.131.52: cyberciti.biz has SOA record ns-1075.awsdns-06.org. awsdns-hostmaster.amazon.com. 1 7200 900 1209600 86400 Nameserver 184.108.40.206: cyberciti.biz has SOA record ns-1075.awsdns-06.org. awsdns-hostmaster.amazon.com. 1 7200 900 1209600 86400 Nameserver 220.127.116.11: cyberciti.biz has SOA record ns-1075.awsdns-06.org. awsdns-hostmaster.amazon.com. 1 7200 900 1209600 86400 Nameserver 18.104.22.168: cyberciti.biz has SOA record ns-1075.awsdns-06.org. awsdns-hostmaster.amazon.com. 1 7200 900 1209600 86400
By default, host command will use UDP protocol when making queries. Pass the -T option to use a TCP connection when querying the name server. This is useful to see if the name server works over TCP and firewall is allowing queries over the TCP:
host -T IPAddress
host -T cyberciti.biz
host -a -T google.com
Specifies number of retries for UDP packets
If you are on unraialbe network, you can set retry number for packats. In this example, try to find out the IP address of the domain called example.com in three retries:
host -t a -R 3 example.com
To use IPv4 query transport only pass the -4 option to the host command:
host -4 IP|Host
host -4 example.com
To use IPv6 query transport only pass the -6 option to the host command. This is useful to test if your IPv6 enabled name servers are working or not:
host -6 IP|Host
host -6 example.com
Pass the -l option to list all hostnames and server in a domain. This only works if you are making query from a slave (secondary) and/or from master dns server IP address only. As a dns server admin you can get the list of all hosts in a domain without opening a zone file:
# Note must be on slave/master server where AXFR is alowed ##
host -l example.com
Please note that the AXFR is a special resource record type. It is used for Authoritative Zone Transfer i.e. transfer entire zone file from the master name server to secondary name servers.
Here is the summary of all important options of the host command on Linux or Unix-like operating systems:
|-a||It is equivalent to -v -t ANY options.|
|-c||Specifies query class for non-IN data|
|-C||Compares SOA records on authoritative nameservers|
|-d||It is equivalent to -v|
|-l||Lists all hosts in a domain, using AXFR|
|-i||IP6.INT reverse lookups|
|-N||Changes the number of dots allowed before root lookup is done|
|-r||Disables recursive processing|
|-R||Specifies number of retries for UDP packets|
|-s||A SERVFAIL response should stop query|
|-t||Specifies the query type|
|-T||Enables TCP/IP mode|
|-v||Enables verbose output|
|-w||Specifies to wait forever for a reply|
|-W||Specifies how long to wait for a reply|
|-4||Use IPv4 query transport only|
|-6||Use IPv6 query transport only|
|-m||Set memory debugging flag (trace|record|usage)|
This tutorials is also available in a quick video format:
- host(1) command man page
- Resource Record (RR) TYPEs