- Table of Contents
- 
                        - 05-Layer 3 - IP Services Configuration Guide
- 00-Preface
- 01-ARP configuration
- 02-IP addressing configuration
- 03-DHCP configuration
- 04-DNS configuration
- 05-IP forwarding basics configuration
- 06-Fast forwarding configuration
- 07-Adjacency table configuration
- 08-IRDP configuration
- 09-IP performance optimization configuration
- 10-UDP Helper configuration
- 11-IPv6 basics configuration
- 12-DHCPv6 configuration
- 13-IPv6 fast forwarding configuration
- 14-Tunneling configuration
- 15-GRE configuration
 
- Related Documents
- 
                        
| Title | Size | Download | 
|---|---|---|
| 12-DHCPv6 configuration | 429.23 KB | 
DHCPv6 address/prefix assignment
Rapid assignment involving two messages
Assignment involving four messages
IPv6 address/prefix allocation sequence·
Configuring IPv6 prefix assignment
Configuring IPv6 address assignment
Configuring network parameters assignment
Configuring network parameters in a DHCPv6 address pool
Configuring network parameters in a DHCPv6 option group
Configuring the DHCPv6 server on an interface
Setting the DSCP value for DHCPv6 packets sent by the DHCPv6 server
Displaying and maintaining the DHCPv6 server
DHCPv6 server configuration examples
Dynamic IPv6 prefix assignment configuration example
Dynamic IPv6 address assignment configuration example
Configuring the DHCPv6 relay agent
DHCPv6 relay agent configuration task list
Enabling the DHCPv6 relay agent on an interface
Specifying DHCPv6 servers on the relay agent
Setting the DSCP value for DHCPv6 packets sent by the DHCPv6 relay agent
Displaying and maintaining the DHCPv6 relay agent
DHCPv6 relay agent configuration example
Configuration restrictions and guidelines
DHCPv6 client configuration task list
Configuring IPv6 address acquisition·
Configuring IPv6 prefix acquisition
Setting the DSCP value for DHCPv6 packets sent by the DHCPv6 client
Configuring the DHCPv6 client DUID
Displaying and maintaining DHCPv6 client
DHCPv6 client configuration examples
IPv6 address acquisition configuration example
IPv6 prefix acquisition configuration example
Stateless DHCPv6 configuration example
Application of trusted and untrusted ports
H3C implementation of Option 18 and Option 37
DHCPv6 snooping support for Option 37
DHCPv6 snooping configuration task list
Configuring basic DHCPv6 snooping
Configuring Option 18 and Option 37
Configuring DHCPv6 snooping entry auto backup
Setting the maximum number of DHCPv6 snooping entries
Configuring DHCPv6 packet rate limit
Enabling DHCPv6-REQUEST check·
Configuring a DHCPv6 packet blocking port
Enabling DHCPv6 snooping logging
Displaying and maintaining DHCPv6 snooping
DHCPv6 snooping configuration example
DHCPv6 overview
DHCPv6 address/prefix assignment
An address/prefix assignment process involves two or four messages.
Rapid assignment involving two messages
As shown in Figure 1, rapid assignment operates in the following steps:
1. The DHCPv6 client sends to the DHCPv6 server a Solicit message that contains a Rapid Commit option to prefer rapid assignment.
2. If the DHCPv6 server supports rapid assignment, it responds with a Reply message containing the assigned IPv6 address/prefix and other configuration parameters. If the DHCPv6 server does not support rapid assignment, Assignment involving four messages is performed.
Figure 1 Rapid assignment involving two messages

Assignment involving four messages
As shown in Figure 2, four-message assignment operates using the following steps:
1. The DHCPv6 client sends a Solicit message to request an IPv6 address/prefix and other configuration parameters.
2. The DHCPv6 server responds with an Advertise message that contains the assignable address/prefix and other configuration parameters if either of the following conditions exists:
¡ The Solicit message does not contain a Rapid Commit option.
¡ The DHCPv6 server does not support rapid assignment even though the Solicit message contains a Rapid Commit option.
3. The DHCPv6 client might receive multiple Advertise messages offered by different DHCPv6 servers. It selects an offer according to the receiving sequence and server priority, and sends a Request message to the selected server for confirmation.
4. The DHCPv6 server sends a Reply message to the client, confirming that the address/prefix and other configuration parameters are assigned to the client.
Figure 2 Assignment involving four messages

Address/prefix lease renewal
An IPv6 address/prefix assigned by a DHCPv6 server has a valid lifetime. After the valid lifetime expires, the DHCPv6 client cannot use the IPv6 address/prefix. To use the IPv6 address/prefix, the DHCPv6 client must renew the lease time.
Figure 3 Using the Renew message for address/prefix lease renewal

As shown in Figure 3, at T1, the DHCPv6 client sends a Renew message to the DHCPv6 server. The recommended value of T1 is half the preferred lifetime. The DHCPv6 server responds with a Reply message, informing the client whether the lease is renewed.
Figure 4 Using the Rebind message for address/prefix lease renewal

As shown in Figure 4:
· If the DHCPv6 client does not receive a response from the DHCPv6 server after sending a Renew message at T1, it multicasts a Rebind message to all DHCPv6 servers at T2. Typically, the value of T2 is 0.8 times the preferred lifetime.
· The DHCPv6 server responds with a Reply message, informing the client whether the lease is renewed.
· If the DHCPv6 client does not receive a response from any DHCPv6 server before the valid lifetime expires, the client stops using the address/prefix.
For more information about the valid lifetime and the preferred lifetime, see "Configuring basic IPv6 settings."
Stateless DHCPv6
Stateless DHCPv6 enables a device that has obtained an IPv6 address/prefix to get other configuration parameters from a DHCPv6 server.
The device performs stateless DHCPv6 if an RA message with the following flags is received from the router during stateless address autoconfiguration:
· The managed address configuration flag (M flag) is set to 0.
· The other stateful configuration flag (O flag) is set to 1.
For more information about stateless address autoconfiguration, see "Configuring basic IPv6 settings."
Figure 5 Stateless DHCPv6 operation

As shown in Figure 5, stateless DHCPv6 operates in the following steps:
1. The DHCPv6 client sends an Information-request message to the multicast address of all DHCPv6 servers and DHCPv6 relay agents. The Information-request message contains an Option Request option that specifies the requested configuration parameters.
2. The DHCPv6 server returns to the client a Reply message containing the requested configuration parameters.
3. The client checks the Reply message. If the obtained configuration parameters match those requested in the Information-request message, the client uses these parameters to complete configuration. If not, the client ignores the configuration parameters. If the client receives multiple replies with configuration parameters matching those requested in the Information-request message, it uses the first received reply.
Protocols and standards
· RFC 3736, Stateless Dynamic Host Configuration Protocol (DHCP) Service for IPv6
· RFC 3315, Dynamic Host Configuration Protocol for IPv6 (DHCPv6)
· RFC 2462, IPv6 Stateless Address Autoconfiguration
· RFC 3633, IPv6 Prefix Options for Dynamic Host Configuration Protocol (DHCP) version 6
Configuring the DHCPv6 server
Overview
IPv6 address assignment
As shown in Figure 6, the DHCPv6 server assigns IPv6 addresses, domain name suffixes, DNS server addresses, and other configuration parameters to DHCPv6 clients.
The IPv6 addresses assigned to the clients include the following types:
· Temporary IPv6 addresses—Frequently changed without lease renewal.
· Non-temporary IPv6 addresses—Correctly used by DHCP clients, with lease renewal.
Figure 6 IPv6 address assignment

IPv6 prefix assignment
As shown in Figure 7, the DHCPv6 server assigns an IPv6 prefix to the DHCPv6 client. The client advertises the prefix information in a multicast RA message so that hosts on the subnet can automatically configure their IPv6 addresses by using the prefix.
Figure 7 IPv6 prefix assignment

Concepts
Multicast addresses used by DHCPv6
DHCPv6 uses the multicast address FF05::1:3 to identify all site-local DHCPv6 servers. It uses the multicast address FF02::1:2 to identify all link-local DHCPv6 servers and relay agents.
DUID
A DHCP unique identifier (DUID) uniquely identifies a DHCPv6 device (DHCPv6 client, server, or relay agent). A DHCPv6 device adds its DUID in a sent packet.
Figure 8 DUID-LL format

The device supports the DUID format based on link-layer address (DUID-LL) defined in RFC 3315. Figure 8 shows the DUID-LL format, which includes the following fields:
· DUID type—The device supports the DUID type of DUID-LL with the value of 0x0003.
· Hardware type—The device supports the hardware type of Ethernet with the value of 0x0001.
· Link layer address—Takes the value of the bridge MAC address of the device.
IA
Identified by an IAID, an identity association (IA) provides a construct through which a client manages the obtained addresses, prefixes, and other configuration parameters. A client can have multiple IAs, for example, one for each of its interfaces.
IAID
An IAID uniquely identifies an IA. It is chosen by the client and must be unique on the client.
PD
The DHCPv6 server creates a prefix delegation (PD) for each assigned prefix to record the following details:
· IPv6 prefix.
· Client DUID.
· IAID.
· Valid lifetime.
· Preferred lifetime.
· Lease expiration time.
· IPv6 address of the requesting client.
DHCPv6 address pool
The DHCP server selects IPv6 addresses, IPv6 prefixes, and other parameters from an address pool, and assigns them to the DHCP clients.
Address allocation mechanisms
DHCPv6 supports the following address allocation mechanisms:
· Static address allocation—To implement static address allocation for a client, create a DHCPv6 address pool, and manually bind the DUID and IAID of the client to an IPv6 address in the DHCPv6 address pool. When the client requests an IPv6 address, the DHCPv6 server assigns the IPv6 address in the static binding to the client.
· Dynamic address allocation—To implement dynamic address allocation for clients, create a DHCPv6 address pool, specify a subnet for the pool, and divide the subnet into temporary and non-temporary IPv6 address ranges. Upon receiving a DHCP request, the DHCPv6 server selects an IPv6 address from the temporary or non-temporary IPv6 address range based on the address type in the client request.
Prefix allocation mechanisms
DHCPv6 supports the following prefix allocation mechanisms:
· Static prefix allocation—To implement static prefix allocation for a client, create a DHCPv6 address pool, and manually bind the DUID and IAID of the client to an IPv6 prefix in the DHCPv6 address pool. When the client requests an IPv6 prefix, the DHCPv6 server assigns the IPv6 prefix in the static binding to the client.
· Dynamic prefix allocation—To implement dynamic prefix allocation for clients, create a DHCPv6 address pool and a prefix pool, specify a subnet for the address pool, and apply the prefix pool to the address pool. Upon receiving a DHCP request, the DHCPv6 server dynamically selects an IPv6 prefix from the prefix pool in the address pool.
Address pool selection
The DHCPv6 server observes the following principles when selecting an IPv6 address or prefix for a client:
1. If there is an address pool where an IPv6 address is statically bound to the DUID or IAID of the client, the DHCPv6 server selects this address pool. It assigns the statically bound IPv6 address or prefix and other configuration parameters to the client.
2. If the receiving interface has an address pool applied, the DHCP server selects an IPv6 address or prefix and other configuration parameters from this address pool.
3. If no static address pool is configured and no address pool is applied to the receiving interface, the DHCPv6 server selects an address pool depending on the client location.
¡ Client on the same subnet as the server—The DHCPv6 server compares the IPv6 address of the receiving interface with the subnets of all address pools. It selects the address pool with the longest-matching subnet.
¡ Client on a different subnet than the server—The DHCPv6 server compares the IPv6 address of the DHCPv6 relay agent interface closest to the client with the subnets of all address pools. It also selects the address pool with the longest-matching subnet.
To make sure IPv6 address allocation functions correctly, keep the subnet used for dynamic assignment consistent with the subnet where the interface of the DHCPv6 server or DHCPv6 relay agent resides.
IPv6 address/prefix allocation sequence
The DHCPv6 server selects an IPv6 address/prefix for a client in the following sequence:
1. IPv6 address/prefix statically bound to the client's DUID and IAID and expected by the client.
2. IPv6 address/prefix statically bound to the client's DUID and IAID.
3. IPv6 address/prefix statically bound to the client's DUID and expected by the client.
4. IPv6 address/prefix statically bound to the client's DUID.
5. IPv6 address/prefix that was ever assigned to the client.
6. Assignable IPv6 address/prefix in the address pool/prefix pool expected by the client.
7. Assignable IPv6 address/prefix in the address pool/prefix pool.
8. IPv6 address/prefix that was a conflict or passed its lease duration. If no IPv6 address/prefix is assignable, the server does not respond.
If a client moves to another subnet, the DHCPv6 server selects an IPv6 address/prefix from the address pool that matches the new subnet.
Conflicted IPv6 addresses can be assigned to other DHCPv6 clients only after the addresses are in conflict for one hour.
Configuration task list
| Tasks at a glance | 
| (Optional.) Perform the following tasks: · Configuring IPv6 prefix assignment | 
| (Required.) Configuring the DHCPv6 server on an interface | 
| (Optional.) Setting the DSCP value for DHCPv6 packets sent by the DHCPv6 server | 
Configuring IPv6 prefix assignment
Use the following methods to configure IPv6 prefix assignment:
· Configure a static IPv6 prefix binding in an address pool—If you bind a DUID and an IAID to an IPv6 prefix, the DUID and IAID in a request must match those in the binding before the DHCPv6 server can assign the IPv6 prefix to the DHCPv6 client. If you only bind a DUID to an IPv6 prefix, the DUID in the request must match the DUID in the binding before the DHCPv6 server can assign the IPv6 prefix to the DHCPv6 client.
· Apply a prefix pool to an address pool—The DHCPv6 server dynamically assigns an IPv6 prefix from the prefix pool in the address pool to a DHCPv6 client.
Configuration guidelines
· An IPv6 prefix can be bound to only one DHCPv6 client. You cannot modify bindings that have been created. To change the binding for a DHCPv6 client, you must delete the existing binding first.
· Only one prefix pool can be applied to an address pool. You cannot modify prefix pools that have been applied. To change the prefix pool for an address pool, you must remove the prefix pool application first.
· You can apply a prefix pool that has not been created to an address pool. The setting takes effect after the prefix pool is created.
Configuration procedure
To configure IPv6 prefix assignment:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. (Optional.) Specify the IPv6 prefixes excluded from dynamic assignment. | ipv6 dhcp server forbidden-prefix start-prefix/prefix-len [ end-prefix/prefix-len ] | By default, no IPv6 prefixes in the prefix pool are excluded from dynamic assignment. If the excluded IPv6 prefix is in a static binding, the prefix still can be assigned to the client. To exclude multiple IPv6 prefix ranges, repeat this step. | 
| 3. Create a prefix pool. | ipv6 dhcp prefix-pool prefix-pool-number prefix prefix/prefix-len assign-len assign-len | This step is required for dynamic prefix assignment. By default, no prefix pool is configured. | 
| 4. Create a DHCPv6 address pool and enter its view. | ipv6 dhcp pool pool-name | By default, no DHCPv6 address pool is configured. | 
| 5. Specify an IPv6 subnet for dynamic assignment. | network prefix/prefix-length [ preferred-lifetime preferred-lifetime valid-lifetime valid-lifetime ] | By default, no IPv6 subnet is specified for dynamic assignment. | 
| 6. Configure static prefix assignment, dynamic prefix assignment, or both. | ·     Configure a static prefix binding: ·     Apply the prefix pool to the address pool: | By default, static or dynamic prefix assignment is not configured for an address pool. To add multiple static IPv6 prefix bindings, use the static-bind prefix command multiple times. | 
Configuring IPv6 address assignment
Use one of the following methods to configure IPv6 address assignment:
· Configure a static IPv6 address binding in an address pool.
If you bind a DUID and an IAID to an IPv6 address, the DUID and IAID in a request must match those in the binding before the DHCPv6 server can assign the IPv6 address to the requesting client. If you only bind a DUID to an IPv6 address, the DUID in a request must match the DUID in the binding before the DHCPv6 server can assign the IPv6 address to the requesting client.
· Specify a subnet and address ranges in an address pool.
¡ Non-temporary address assignment—The server selects addresses from the non-temporary address range specified by the address range command. If no non-temporary address range is specified, the server selects addresses on the subnet specified by the network command.
¡ Temporary address assignment—The server selects addresses from the temporary address range specified by the temporary address range command. If no temporary address range is specified in the address pool, the DHCPv6 server cannot assign temporary addresses to clients.
Configuration guidelines
· You can specify only one non-temporary address range and one temporary address range in an address pool.
· The address ranges specified by the address range and temporary address range commands must be on the subnet specified by the network command. Otherwise, the addresses are unassignable.
· Only one prefix pool can be applied to an address pool. You can apply a prefix pool that has not been created to an address pool. The setting takes effect after the prefix pool is created.
· An IPv6 address can be bound to only one DHCPv6 client. You cannot modify bindings that have been created. To change the binding for a DHCPv6 client, you must delete the existing binding first.
· Only one subnet can be specified in an address pool. If you use the network command multiple times in a DHCPv6 address pool, the most recent configuration takes effect. If you use this command to specify only new lifetimes, the settings do not affect existing leases. The IPv6 addresses assigned after the modification will use the new lifetimes.
Configuration procedure
To configure IPv6 address assignment:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. (Optional.) Specify the IPv6 addresses excluded from dynamic assignment. | ipv6 dhcp server forbidden-address start-ipv6-address [ end-ipv6-address ] | By default, all IPv6 addresses except for the DHCPv6 server's IP address in a DHCPv6 address pool are assignable. If the excluded IPv6 address is in a static binding, the address still can be assigned to the client. To exclude multiple IPv6 prefix ranges, repeat this step. | 
| 3. Create a DHCPv6 address pool and enter its view. | ipv6 dhcp pool pool-name | By default, no DHCPv6 address pool is configured. | 
| 4. Specify an IPv6 subnet for dynamic assignment. | network prefix/prefix-length [ preferred-lifetime preferred-lifetime valid-lifetime valid-lifetime ] | By default, no IPv6 address subnet is specified. You cannot use this command to configure the same subnet in different address pools. | 
| 5. (Optional.) Specify a non-temporary IPv6 address range. | address range start-ipv6-address end-ipv6-address [ preferred-lifetime preferred-lifetime valid-lifetime valid-lifetime ] | By default, no non-temporary IPv6 address range is specified, and all unicast addresses on the subnet are assignable. | 
| 6. (Optional.) Specify a temporary IPv6 address range. | temporary address range start-ipv6-address end-ipv6-address [ preferred-lifetime preferred-lifetime valid-lifetime valid-lifetime ] | By default, no temporary IPv6 address range is specified, and the DHCPv6 server cannot assign temporary IPv6 addresses. | 
| 7. (Optional.) Create a static binding. | static-bind address ipv6-address/addr-prefix-length | duid duid [ iaid iaid ] [ preferred-lifetime preferred-lifetime valid-lifetime valid-lifetime ] | By default, no static binding is configured. To add more static bindings, repeat this step. | 
Configuring network parameters assignment
In addition to IPv6 prefixes and IPv6 addresses, you can configure up to eight DNS server addresses, one domain name suffix, eight SIP server addresses, and eight SIP server domain names in an address pool.
You can configure network parameters on a DHCPv6 server by using one of the following methods:
· Configure network parameters in a DHCPv6 address pool.
· Configure network parameters in a DHCPv6 option group, and reference the option group in a DHCPv6 address pool.
Network parameters configured in a DHCPv6 address pool take precedence over those configured in a DHCPv6 option group.
Configuring network parameters in a DHCPv6 address pool
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Create a DHCPv6 address pool and enter its view. | ipv6 dhcp pool pool-name | By default, no DHCPv6 address pool exists on the DHCPv6 server. | 
| 3. Specify an IPv6 subnet for dynamic assignment. | network prefix/prefix-length [ preferred-lifetime preferred-lifetime valid-lifetime valid-lifetime ] | By default, no IPv6 subnet is specified. | 
| 4. (Optional.) Specify a DNS server address. | dns-server ipv6-address | By default, no DNS server address is specified. | 
| 5. (Optional.) Specify a domain name suffix. | domain-name domain-name | By default, no domain name suffix is specified. | 
| 6. (Optional.) Specify a SIP server address or domain name. | sip-server { address ipv6-address | domain-name domain-name } | By default, no SIP server address or domain name is specified. | 
| 7. (Optional.) Configure a self-defined DHCPv6 option. | option code hex hex-string | By default, no self-defined DHCPv6 option is configured. | 
Configuring network parameters in a DHCPv6 option group
A DHCPv6 option group can be created by using the following methods:
· Create a static DHCPv6 option group by using the ipv6 dhcp option-group command.
· When the device acts as a DHCPv6 client, it automatically creates a dynamic DHCPv6 option group for saving the obtained parameters. For more information about creating a dynamic DHCPv6 option group, see "Configuring the DHCPv6 client."
To create a static DHCPv6 option group:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Create a static DHCPv6 option group and enter its view. | ipv6 dhcp option-group option-group-number | By default, no static DHCPv6 option group exists on the DHCPv6 server. | 
| 3. (Optional.) Specify a DNS server address. | dns-server ipv6-address | By default, no DNS server address is specified. | 
| 4. (Optional.) Specify a domain name suffix. | domain-name domain-name | By default, no domain name suffix is specified. | 
| 5. (Optional.) Specify a SIP server address or domain name. | sip-server { address ipv6-address | domain-name domain-name } | By default, no SIP server address or domain name is specified. | 
| 6. (Optional.) Configure a self-defined DHCPv6 option. | option code hex hex-string | By default, no self-defined DHCPv6 option is configured. | 
Configuring the DHCPv6 server on an interface
Enable the DHCP server and configure one of the following address/prefix assignment methods on an interface:
· Apply an address pool on the interface—The DHCPv6 server selects an IPv6 address/prefix from the applied address pool for a requesting client. If there is no assignable IPv6 address/prefix in the address pool, the DHCPv6 server cannot to assign an IPv6 address/prefix to a client.
· Configure global address assignment on the interface—The DHCPv6 server selects an IPv6 address/prefix in the global DHCPv6 address pool that matches the server interface address or the DHCPv6 relay agent address for a requesting client.
If you configure both methods on an interface, the DHCPv6 server uses the specified address pool for address assignment without performing global address assignment.
Configuration guidelines
· An interface cannot act as a DHCPv6 server and DHCPv6 relay agent at the same time.
· Do not enable DHCPv6 server and DHCPv6 client on the same interface.
· If you use the ipv6 dhcp server command multiple times, the most recent configuration takes effect.
· You can apply an address pool that has not been created to an interface. The setting takes effect after the address pool is created.
· Only one address pool can be applied to an interface. If you use the ipv6 dhcp server apply pool command multiple times, the most recent configuration takes effect.
Configuration procedure
To configure the DHCPv6 server on an interface:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | interface interface-type interface-number | N/A | 
| 3. Enable the DHCPv6 server on the interface. | ipv6 dhcp select server | By default, the interface discards DHCPv6 packets from DHCPv6 clients. | 
| 4. Configure an address/prefix assignment method. | ·     Configure global address assignment: ·     Apply a DHCPv6 address pool to the interface: | By default, desired address/prefix assignment and rapid assignment are disabled, and the default preference is 0. | 
Setting the DSCP value for DHCPv6 packets sent by the DHCPv6 server
The DSCP value of a packet specifies the priority level of the packet and affects the transmission priority of the packet.
To set the DSCP value for DHCPv6 packets sent by the DHCPv6 server:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Set the DSCP value for DHCPv6 packets sent by the DHCPv6 server. | ipv6 dhcp dscp dscp-value | By default, the DSCP value in DHCPv6 packets sent by the DHCPv6 server is 56. | 
Displaying and maintaining the DHCPv6 server
Execute display commands in any view and reset commands in user view.
| Task | Command | 
| Display the DUID of the local device. | display ipv6 dhcp duid | 
| Display information about a DHCPv6 option group. | display ipv6 dhcp option-group [ option-group-number ] | 
| Display DHCPv6 address pool information. | display ipv6 dhcp pool [ pool-name ] | 
| Display prefix pool information. | display ipv6 dhcp prefix-pool [ prefix-pool-number ] | 
| Display DHCPv6 server information on an interface. | display ipv6 dhcp server [ interface interface-type interface-number ] | 
| Display information about IPv6 address conflicts. | display ipv6 dhcp server conflict [ address ipv6-address ] | 
| Display information about expired IPv6 addresses. | display ipv6 dhcp server expired [ address ipv6-address | pool pool-name ] | 
| Display information about IPv6 address bindings. | display ipv6 dhcp server ip-in-use [ address ipv6-address | pool pool-name ] | 
| Display information about IPv6 prefix bindings. | display ipv6 dhcp server pd-in-use [ pool pool-name | prefix prefix/prefix-len ] | 
| Display packet statistics on the DHCPv6 server. | display ipv6 dhcp server statistics [ pool pool-name ] | 
| Clear information about IPv6 address conflicts. | reset ipv6 dhcp server conflict [ address ipv6-address ] | 
| Clear information about expired IPv6 address bindings. | reset ipv6 dhcp server expired [ address ipv6-address | pool pool-name ] | 
| Clear information about IPv6 address bindings. | reset ipv6 dhcp server ip-in-use [ address ipv6-address | pool pool-name ] | 
| Clear information about IPv6 prefix bindings. | reset ipv6 dhcp server pd-in-use [ pool pool-name | prefix prefix/prefix-len ] | 
| Clear packets statistics on the DHCPv6 server. | reset ipv6 dhcp server statistics | 
DHCPv6 server configuration examples
Dynamic IPv6 prefix assignment configuration example
Network requirements
As shown in Figure 9, Switch acts as a DHCPv6 server to assign an IPv6 prefix, a DNS server address, a domain name, a SIP server address, and a SIP server name to each DHCPv6 client.
The switch assigns prefix 2001:0410:0201::/48 to the client whose DUID is 00030001CA0006A40000, and assigns prefixes in the range of 2001:0410::/48 to 2001:0410:FFFF::/48 (excluding 2001:0410:0201::/48) to other clients. The DNS server address is 2::2:3. The DHCPv6 clients reside in domain aaa.com. The SIP server address is 2:2::4, and the SIP server name is bbb.com.

Configuration procedure
# Specify an IPv6 address for VLAN-interface 2.
<Switch> system-view
[Switch] interface vlan-interface 2
[Switch-Vlan-interface2] ipv6 address 1::1/64
# Disable RA message suppression on VLAN-interface 2.
[Switch-Vlan-interface2] undo ipv6 nd ra halt
# Set the M flag to 1 in RA advertisements to be sent on VLAN-interface 2. Hosts that receive the RA advertisements will obtain IPv6 addresses through DHCPv6.
[Switch-Vlan-interface2] ipv6 nd autoconfig managed-address-flag
# Set the O flag to 1 in RA advertisements to be sent on VLAN-interface 2. Hosts that receive the RA advertisements will obtain information other than IPv6 address through DHCPv6.
[Switch-Vlan-interface2] ipv6 nd autoconfig other-flag
[Switch-Vlan-interface2] quit
# Create prefix pool 1, and specify the prefix 2001:0410::/32 with the assigned prefix length 48.
[Switch] ipv6 dhcp prefix-pool 1 prefix 2001:0410::/32 assign-len 48
# Create address pool 1.
[Switch] ipv6 dhcp pool 1
# In address pool 1, configure subnet 1::/64 where VLAN interface-2 resides.
[Switch-dhcp6-pool-1] network 1::/64
# Apply prefix pool 1 to address pool 1, and set the preferred lifetime to one day, and the valid lifetime to three days.
[Switch-dhcp6-pool-1] prefix-pool 1 preferred-lifetime 86400 valid-lifetime 259200
# In address pool 1, bind prefix 2001:0410:0201::/48 to the client DUID 00030001CA0006A40000, and set the preferred lifetime to one day, and the valid lifetime to three days.
[Switch-dhcp6-pool-1] static-bind prefix 2001:0410:0201::/48 duid 00030001CA0006A40000 preferred-lifetime 86400 valid-lifetime 259200
# Configure the DNS server address 2:2::3.
[Switch-dhcp6-pool-1] dns-server 2:2::3
# Configure the domain name as aaa.com.
[Switch-dhcp6-pool-1] domain-name aaa.com
# Configure the SIP server address as 2:2::4, and the SIP server name as bbb.com.
[Switch-dhcp6-pool-1] sip-server address 2:2::4
[Switch-dhcp6-pool-1] sip-server domain-name bbb.com
[Switch-dhcp6-pool-1] quit
# Enable the DHCPv6 server on VLAN-interface 2, enable desired prefix assignment and rapid prefix assignment, and set the preference to the highest.
[Switch] interface vlan-interface 2
[Switch-Vlan-interface2] ipv6 dhcp select server
[Switch-Vlan-interface2] ipv6 dhcp server allow-hint preference 255 rapid-commit
Verifying the configuration
# Display DHCPv6 server configuration on VLAN-interface 2.
[Switch-Vlan-interface2] display ipv6 dhcp server interface vlan-interface 2
Using pool: global
Preference value: 255
Allow-hint: Enabled
Rapid-commit: Enabled
# Display information about address pool 1.
[Switch-Vlan-interface2] display ipv6 dhcp pool 1
DHCPv6 pool: 1
Network: 1::/64
Preferred lifetime 604800, valid lifetime 2592000
Prefix pool: 1
Preferred lifetime 86400, valid lifetime 259200
Static bindings:
DUID: 00030001ca0006a40000
IAID: Not configured
Prefix: 2001:410:201::/48
Preferred lifetime 86400, valid lifetime 259200
DNS server addresses:
2:2::3
Domain name:
aaa.com
SIP server addresses:
2:2::4
SIP server domain names:
bbb.com
# Display information about prefix pool 1.
[Switch-Vlan-interface2] display ipv6 dhcp prefix-pool 1
Prefix: 2001:410::/32
Assigned length: 48
Total prefix number: 65536
Available: 65535
In-use: 0
Static: 1
# After the client with the DUID 00030001CA0006A40000 obtains an IPv6 prefix, display the binding information on the DHCPv6 server.
[Switch-Vlan-interface2] display ipv6 dhcp server pd-in-use
Pool: 1
IPv6 prefix Type Lease expiration
2001:410:201::/48 Static(C) Jul 10 19:45:01 2009
# After the other client obtains an IPv6 prefix, display binding information on the DHCPv6 server.
[Switch-Vlan-interface2] display ipv6 dhcp server pd-in-use
Pool: 1
IPv6 prefix Type Lease expiration
2001:410:201::/48 Static(C) Jul 10 19:45:01 2009
2001:410::/48 Auto(C) Jul 10 20:44:05 2009
Dynamic IPv6 address assignment configuration example
Network requirements
As shown in Figure 10, Switch A acts as a DHCPv6 server to assign IPv6 addresses to the clients on subnets 1::1:0:0:0/96 and 1::2:0:0:0/96. On Switch A, configure the IPv6 address for VLAN-interface 10 and 1::2:0:0:1/96 for VLAN-interface 20. The lease duration of the addresses on subnet 1::1:0:0:0/96 is 172800 seconds (two days), the valid time is 345600 seconds (four days), the domain name suffix is aabbcc.com, and the DNS server address is 1::1:0:0:2/96. The lease duration of the addresses on subnet 1::2:0:0:0/96 is 432000 seconds (five days), the valid time is 864000 seconds (ten days), the domain name is aabbcc.com, and the DNS server address is 1::2:0:0:2/96.

Configuration procedure
1. Configure the interfaces on the DHCPv6 server:
# Specify an IPv6 address for VLAN-interface 10.
<SwitchA> system-view
[SwitchA] interface vlan-interface 10
[SwitchA-Vlan-interface10] ipv6 address 1::1:0:0:1/96
# Disable RA message suppression on VLAN-interface 10.
[SwitchA-Vlan-interface10] undo ipv6 nd ra halt
# Set the M flag to 1 in RA advertisements to be sent on VLAN-interface 10. Hosts that receive the RA advertisements will obtain IPv6 addresses through DHCPv6.
[SwitchA-Vlan-interface10] ipv6 nd autoconfig managed-address-flag
# Set the O flag to 1 in RA advertisements to be sent on VLAN-interface 10. Hosts that receive the RA advertisements will obtain information other than IPv6 address through DHCPv6.
[SwitchA-Vlan-interface10] ipv6 nd autoconfig other-flag
[SwitchA-Vlan-interface10] quit
# Specify an IPv6 address for VLAN-interface 20.
[SwitchA] interface vlan-interface 20
[SwitchA-Vlan-interface20] ipv6 address 1::2:0:0:1/96
# Disable RA message suppression on VLAN-interface 20.
[SwitchA-Vlan-interface20] undo ipv6 nd ra halt
# Set the M flag to 1 in RA advertisements to be sent on VLAN-interface 20. Hosts that receive the RA advertisements will obtain IPv6 addresses through DHCPv6.
[SwitchA-Vlan-interface20] ipv6 nd autoconfig managed-address-flag
# Set the O flag to 1 in RA advertisements to be sent on VLAN-interface 20. Hosts that receive the RA advertisements will obtain information other than IPv6 address through DHCPv6.
[SwitchA-Vlan-interface20] ipv6 nd autoconfig other-flag
[SwitchA-Vlan-interface20] quit
2. Enable DHCPv6:
# Enable DHCPv6 server on VLAN-interface 10 and VLAN-interface 20.
[SwitchA] interface vlan-interface 10
[SwitchA-Vlan-interface10] ipv6 dhcp select server
[SwitchA-Vlan-interface10] quit
[SwitchA] interface vlan-interface 20
[SwitchA-Vlan-interface20] ipv6 dhcp select server
[SwitchA-Vlan-interface20] quit
# Exclude the DNS server address from dynamic assignment.
[SwitchA] ipv6 dhcp server forbidden-address 1::1:0:0:2
[SwitchA] ipv6 dhcp server forbidden-address 1::2:0:0:2
# Configure the DHCPv6 address pool 1 to assign IPv6 addresses and other configuration parameters to clients on subnet 1::1:0:0:0/96.
[SwitchA] ipv6 dhcp pool 1
[SwitchA-dhcp6-pool-1] network 1::1:0:0:0/96 preferred-lifetime 172800 valid-lifetime 345600
[SwitchA-dhcp6-pool-1] domain-name aabbcc.com
[SwitchA-dhcp6-pool-1] dns-server 1::1:0:0:2
[SwitchA-dhcp6-pool-1] quit
# Configure the DHCPv6 address pool 2 to assign IPv6 addresses and other configuration parameters to clients on subnet 1::2:0:0:0/96.
[SwitchA] ipv6 dhcp pool 2
[SwitchA-dhcp6-pool-2] network 1::2:0:0:0/96 preferred-lifetime 432000 valid-lifetime 864000
[SwitchA-dhcp6-pool-2] domain-name aabbcc.com
[SwitchA-dhcp6-pool-2] dns-server 1::2:0:0:2
[SwitchA-dhcp6-pool-2] quit
Verifying the configuration
# Verify that the clients on subnets 1::1:0:0:0/96 and 1::2:0:0:0/96 can obtain IPv6 addresses and all other configuration parameters from the DHCPv6 server (Switch A). (Details not shown.)
# On the DHCPv6 server, display IPv6 addresses assigned to the DHCPv6 clients.
[SwitchA] display ipv6 dhcp server ip-in-use
Configuring the DHCPv6 relay agent
Overview
A DHCPv6 client usually uses a multicast address to contact the DHCPv6 server on the local link to obtain an IPv6 address and other configuration parameters. As shown in Figure 11, if the DHCPv6 server resides on another subnet, the DHCPv6 clients need a DHCPv6 relay agent to contact the server. The relay agent feature avoids deploying a DHCP server on each subnet.
Figure 11 Typical DHCPv6 relay agent application

As shown in Figure 12, a DHCPv6 client obtains an IPv6 address and other network configuration parameters from a DHCPv6 server through a DHCPv6 relay agent. The following example uses rapid assignment to describe the process:
· The DHCPv6 client sends a Solicit message containing the Rapid Commit option to the multicast address FF02::1:2 of all the DHCPv6 servers and relay agents.
· After receiving the Solicit message, the DHCPv6 relay agent encapsulates the message into the Relay Message option of a Relay-forward message, and sends the message to the DHCPv6 server.
· After obtaining the Solicit message from the Relay-forward message, the DHCPv6 server performs the following tasks:
¡ Selects an IPv6 address and other required parameters.
¡ Adds them to a reply that is encapsulated within the Relay Message option of a Relay-reply message.
¡ Sends the Relay-reply message to the DHCPv6 relay agent.
· The DHCPv6 relay agent obtains the reply from the Relay-reply message and sends the reply to the DHCPv6 client.
· The DHCPv6 client uses the IPv6 address and other network parameters assigned by the DHCPv6 server to complete network configuration.
Figure 12 Operating process of a DHCPv6 relay agent

DHCPv6 relay agent configuration task list
Enabling the DHCPv6 relay agent on an interface
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | interface interface-type interface-number | N/A | 
| 3. Enable DHCPv6 relay agent on the interface. | ipv6 dhcp select relay | By default, the DHCPv6 relay agent is disabled on the interface. Do not enable the DHCPv6 relay agent and DHCPv6 client on the same interface. | 
Specifying DHCPv6 servers on the relay agent
You can use the ipv6 dhcp relay server-address command to specify a maximum of eight DHCPv6 servers on the DHCP relay agent interface. The DHCPv6 relay agent forwards DHCP requests to all the specified DHCPv6 servers.
To specify a DHCPv6 server on a relay agent:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | interface interface-type interface-number | N/A | 
| 3. Specify a DHCPv6 server. | ipv6 dhcp relay server-address ipv6-address [ interface interface-type interface-number ] | By default, no DHCPv6 server is specified. If a DHCPv6 server address is a link-local address or multicast address, you must specify an outgoing interface by using the interface keyword in this command. Otherwise, DHCPv6 packets might fail to reach the DHCPv6 server. | 
Setting the DSCP value for DHCPv6 packets sent by the DHCPv6 relay agent
The DSCP value of a packet specifies the priority level of the packet and affects the transmission priority of the packet.
To set the DSCP value for DHCPv6 packets sent by the DHCPv6 relay agent:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Set the DSCP value for DHCPv6 packets sent by the DHCPv6 relay agent. | ipv6 dhcp dscp dscp-value | The default DSCP value is 56. | 
Displaying and maintaining the DHCPv6 relay agent
Execute display commands in any view and reset commands in user view.
| Task | Command | 
| Display the DUID of the local device. | display ipv6 dhcp duid | 
| Display DHCPv6 server addresses specified on the DHCPv6 relay agent. | display ipv6 dhcp relay server-address [ interface interface-type interface-number ] | 
| Display packet statistics on the DHCPv6 relay agent. | display ipv6 dhcp relay statistics [ interface interface-type interface-number ] | 
| Clear packets statistics on the DHCPv6 relay agent. | reset ipv6 dhcp relay statistics [ interface interface-type interface-number ] | 
DHCPv6 relay agent configuration example
Network requirements
As shown in Figure 13, configure the DHCPv6 relay agent on Switch A to relay DHCPv6 packets between DHCPv6 clients and the DHCPv6 server.
Switch A acts as the gateway of network 1::/64. It sends RA messages to notify the hosts to obtain IPv6 addresses and other configuration parameters through DHCPv6. For more information about RA messages, see "Configuring basic IPv6 settings."

Configuration procedure
# Specify IPv6 addresses for VLAN-interface 2 and VLAN-interface 3.
<SwitchA> system-view
[SwitchA] interface vlan-interface 2
[SwitchA-Vlan-interface2] ipv6 address 2::1 64
[SwitchA-Vlan-interface2] quit
[SwitchA] interface vlan-interface 3
[SwitchA-Vlan-interface3] ipv6 address 1::1 64
# Disable RA message suppression on VLAN-interface 3.
[SwitchA-Vlan-interface3] undo ipv6 nd ra halt
# Set the M flag to 1 in RA advertisements to be sent on VLAN-interface 3. Hosts that receive the RA advertisements will obtain IPv6 addresses through DHCPv6.
[SwitchA-Vlan-interface3] ipv6 nd autoconfig managed-address-flag
# Set the O flag to 1 in RA advertisements to be sent on VLAN-interface 3. Hosts that receive the RA advertisements will obtain information other than IPv6 address through DHCPv6.
[SwitchA-Vlan-interface3] ipv6 nd autoconfig other-flag
# Enable the DHCPv6 relay agent on VLAN-interface 3 and specify the DHCPv6 server on the relay agent.
[SwitchA-Vlan-interface3] ipv6 dhcp select relay
[SwitchA-Vlan-interface3] ipv6 dhcp relay server-address 2::2
Verifying the configuration
# Display DHCPv6 server address information on Switch A.
[SwitchA-Vlan-interface3] display ipv6 dhcp relay server-address
Interface: Vlan-interface3
Server address Outgoing Interface
2::2
# Display packet statistics on the DHCPv6 relay agent.
[SwitchA-Vlan-interface3] display ipv6 dhcp relay statistics
Packets dropped : 0
Packets received : 14
Solicit : 0
Request : 0
Confirm : 0
Renew : 0
Rebind : 0
Release : 0
Decline : 0
Information-request : 7
Relay-forward : 0
Relay-reply : 7
Packets sent : 14
Advertise : 0
Reconfigure : 0
Reply : 7
Relay-forward : 7
Relay-reply : 0
Configuring the DHCPv6 client
Overview
With DHCPv6 client configured, an interface can obtain configuration parameters from the DHCPv6 server.
A DHCPv6 client can use DHCPv6 to complete the following functions:
· Obtain an IPv6 address and other configuration parameters, and automatically create a DHCPv6 option group for the obtained parameters.
· Obtain an IPv6 prefix and other configuration parameters, and automatically create a DHCPv6 option group for the obtained parameters.
· Support stateless DHCPv6. The DHCPv6 client can obtain configuration parameters except IPv6 address and IPv6 prefix. The interface obtains an IPv6 address through stateless IPv6 address autoconfiguration. If the interface receives an RA message with the M flag set to 0 and the O flag set to 1 during address acquisition, the interface performs stateless DHCPv6 to get other configuration parameters.
Configuration restrictions and guidelines
When you configure DHCPv6 client, follow these restrictions and guidelines:
· The DHCPv6 client configuration is supported only on Layer 3 Ethernet interfaces, Layer 3 aggregate interfaces, and VLAN interfaces.
· Do not configure the DHCPv6 client on the same interface as the DHCPv6 server or the DHCPv6 relay agent.
DHCPv6 client configuration task list
| Tasks at a glance | 
| (Required.) Perform one of the following tasks: · Configuring IPv6 address acquisition | 
| (Optional.) Setting the DSCP value for DHCPv6 packets sent by the DHCPv6 client | 
| (Optional.) Configuring the DHCPv6 client DUID | 
Configuring IPv6 address acquisition
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | ·     Layer 3 Ethernet interface: ·     Layer 3 aggregate interface: ·     VLAN interface: | N/A | 
| 3. Configure the interface to use DHCPv6 to obtain an IPv6 address and other configuration parameters. | ipv6 address dhcp-alloc [ option-group group-number | rapid-commit ] * | By default, the interface does not use DHCPv6 for IPv6 address acquisition. | 
Configuring IPv6 prefix acquisition
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | ·     Layer 3 Ethernet interface: ·     Layer 3 aggregate interface: ·     VLAN interface: | N/A | 
| 3. Configure the interface to use DHCPv6 to obtain an IPv6 prefix and other configuration parameters. | ipv6 dhcp client pd prefix-number [ option-group group-number | rapid-commit ] * | By default, the interface does not use DHCPv6 for IPv6 prefix acquisition. | 
Configuring stateless DHCPv6
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | ·     Layer 3 Ethernet interface: ·     Layer 3 aggregate interface: ·     VLAN interface: | N/A | 
| 3. Configure the interface to support stateless DHCPv6. | ·     Enable stateless IPv6 address
  autoconfiguration: ·     Enable stateless DHCPv6: | By default, the interface does not support stateless DHCPv6. You can perform both tasks. If you use only the ipv6 address auto command, make sure the M flag is set to 0 and the O flag is set to 1 in the RA message. Otherwise, stateless DHCPv6 cannot be triggered. | 
Setting the DSCP value for DHCPv6 packets sent by the DHCPv6 client
The DSCP value of a packet specifies the priority level of the packet and affects the transmission priority of the packet.
To set the DSCP value for DHCPv6 packets sent by the DHCPv6 client:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Set the DSCP value for DHCPv6 packets sent by the DHCPv6 client. | ipv6 dhcp client dscp dscp-value | By default, the DSCP value in DHCPv6 packets sent by the DHCPv6 client is 56. | 
Configuring the DHCPv6 client DUID
The DUID of a DHCPv6 client is the unique identifier of the client. Make sure the DUID that you configure is unique. The client pads its DUID into Option 1 of the DHCPv6 packet that it sends to the DHCPv6 server. The DHCPv6 server can assign specific IPv6 addresses or prefixes to DHCPv6 clients with specific DUIDs.
By default, the device uses DUID based on link-layer address (DUID-LL) as the DHCPv6 client DUID. DUID-LL includes the following fields:
· DUID type—The device supports the DUID type of DUID-LL with the value of 0x0003.
· Hardware type—The device supports the hardware type of Ethernet with the value of 0x0001.
· Link layer address—Takes the value of the bridge MAC address of the device.
To configure the DHCPv6 client DUID:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | interface interface-type interface-number | N/A | 
| 3. Configure the DHCPv6 client DUID. | ipv6 dhcp client duid { ascii string | hex string | mac interface-type interface-number } | By default, the device uses DUID-LL as the DHCPv6 client DUID. | 
Displaying and maintaining DHCPv6 client
Execute the display commands in any view, and execute the reset command in user view.
| Task | Command | 
| Display the DHCPv6 client information. | display ipv6 dhcp client [ interface interface-type interface-number ] | 
| Display the DHCPv6 client statistics. | display ipv6 dhcp client statistics [ interface interface-type interface-number ] | 
| Clear the DHCPv6 client statistics. | reset ipv6 dhcp client statistics [ interface interface-type interface-number ] | 
DHCPv6 client configuration examples
IPv6 address acquisition configuration example
Network requirements
As shown in Figure 14, configure VLAN-interface 2 of Switch to use DHCPv6 to obtain configuration parameters from the DHCPv6 server. The parameters include IPv6 address, DNS server address, domain name suffix, SIP server address, and SIP server domain name.

Configuration procedure
You must configure the DHCPv6 server first before configuring the DHCPv6 client. For information about configuring DHCPv6 server, see "Configuring the DHCPv6 server."
# Configure VLAN-interface 2 to support DHCPv6 rapid address assignment. Enable the DHCPv6 client to create dynamic DHCPv6 option group 1 for saving configuration parameters.
<Switch> system-view
[Switch] interface vlan-interface 2
[Switch-Vlan-interface2] ipv6 address dhcp-alloc rapid-commit option-group 1
[Switch-Vlan-interface2] quit
Verifying the configuration
# Display the DHCPv6 client information. The output shows that the client has obtained an IPv6 address and other configuration parameters from the server.
[Switch] display ipv6 dhcp client
Vlan-interface2:
Type: Stateful client requesting address
State: OPEN
IAID: 0xf0019
Client DUID: 00030001000fe2ff0000
Preferred server:
Reachable via address: FE80::200:5EFF:FE0A:2303
Server DUID: 00030001000fe20a0a00
Address: 1:2::2
Preferred lifetime 60 sec, valid lifetime 60 sec
T1 30 sec, T2 48 sec
Will expire on Feb 4 2013 at 15:37:20 (50 seconds left)
DNS server addresses:
2000::FF
Domain name:
example.com
SIP server addresses:
2:2::4
SIP server domain names:
bbb.com
# Display information about the dynamic DHCPv6 option group. The output shows that the client has created a dynamic DHCPv6 option group for saving configuration parameters.
[Switch] display ipv6 dhcp option-group 1
DHCPv6 option group: 1
DNS server addresses:
Type: Dynamic (DHCPv6 address allocation)
Interface: Vlan-interface2
2000::FF
Domain name:
Type: Dynamic (DHCPv6 address allocation)
Interface: Vlan-interface2
example.com
SIP server addresses:
Type: Dynamic (DHCPv6 address allocation)
Interface: Vlan-interface2
2:2::4
SIP server domain names:
Type: Dynamic (DHCPv6 address allocation)
Interface: Vlan-interface2
bbb.com
# Display brief IPv6 information for all interfaces on the device. The output shows that the DHCPv6 client has obtained an IPv6 address..
[Switch] display ipv6 interface brief
*down: administratively down
(s): spoofing
Interface Physical Protocol IPv6 Address
Vlan-interface2 up up 1:2::2
IPv6 prefix acquisition configuration example
Network requirements
As shown in Figure 15, configure VLAN-interface 2 of Switch to use DHCPv6 to obtain configuration parameters from the DHCPv6 server. The parameters include IPv6 prefix, DNS server address, domain name suffix, SIP server address, and SIP server domain name.

Configuration procedure
You must configure the DHCPv6 server first before configuring the DHCPv6 client. For information about configuring DHCPv6 server, see "Configuring the DHCPv6 server."
# Configure an IPv6 address for VLAN-interface 2 that connects to the DHCPv6 server.
<Switch> system-view
[Switch] interface vlan-interface 2
[Switch-Vlan-interface2] ipv6 address 1::2/48
# Configure VLAN-interface 2 to support DHCPv6 rapid prefix assignment. Enable the DHCPv6 client to assign an ID to the obtained IPv6 prefix and create a dynamic DHCPv6 option group for saving configuration parameters.
[Switch-Vlan-interface2] ipv6 dhcp client pd 1 rapid-commit option-group 1
[Switch-Vlan-interface2] quit
Verifying the configuration
# Display the DHCPv6 client information. The output shows that the client has obtained an IPv6 prefix and other configuration parameters from the DHCPv6 server.
[Switch] display ipv6 dhcp client
Vlan-interface2:
Type: Stateful client requesting prefix
State: OPEN
IAID: 0xf0019
Client DUID: 00030001000fe2ff0000
Preferred server:
Reachable via address: FE80::200:5EFF:FE0A:2303
Server DUID: 00030001000fe20a0a00
Prefix: 12:34::/32
Preferred lifetime 90 sec, valid lifetime 90 sec
T1 45 sec, T2 72 sec
Will expire on Feb 4 2013 at 15:37:20 (80 seconds left)
DNS server addresses:
2000::FF
Domain name:
example.com
SIP server addresses:
2:2::4
SIP server domain names:
bbb.com
# Display information about the dynamic IPv6 prefix. The output shows that the client has obtained an IPv6 prefix.
[Switch] display ipv6 prefix 1
Number: 1
Type : Dynamic
Prefix: 12:34::/32
Preferred lifetime 90 sec, valid lifetime 90 sec
# Display information about the dynamic DHCPv6 option group. The output shows that the client has created a dynamic DHCPv6 option group for saving configuration parameters.
[Switch] display ipv6 dhcp option-group 1
DHCPv6 option group: 1
DNS server addresses:
Type: Dynamic (DHCPv6 prefix allocation)
Interface: Vlan-interface2
2000::FF
Domain name:
Type: Dynamic (DHCPv6 prefix allocation)
Interface: Vlan-interface2
example.com
SIP server addresses:
Type: Dynamic (DHCPv6 prefix allocation)
Interface: Vlan-interface2
2:2::4
SIP server domain names:
Type: Dynamic (DHCPv6 prefix allocation)
Interface: Vlan-interface2
bbb.com
Stateless DHCPv6 configuration example
Network requirements
As shown in Figure 16, configure VLAN-interface 2 on Switch A to use stateless DHCPv6 to obtain configuration parameters except IPv6 address and IPv6 prefix. Switch B acts as the gateway and advertises RA messages periodically.

Configuration procedure
You must configure the DHCPv6 server first before configuring the DHCPv6 client. For information about configuring DHCPv6 server, see "Configuring the DHCPv6 server."
1. Configure the gateway Switch B.
# Configure an IPv6 address for VLAN-interface 2.
<SwitchB> system-view
[SwitchB] interface vlan-interface 2
[SwitchB-Vlan-interface2] ipv6 address 1::1 64
# Set the O flag to 1 in RA advertisements to be sent on VLAN-interface 2. Hosts that receive the RA advertisements will obtain information other than IPv6 address through DHCPv6.
[SwitchB-Vlan-interface2] ipv6 nd autoconfig other-flag
# Disable RA message suppression on VLAN-interface 2.
[SwitchB-Vlan-interface2] undo ipv6 nd ra halt
2. Configure the DHCPv6 client Switch A.
# Enable stateless IPv6 address autoconfiguration on VLAN-interface 2.
<SwitchA> system-view
[SwitchA] interface vlan-interface 2
[SwitchA-Vlan-interface2] ipv6 address auto
With stateless IPv6 address autoconfiguration enabled, but no IPv6 address configured for VLAN-interface 2, Switch A automatically generates a link local address. It sends an RS message to Switch B to request configuration information for IPv6 address generation. Upon receiving the RS message, Switch B sends back an RA message. After receiving an RA message with the M flag set to 0 and the O flag set to 1, Switch A performs stateless DHCPv6 to get other configuration parameters.
Verifying the configuration
# Display the DHCPv6 client information for VLAN-interface 2.
[SwitchA-Vlan-interface2] display ipv6 dhcp client interface vlan-interface 2
Vlan-interface2:
Type: Stateless client
State: OPEN
IAID: 0xf0019
Client DUID: 00030001000fe2ff0000
Preferred server:
Reachable via address: FE80::213:7FFF:FEF6:C818
Server DUID: 0003000100137ff6c818
DNS server addresses:
1:2:4::5
1:2:4::7
Domain name:
abc.com
# Display the DHCPv6 client statistics.
[SwitchA-Vlan-interface2] display ipv6 dhcp client statistics
Interface : Vlan-interface2
Packets received : 1
Reply : 1
Advertise : 0
Reconfigure : 0
Invalid : 0
Packets sent : 5
Solicit : 0
Request : 0
Renew : 0
Rebind : 0
Information-request : 5
Release : 0
Decline : 0
Configuring DHCPv6 snooping
Overview
DHCPv6 snooping works between the DHCPv6 client and server, or between the DHCPv6 client and DHCPv6 relay agent. It guarantees that DHCPv6 clients obtain IP addresses from authorized DHCPv6 servers. Also, it records IP-to-MAC bindings of DHCPv6 clients (called DHCPv6 snooping entries) for security purposes.
DHCPv6 snooping does not work between the DHCPv6 server and DHCPv6 relay agent.
DHCPv6 snooping defines trusted and untrusted ports to make sure that clients obtain IPv6 addresses only from authorized DHCPv6 servers.
· Trusted—A trusted port can forward DHCPv6 messages correctly to make sure the clients get IPv6 addresses from authorized DHCPv6 servers.
· Untrusted—An untrusted port discards received messages sent by DHCPv6 servers to prevent unauthorized servers from assigning IPv6 addresses.
DHCPv6 snooping reads DHCP-ACK messages received from trusted ports and DHCP-REQUEST messages to create DHCPv6 snooping entries. A DHCPv6 snooping entry includes the MAC and IP addresses of a client, the port that connects to the DHCPv6 client, and the VLAN. You can use the display ipv6 dhcp snooping binding command to display the IP addresses of users for management.
Application of trusted and untrusted ports
Configure ports facing the DHCPv6 server as trusted ports, and configure other ports as untrusted ports.
As shown in Figure 17, configure the DHCPv6 snooping device's port that is connected to the DHCPv6 server as a trusted port. The trusted port forwards response messages from the DHCPv6 server to the client. The untrusted port connected to the unauthorized DHCPv6 server discards incoming DHCPv6 response messages.
Figure 17 Trusted and untrusted ports

H3C implementation of Option 18 and Option 37
Option 18 for DHCPv6 snooping
Option 18, also called the interface-ID option, is used by the DHCPv6 relay agent to determine the interface to use to forward RELAY-REPLY message.
In H3C implementation, the DHCPv6 snooping device adds Option 18 to the received DHCPv6 request message before forwarding it to the DHCPv6 server. The server then assigns IP address to the client based on the client information in Option 18.

Figure 18 shows the Option 18 format, which includes the following fields:
· Option code—Option code.
· Option length—Size of the option data.
· Port index—Port that receives the DHCPv6 request from the client.
· VLAN ID—ID of the outer VLAN.
· Second VLAN ID—ID of the inner VLAN.
· DUID—DUID of the DHCPv6 client.
| 
 | NOTE: The Second VLAN ID field is optional. If the received DHCPv6 request does not contain a second VLAN, Option 18 also does not contain it. | 
DHCPv6 snooping support for Option 37
Option 37, also called the remote-ID option, is used to identify the client.
In H3C implementation, the DHCPv6 snooping device adds Option 37 to the received DHCPv6 request message before forwarding it to the DHCPv6 server. This option provides client information about address allocation.

Figure 19 shows the Option 37 format, which includes the following fields:
· Option code—Option code.
· Option length—Size of the option data.
· Enterprise number—Enterprise number.
· Port index—Port that receives the DHCPv6 request from the client.
· VLAN ID—ID of the outer VLAN.
· Second VLAN ID—ID of the inner VLAN.
· DUID—DUID of the DHCPv6 client.
| 
 | NOTE: The Second VLAN ID field is optional. If the received DHCPv6 request does not contain a second VLAN, Option 37 also does not contain it. | 
DHCPv6 snooping configuration task list
| Tasks at a glance | 
| (Required.) Configuring basic DHCPv6 snooping | 
| (Optional.) Configuring Option 18 and Option 37 | 
| (Optional.) Configuring DHCPv6 snooping entry auto backup | 
| (Optional.) Setting the maximum number of DHCPv6 snooping entries | 
| (Optional.) Configuring DHCPv6 packet rate limit | 
| (Optional.) Enabling DHCPv6-REQUEST check | 
| (Optional.) Configuring a DHCPv6 packet blocking port | 
| (Optional.) Enabling DHCPv6 snooping logging | 
Configuring basic DHCPv6 snooping
Follow these guidelines when you configure basic DHCPv6 snooping:
· To make sure DHCPv6 clients can obtain valid IPv6 addresses, specify the ports connected to authorized DHCPv6 servers as trusted ports. The trusted ports and the ports connected to DHCPv6 clients must be in the same VLAN.
· If you configure DHCPv6 snooping settings on a Layer 2 Ethernet interface that is a member port of a Layer 2 aggregate interface, the settings do not take effect unless the interface is removed from the aggregation group.
To configure basic DHCPv6 snooping:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enable DHCPv6 snooping. | ipv6 dhcp snooping enable | By default, DHCPv6 snooping is disabled. | 
| 3. Enter interface view. | interface interface-type interface-number | This interface must connect to the DHCPv6 server. | 
| 4. Specify the port as a trusted port. | ipv6 dhcp snooping trust | By default, all ports are untrusted ports after DHCPv6 snooping is enabled. | 
| 5. Return to system view. | quit | N/A | 
| 6. Enter interface view. | interface interface-type interface-number | This interface must connect to the DHCPv6 client. | 
| 7. (Optional.) Enable recording of client information in DHCPv6 snooping entries. | ipv6 dhcp snooping binding record | By default, DHCPv6 snooping does not record client information. | 
Configuring Option 18 and Option 37
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | ·     Enter Layer 2 Ethernet interface view: ·     Enter Layer 2 aggregate interface view: | N/A | 
| 3. Enable support for Option 18. | ipv6 dhcp snooping option interface-id enable | By default, Option 18 is not supported. | 
| 4. (Optional.) Specify the content as the interface ID. | ipv6 dhcp snooping option interface-id [ vlan vlan-id ] string interface-id | By default, the DHCPv6 snooping device uses its DUID as the content for Option 18. | 
| 5. Enable support for Option 37. | ipv6 dhcp snooping option remote-id enable | By default, Option 37 is not supported. | 
| · (Optional.) Specify the content as the remote ID. | ipv6 dhcp snooping option remote-id [ vlan vlan-id ] string remote-id | By default, the DHCPv6 snooping device uses its DUID as the content for Option 37. | 
Configuring DHCPv6 snooping entry auto backup
The auto backup feature saves DHCPv6 snooping entries to a backup file, and allows the DHCPv6 snooping device to download the entries from the backup file at reboot. The entries on the DHCPv6 snooping device cannot survive a reboot. The auto backup helps the security features provide services if these features (such as IP source guard) must use DHCPv6 snooping entries for user authentication.
| 
 | IMPORTANT: If you disable DHCPv6 snooping with the undo ipv6 dhcp snooping enable command, the device deletes all DHCPv6 snooping entries, including those stored in the backup file. | 
To configure DHCPv6 snooping entry auto backup:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Configure the DHCPv6 snooping device to back up DHCPv6 snooping entries to a file. | ipv6 dhcp snooping binding database filename { filename | url url [ username username [ password { cipher | simple } key ] ] } | By default, the DHCPv6 snooping device does not back up the DHCPv6 snooping entries. With this command executed, the DHCPv6 snooping device backs up DHCPv6 snooping entries immediately and runs auto backup. This command automatically creates the file if you specify a non-existent file. | 
| 3. (Optional.) Manually save DHCPv6 snooping entries to the backup file. | ipv6 dhcp snooping binding database update now | N/A | 
| 4. (Optional.) Set the waiting time after a DHCPv6 snooping entry change for the DHCPv6 snooping device to update the backup file. | ipv6 dhcp snooping binding database update interval seconds | The default waiting time is 300 seconds. The waiting period starts when a DHCPv6 snooping entry is learned, updated, or removed. The DHCPv6 snooping device updates the backup file when the specified waiting period is reached. All changed entries during the period will be saved to the backup file. If no DHCPv6 snooping entry changes, the backup file is not updated. | 
Setting the maximum number of DHCPv6 snooping entries
Perform this task to prevent the system resources from being overused.
To set the maximum number of DHCPv6 snooping entries:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | interface interface-type interface-number | N/A | 
| 3. Set the maximum number of DHCPv6 snooping entries for the interface to learn. | ipv6 dhcp snooping max-learning-num number | By default, the number of DHCPv6 snooping entries for an interface to learn is not limited. | 
Configuring DHCPv6 packet rate limit
This DHCPv6 packet rate limit feature discards exceeding DHCPv6 packets to prevent attacks that send large numbers of DHCPv6 packets.
To configure DHCPv6 packet rate limit:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | interface interface-type interface-number | N/A | 
| 3. Specify the maximum rate at which an interface can receive DHCPv6 packets. | ipv6 dhcp snooping rate-limit rate | By default, incoming DHCPv6 packets on an interface are not rate limited. You can configure this command only on Layer 2 Ethernet interfaces and Layer 2 aggregate interfaces. If you specify the maximum rate on a Layer 2 Ethernet interface that is a member port of a Layer 2 aggregate interface, the Layer 2 Ethernet interface uses the DHCP packet maximum rate configured on the Layer 2 aggregate interface. If the Layer 2 Ethernet interface leaves the aggregation group, it uses its own DHCP packet maximum rate. | 
Enabling DHCPv6-REQUEST check
Perform this task to use the DHCPv6-REQUEST check feature to protect the DHCPv6 server against DHCPv6 client spoofing attacks. Attackers can forge DHCPv6-RENEW messages to renew leases for legitimate DHCPv6 clients that no longer need the IP addresses. The forged messages disable the victim DHCPv6 server from releasing the IP addresses. Attackers can also forge DHCPv6-DECLINE or DHCPv6-RELEASE messages to terminate leases for legitimate DHCPv6 clients that still need the IP addresses.
The DHCPv6-REQUEST check feature enables the DHCPv6 snooping device to check every received DHCPv6-RENEW, DHCPv6-DECLINE, or DHCPv6-RELEASE message against DHCPv6 snooping entries.
· If any criterion in an entry is matched, the device compares the entry with the message information.
¡ If they are consistent, the device considers the message valid and forwards it to the DHCPv6 server.
¡ If they are different, the device considers the message forged and discards it.
· If no matching entry is found, the device forwards the message to the DHCPv6 server.
To enable DHCPv6-REQUEST check:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | interface interface-type interface-number | N/A | 
| 3. Enable DHCPv6-REQUEST check. | ipv6 dhcp snooping check request-message | By default, DHCPv6-REQUEST check is disabled. You can enable the feature only on Layer 2 Ethernet interfaces and Layer 2 aggregate interfaces. | 
Configuring a DHCPv6 packet blocking port
A DHCPv6 packet blocking port drops all incoming DHCPv6 packets. Use this feature to filter all incoming DHCPv6 packets on the interface where DHCP snooping features are configured. These packets cannot be dropped by simply applying an ACL, because the ACL rules deployed by DHCPv6 snooping features take precedence over the ACL application.
To configure a DHCPv6 packet blocking port:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enter interface view. | interface interface-type interface-number | N/A | 
| 3. Configure the port to block DHCPv6 packets. | ipv6 dhcp snooping deny | By default, the port does not block DHCPv6 packets. | 
Enabling DHCPv6 snooping logging
The DHCPv6 snooping logging feature enables the DHCPv6 snooping device to generate DHCPv6 snooping logs and send them to the information center. For information about the log destination and output rule configuration in the information center, see Network Management and Monitoring Configuration Guide.
As a best practice, disable this feature if the log generation affects the device performance.
To enable DHCPv6 snooping logging:
| Step | Command | Remarks | 
| 1. Enter system view. | system-view | N/A | 
| 2. Enable DHCPv6 snooping logging. | ipv6 dhcp snooping log enable | By default, DHCPv6 snooping logging is disabled. | 
Displaying and maintaining DHCPv6 snooping
Execute display commands in any view, and reset commands in user view.
| Task | Command | 
| Display information about trusted ports. | display ipv6 dhcp snooping trust | 
| Display DHCPv6 snooping entries. | display ipv6 dhcp snooping binding [ address ipv6-address [ vlan vlan-id ] ] | 
| Display information about the file that stores DHCPv6 snooping entries. | display ipv6 dhcp snooping binding database | 
| Display DHCPv6 packet statistics for DHCPv6 snooping. | display ipv6 dhcp snooping packet statistics [ slot slot-number ] | 
| Clear DHCPv6 snooping entries. | reset ipv6 dhcp snooping binding { all | address ipv6-address [ vlan vlan-id ] } | 
| Clear DHCPv6 packet statistics for DHCPv6 snooping. | reset ipv6 dhcp snooping packet statistics [ slot slot-number ] | 
DHCPv6 snooping configuration example
Network requirements
As shown in Figure 20, configure Ten-GigabitEthernet 1/1/1 connecting to the DHCPv6 server as a trusted port. Enable DHCPv6 snooping to record client information in DHCPv6 snooping entries.

Configuration procedure
# Enable DHCPv6 snooping.
<SwitchB> system-view
[SwitchB] ipv6 dhcp snooping enable
# Specify Ten-GigabitEthernet 1/1/1 as a trusted port.
[SwitchB] interface ten-gigabitethernet 1/1/1
[SwitchB-Ten-GigabitEthernet1/1/1] ipv6 dhcp snooping trust
[SwitchB-Ten-GigabitEthernet1/1/1] quit
# Enable recording of client information in DHCPv6 snooping entries.
[SwitchB]interface ten-gigabitethernet 1/1/2
[SwitchB-Ten-GigabitEthernet1/1/2] ipv6 dhcp snooping binding record
[SwitchB-Ten-GigabitEthernet1/1/2] quit
Verifying the configuration
# Verify that the DHCPv6 client obtains an IPv6 address and all other configuration parameters only from the authorized DHCPv6 server. (Details not shown.)
# Display DHCPv6 snooping entries on the DHCPv6 snooping device.
[SwitchB] display ipv6 dhcp snooping binding
 Login
Login

