This shows you the differences between two versions of the page.
| Both sides previous revision Previous revision Next revision | Previous revision | ||
| ipv6_opnfv_project:topdown_usecase [2016/02/22 20:12] Bin Hu [Table] | ipv6_opnfv_project:topdown_usecase [2016/02/22 20:39] (current) Bin Hu [Table] | ||
|---|---|---|---|
| Line 7: | Line 7: | ||
| | IPv6 VM to VM only | Yes | It is possible to assign IPv6-only addresses to VMs. Both switching (within VMs on the same tenant network) as well as east/west routing (between different networks of the same tenant) are supported.  | | | IPv6 VM to VM only | Yes | It is possible to assign IPv6-only addresses to VMs. Both switching (within VMs on the same tenant network) as well as east/west routing (between different networks of the same tenant) are supported.  | | ||
| | IPv6 external L2 VLAN directly attached to a VM | Yes | IPv6 provider network model; RA messages from upstream (external) router are forwarded into the VMs | | | IPv6 external L2 VLAN directly attached to a VM | Yes | IPv6 provider network model; RA messages from upstream (external) router are forwarded into the VMs | | ||
| - | | IPv6 subnet routed via L3 agent to an external IPv6 network\\  1. Both VLAN and overlay (e.g. GRE, VXLAN)  subnet attached to VMs;\\  2. Must be able to support multiple L3 agents for a given external network to support scaling (neutron scheduler to assign vRouters to the L3 agents)  | 1. Yes\\ 2. Yes | Configuration is enhanced in Kilo to allow easier setup of the upstream gateway, without the user forced to create an IPv6 subnet for the external network.  | | + | | IPv6 subnet routed via L3 agent to an external IPv6 network\\  1. Both VLAN and overlay (e.g. GRE, VXLAN)  subnet attached to VMs;\\  2. Must be able to support multiple L3 agents for a given external network to support scaling (neutron scheduler to assign vRouters to the L3 agents)  | 1. Yes\\ 2. Yes | Configuration is enhanced since Kilo to allow easier setup of the upstream gateway, without the user being forced to create an IPv6 subnet for the external network.  | | 
| | Ability for a NIC to support both IPv4 and IPv6 (dual stack) address;\\ 1. VM with a single interface associated with a network, which is then associated with two subnets.\\ 2. VM with two different interfaces associated with two different networks and two different subnets.  | 1. Yes\\ 2. Yes | Dual-stack is supported in Neutron with the addition of [[https://blueprints.launchpad.net/neutron/+spec/multiple-ipv6-prefixes| Multiple IPv6 Prefixes]] Blueprint.  | | | Ability for a NIC to support both IPv4 and IPv6 (dual stack) address;\\ 1. VM with a single interface associated with a network, which is then associated with two subnets.\\ 2. VM with two different interfaces associated with two different networks and two different subnets.  | 1. Yes\\ 2. Yes | Dual-stack is supported in Neutron with the addition of [[https://blueprints.launchpad.net/neutron/+spec/multiple-ipv6-prefixes| Multiple IPv6 Prefixes]] Blueprint.  | | ||
| | Support IPv6 Address assignment modes.\\ 1. SLAAC\\ 2. DHCPv6 Stateless\\ 3. DHCPv6 Stateful  | 1. Yes\\ 2. Yes\\ 3. Yes |  | | | Support IPv6 Address assignment modes.\\ 1. SLAAC\\ 2. DHCPv6 Stateless\\ 3. DHCPv6 Stateful  | 1. Yes\\ 2. Yes\\ 3. Yes |  | | ||
| Line 13: | Line 13: | ||
| | Ability to create a port with fixed_ip for a SLAAC/DHCPv6-Stateless Subnet.  | ** No ** | The following patch disables this operation: https://review.openstack.org/#/c/129144/  | | | Ability to create a port with fixed_ip for a SLAAC/DHCPv6-Stateless Subnet.  | ** No ** | The following patch disables this operation: https://review.openstack.org/#/c/129144/  | | ||
| | Support for private IPv6 to external IPv6 floating IP; Ability to specify floating IPs via Neutron API (REST and CLI) as well as via Horizon, including combination of IPv6/IPv4 and IPv4/IPv6 floating IPs if implemented.  | **Rejected**  | Blueprint proposed in upstream and got rejected. General expectation is to avoid NAT with IPv6 by assigning GUA to tenant VMs.\\ See https://review.openstack.org/#/c/139731/ for discussion.  | | | Support for private IPv6 to external IPv6 floating IP; Ability to specify floating IPs via Neutron API (REST and CLI) as well as via Horizon, including combination of IPv6/IPv4 and IPv4/IPv6 floating IPs if implemented.  | **Rejected**  | Blueprint proposed in upstream and got rejected. General expectation is to avoid NAT with IPv6 by assigning GUA to tenant VMs.\\ See https://review.openstack.org/#/c/139731/ for discussion.  | | ||
| - | | Provide IPv6/IPv4 feature parity in support for pass-through capabilities (e.g., SR-IOV).  | **Roadmap**  | The L3 configuration should be transparent for the SR-IOV implementation. SR-IOV networking support introduced in Juno based on the sriovnicswitch ML2 driver is expected to work with IPv4 and IPv6 enabled VMs. | | + | | Provide IPv6/IPv4 feature parity in support for pass-through capabilities (e.g., SR-IOV).  | To-Do | The L3 configuration should be transparent for the SR-IOV implementation. SR-IOV networking support introduced in Juno based on the sriovnicswitch ML2 driver is expected to work with IPv4 and IPv6 enabled VMs. We need to verify if it works or not. | | 
| - | | Additional IPv6 extensions, for example: IPSEC, IPv6 Anycast, Multicast  | **No**  | It doesn’t appear to be considered yet (lack of clear requirements)  | | + | | Additional IPv6 extensions, for example: IPSEC, IPv6 Anycast, Multicast  | **No**  | It does not appear to be considered yet (lack of clear requirements)  | | 
| | VM access to the meta-data server to obtain user data, SSH keys, etc. using cloud-init with IPv6 only interfaces.  | **No**  | This is currently not supported. Config-drive or dual-stack IPv4/IPv6 can be used as a workaround (so that the IPv4 network is used to obtain connectivity with the metadata service)\\ Ref:[[http://openstack.10931.n7.nabble.com/Neutron-cloud-init-IPv6-support-td45386.html|email-thread]]  | | | VM access to the meta-data server to obtain user data, SSH keys, etc. using cloud-init with IPv6 only interfaces.  | **No**  | This is currently not supported. Config-drive or dual-stack IPv4/IPv6 can be used as a workaround (so that the IPv4 network is used to obtain connectivity with the metadata service)\\ Ref:[[http://openstack.10931.n7.nabble.com/Neutron-cloud-init-IPv6-support-td45386.html|email-thread]]  | | ||
| | Full support for IPv6 matching (i.e., IPv6, ICMPv6, TCP, UDP) in security groups. Ability to control and manage all IPv6 security group capabilities via Neutron/Nova API (REST and CLI) as well as via Horizon.  | Yes | | | | Full support for IPv6 matching (i.e., IPv6, ICMPv6, TCP, UDP) in security groups. Ability to control and manage all IPv6 security group capabilities via Neutron/Nova API (REST and CLI) as well as via Horizon.  | Yes | | | ||
| - | | During network/subnet/router create, there should be an option to allow user to specify the type of address management they would like. This includes all options including those low priority if implemented (e.g., toggle on/off router and address prefix advertisements); It must be supported via Neutron API (REST and CLI) as well as via Horizon  | Yes | Two new Subnet attributes were introduced to control IPv6 address assignment options: "ipv6-ra-mode" - to determine who sends Router Advertisements, and "ipv6-address-mode" - to determine how VM obtains IPv6 address, default gateway, and/or optional information.  | | + | | During network/subnet/router create, there should be an option to allow user to specify the type of address management they would like. This includes all options including those low priority if implemented (e.g., toggle on/off router and address prefix advertisements); It must be supported via Neutron API (REST and CLI) as well as via Horizon  | Yes | Two new Subnet attributes were introduced to control IPv6 address assignment options: \\ "ipv6-ra-mode" - to determine who sends Router Advertisements, and \\ "ipv6-address-mode" - to determine how VM obtains IPv6 address, default gateway, and/or optional information.  | | 
| | Security groups anti-spoofing: Prevent VM from using a source IPv6/MAC address which is not assigned to the VM | Yes | | | | Security groups anti-spoofing: Prevent VM from using a source IPv6/MAC address which is not assigned to the VM | Yes | | | ||
| | Protect tenant and provider network from rogue RAs | Yes | When using a tenant network, Neutron is going to automatically handle the filter rules to allow connectivity of RAs to the VMs only from the Neutron router port; with provider networks, users are required to specify the LLA of the upstream router during the subnet creation, or otherwise manually edit the security-groups rules to allow incoming traffic from this specific address.  | | | Protect tenant and provider network from rogue RAs | Yes | When using a tenant network, Neutron is going to automatically handle the filter rules to allow connectivity of RAs to the VMs only from the Neutron router port; with provider networks, users are required to specify the LLA of the upstream router during the subnet creation, or otherwise manually edit the security-groups rules to allow incoming traffic from this specific address.  | | ||
| Line 24: | Line 24: | ||
| | Support for IPv6 Prefix Delegation.  | Yes | Partial support in Liberty  | | | Support for IPv6 Prefix Delegation.  | Yes | Partial support in Liberty  | | ||
| | Distributed Virtual Routing (DVR) support for IPv6 | **No**  | Blueprint proposed upstream, pending discussion.  | | | Distributed Virtual Routing (DVR) support for IPv6 | **No**  | Blueprint proposed upstream, pending discussion.  | | ||
| + | | IPv6 First-Hop Security, IPv6 ND spoofing  | Yes | | | ||
| | IPv6 support in Neutron Layer3 High Availability (keepalived+VRRP).  | Yes | | | | IPv6 support in Neutron Layer3 High Availability (keepalived+VRRP).  | Yes | | | ||
| + | |||
| + | |||
| + | |||
| + | |||
| + | |||
| + | |||
| + | |||