Guidance for configuring IPv6 in Windows for avant-garde users

Windows Vista, Windows Server 2008, and later versions of Windows implement RFC 3484 and use a prefix table to decide which address to use when multiple addresses are available for a Domain Name System (DNS) name.

By default, Windows favors IPv6 global unicast addresses over IPv4 addresses.

Applies to: Windows 10 - all editions, Windows Server 2019, Windows Server 2016, Windows Server 2012 R2
Original KB number: 929852

Summary

Information technology is common for It administrators to disable IPv6 to troubleshoot networking-related issues such as name resolution issues.

Important

Internet Protocol version vi (IPv6) is a mandatory function of Windows Vista and Windows Server 2008 and newer versions. We do non recommend that you disable IPv6 or its components. If you lot practice, some Windows components may not function.

We recommend using Prefer IPv4 over IPv6 in prefix policies instead of disabling IPV6.

Utilize registry key to configure IPv6

Important

Follow the steps in this department carefully. Serious bug might occur if you lot modify the registry incorrectly. Before yous modify it, support the registry for restoration in instance bug occur.

The IPv6 functionality can be configured past modifying the post-obit registry cardinal:

Location: HKEY_LOCAL_MACHINE\Organisation\CurrentControlSet\Services\Tcpip6\Parameters\
Name: DisabledComponents
Type: REG_DWORD
Min Value: 0x00 (default value)
Max Value: 0xFF (IPv6 disabled)

IPv6 Functionality Registry value and comments
Prefer IPv4 over IPv6 Decimal 32
Hexadecimal 0x20
Binary xx1x xxxx

Recommended instead of disabling IPv6.

Disable IPv6 Decimal 255
Hexadecimal 0xFF
Binary 1111 1111

See startup filibuster occurs after you disable IPv6 in Windows if you encounter startup delay after disabling IPv6 in Windows vii SP1 or Windows Server 2008 R2 SP1.

Additionally, system startup will be delayed for v seconds if IPv6 is disabled by incorrectly, setting the DisabledComponents registry setting to a value of 0xffffffff. The correct value should be 0xff. For more information, see Internet Protocol Version half dozen (IPv6) Overview.

The DisabledComponents registry value doesn't affect the state of the check box. Even if the DisabledComponents registry key is set to disable IPv6, the check box in the Networking tab for each interface tin be checked. This is an expected behavior.

You cannot completely disable IPv6 as IPv6 is used internally on the arrangement for many TCPIP tasks. For example, y'all volition still be able to run ping ::i subsequently configuring this setting.

Disable IPv6 on all nontunnel interfaces Decimal 16
Hexadecimal 0x10
Binary xxx1 xxxx
Disable IPv6 on all tunnel interfaces Decimal i
Hexadecimal 0x01
Binary xxxx xxx1
Disable IPv6 on all nontunnel interfaces (except the loopback) and on IPv6 tunnel interface Decimal 17
Hexadecimal 0x11
Binary xxx1 xxx1
Prefer IPv6 over IPv4 Binary xx0x xxxx
Re-enable IPv6 on all nontunnel interfaces Binary xxx0 xxxx
Re-enable IPv6 on all tunnel interfaces Binary 30 xxx0
Re-enable IPv6 on nontunnel interfaces and on IPv6 tunnel interfaces Binary xxx0 xxx0

Note

  • Administrators must create an .admx file to expose the registry settings of below tabular array in a Group Policy setting.
  • You must restart your figurer for these changes to take effect.
  • Values other than 0 or 32 causes the Routing and Remote Admission service to fail subsequently this modify takes event.

By default, the 6to4 tunneling protocol is enabled in Windows when an interface is assigned a public IPv4 address (Public IPv4 address means whatever IPv4 address that isn't in the ranges ten.0.0.0/8, 172.16.0.0/12, or 192.168.0.0/xvi). 6to4 automatically assigns an IPv6 address to the 6to4 tunneling interface for each address, and 6to4 dynamically registers these IPv6 addresses on the assigned DNS server. If this behavior isn't desired, we recommend disabling the IPv6 tunnel interfaces on the affected hosts.

You can besides follow these steps to modify the registry key:

  1. Open an authoritative Command Prompt window.

  2. Run the post-obit command:

                      reg add "HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip6\Parameters" /v DisabledComponents /t REG_DWORD /d <value> /f                                  

    Note

    Supplant the <value> with the respective value.

How to summate the registry value

Windows employ bitmasks to cheque the DisabledComponents values and determine whether a component should be disabled.

To learn which component each bit (from depression to loftier) controls, refer to the following table.

Name Setting
Tunnel Disable tunnel interfaces
Tunnel6to4 Disable 6to4 interfaces
TunnelIsatap Disable Isatap interfaces
Tunnel Teredo Disable Teredo interfaces
Native Disable native interfaces (likewise PPP)
PreferIpv4 Prefer IPv4 in default prefix policy
TunnelCp Disable CP interfaces
TunnelIpTls Disable IP-TLS interfaces

For each scrap, 0 means false and 1 means true. Refer to the following table for an example.

Setting Prefer IPv4 over IPv6 in prefix policies Disable IPv6 on all nontunnel interfaces Disable IPv6 on all tunnel interfaces Disable IPv6 on nontunnel interfaces (except the loopback) and on IPv6 tunnel interface
Disable tunnel interfaces 0 0 1 one
Disable 6to4 interfaces 0 0 0 0
Disable Isatap interfaces 0 0 0 0
Disable Teredo interfaces 0 0 0 0
Disable native interfaces (as well PPP) 0 one 0 1
Prefer IPv4 in default prefix policy. 1 0 0 0
Disable CP interfaces 0 0 0 0
Disable IP-TLS interfaces 0 0 0 0
Binary 0010 0000 0001 0000 0000 0001 0001 0001
Hexadecimal 0x20 0x10 0x01 0x11

Using the network properties GUI to disable IPv6 is not supported

This registry value doesn't bear on the state of the following check box. Fifty-fifty if the registry fundamental is ready to disable IPv6, the bank check box in the Networking tab for each interface can be selected. This is an expected behavior.

The Internet Protocol Version 6 (TCP/IPv6) option in Network properties.

Reference

For more information about RFC 3484, see Default Address Selection for Cyberspace Protocol version six (IPv6).

For more information nearly how to set IPv4 precedence over IPv6, see Using SIO_ADDRESS_LIST_SORT.

For data about RFC 4291, come across IP Version half dozen Addressing Architecture.

For more information about the related issues, run across the articles below:

  • Example i: On Domain Controllers, you might meet where LDAP over UDP 389 will stop working. See How to use Portqry to troubleshoot Active Directory connectivity problems
  • Instance 2: Exchange Server 2010, you might run into issues where Exchange will stop working. See Arguments against disabling IPv6 and Disabling IPv6 And Exchange – Going All The Way.
  • Case three: Failover Clusters See What is a Microsoft Failover Cluster Virtual Adapter anyway? and Failover Clustering and IPv6 in Windows Server 2012 R2.

Tools to help with network trace: Microsoft Network Monitor 3.four (archive)

Warning

Netmon 3.four isn't compatible with Windows Server 2012 or newer Os when LBFO NIC teaming is enabled. Utilise Message Analyzer instead.