top of page
Writer's pictureUzair Ansari

Configure DNS suffix search order using PowerShell

In the realm of networking, Domain Name System (DNS) plays a crucial role in translating human-readable domain names into IP addresses. However, navigating the DNS landscape becomes even more efficient when we harness the power of DNS domain suffix search lists. These lists extend and refine DNS search capabilities, allowing users to explore short, unqualified computer names across multiple specified DNS domains. In this blog post, we'll delve into the significance of DNS domain suffixes and guide you through the steps of configuring them on a client machine.



You have the option to set up a DNS domain suffix search list for DNS client machines, enhancing and modifying their search capabilities. By including suffixes in this list, you can explore short, unqualified computer names across multiple specified DNS domains. In the event of a failed DNS query, the DNS Client service can utilize this list to add additional name suffix endings to the original name. Subsequently, it will reattempt DNS queries to the DNS server using these alternate, fully qualified domain names.




Understanding DNS Domain Suffix Search Lists

The DNS domain suffix search list serves as a valuable tool for enhancing the efficiency of DNS queries. By adding suffixes to this list, users can broaden their search for unqualified computer names, making it possible to traverse through various specified DNS domains. This proves particularly useful in scenarios where a DNS query fails to yield the desired results.



Why You Should Care

Imagine a scenario where you're trying to access a resource on a network by referring to a short, unqualified computer name. Without a DNS domain suffix search list, your query might hit a dead end if the DNS server is not configured to recognize the unqualified name. However, with a well-configured suffix list, the DNS Client service can intelligently append different name suffix endings to your original query. This iterative approach increases the chances of successfully resolving the resource's fully qualified domain name.



Configuring DNS Suffixes on Your Client Machine

Now, let's explore the steps to configure DNS domain suffixes on a client machine. Follow these simple steps to enhance your DNS search capabilities:



  • Manually setting DNS suffix search order:


Access Network Connection Properties:

Open the Network and Sharing Center on your Windows machine. Navigate to the "Change adapter settings" option.


Choose Your Network Connection:

Right-click on the network connection you're using and select "Properties."


Access TCP/IPv4 Properties:

Locate the "Internet Protocol Version 4 (TCP/IPv4)" option and click on "Properties."


Navigate to Advanced Settings:

In the TCP/IPv4 Properties window, click the "Advanced" button.


Configure DNS Suffixes:

In the Advanced TCP/IP Settings window, go to the "DNS" tab. Here, you can add DNS suffixes in the "Append these DNS suffixes (in order)" field. Simply click "Add" and enter the desired suffixes.


Order Your Suffixes:

The order of suffixes matters. The DNS Client service will prioritize suffixes from top to bottom. You can use the "Move Up" and "Move Down" buttons to adjust the order.


Apply Changes:

Click "OK" in each open window to apply the changes and close the configuration panels.




  • Using PowerShell to set DNS suffix search order:


# 1. Create an empty array list to build DNS suffix list
[System.Collections.ArrayList]$SuffixList = @()

# 2. Retrieve existing DNS suffix list and add it to the array list
Get-CimInstance -Class win32_networkadapterconfiguration | select -ExpandProperty dnsdomainsuffixsearchorder | select -Unique | %{$SuffixList += $_}

# 2. Add your desired DNS suffix to the array list
"example.com", "internal.com" | %{$SuffixList += $_}

# 3. Convert to the suffix list into string so that in the subsequent step it can be converted into array type.
$SuffixString = ""
foreach ($Suffix in $SuffixList){
    $SuffixString += "$suffix,"
}
$SuffixString = $SuffixString.TrimEnd(",")

# 4. Convert the suffix list into Array (The acceptable type required in the next step)
$NewSuffixList = @($SuffixString)


# 5. Use the Array object of DNS suffix list created in the previous step to set DNS suffix search order.
Invoke-CimMethod -ClassName win32_networkadapterconfiguration -MethodName "SetDNSSuffixSearchOrder" -Arguments @{
    DNSDomainSuffixSearchOrder=$NewSuffixList
}


By following these steps, you empower your client machine with an extended DNS search capability, making it adept at resolving unqualified computer names across specified domains.



In conclusion, the strategic use of DNS domain suffix search lists elevates your network navigation experience. It's a simple yet powerful technique that enhances the efficiency of DNS queries and ensures smoother access to resources within your network. Take control of your DNS configuration today and optimize your connectivity.

840 views0 comments

Recent Posts

See All
bottom of page