if you're deploying ipv6 in your organization there are a number of different ways that you could implement this in your environment one way is to tunnel the ipv6 within an existing network configuration for example six to four is an addressing type that sends ipv6 information over an existing ipv4 address this process creates an ipv6 address that's based on your existing ipv4 address one of the challenges with six to four is that it requires specific relay routers that are designed to provide this tunneling this also does not support network address translation which certainly limits the ability to send this traffic across the internet the reverse of six to four is four in six tunneling where you would tunnel ipv4 traffic inside of an existing ipv6 network because of the challenges associated with this addressing and tunneling system we don't tend to see a widespread implementation of these technologies on today's networks if you do want to tunnel ipv6 and you want to support network address translation you might want to use territo this tunnels ipv6 through an added ipv4 network allowing you to send ipv6 end to end through an ipv4 network with territo you don't need any special router or relay system this is designed to be a temporary form of communication until we're able to send ipv6 traffic end to end territo is commonly seen on windows operating systems but there is an open source version of this for linux bsd unix and mac os called morito this provides the same functionality as a windows based torito system but it works on these additional operating systems today's implementations of ipv6 tend to be end-to-end and we're able to implement this by using dual stack routing this means that our devices and our routers can communicate using ipv4 and ipv6 simultaneously you can send whatever traffic you would like to the device and it knows to forward that traffic appropriately with ipv4 you would configure a router or a device with an ipv4 address it uses standard ipv4 routing tables and you can even use ipv4 dynamic routing protocols this is the same ipv4 configuration that we've been using on our routers for years what we've done is add an additional protocol to our routers for ipv6 there's a separate configuration for ipv6 addresses these devices have their own ipv6 routing tables that are separate from the ipv4 routing tables and if you're using ipv6 dynamic routing protocols those protocols would be used by the ipv6 section of this router this allows us to configure our devices with an ipv4 address an ipv6 address or allows us to configure both on our devices simultaneously and all of our routing devices will be able to route that traffic appropriately if you're starting to use ipv6 one of the things you'll notice is that ipv6 doesn't use broadcasts we've removed broadcast completely from the protocol but we still need a way to identify other devices that might be on the network and without a broadcast we can't use the traditional address resolution protocol to be able to find devices so instead we use a specialized multicast protocol called neighbor solicitation or ns one device would send this neighbor solicitation to this multicast address and any device on the network that matches the request will send the response back as a neighbor advertisement or n a this effectively replaces the functionality of address resolution protocol that we used to have in ipv4 and updates it for the multicast capabilities of ipv6 this allows us to use more efficient protocols like multicast and replace the functionality of ipv4 arp with a neighbor discovery protocol or ndp ipv6 also provides us with a way to statically address devices automatically without the use of a dhcp server this is called stateless address auto configuration or slack this means that we could have an entire network configured with slack based ip addresses without having to build a separate dhcp server to assign addresses to be able to support this ipv6 auto configuration we need to use duplicate address detection or dad to ensure that no duplicate ip addresses would be configured this is also the protocol that we would use to find routers on our network this neighbor discovery protocol would send a router solicitation packet and listen for a router advertisement this would allow your local devices to automatically configure themselves and identify where the routers are on their local subnet this process uses the neighbor discovery protocol to find these routers a router solicitation message is sent to an ipv6 router multicast address and any local routers on that subnet will respond back with a router advertisement routers may also be configured to send unsolicited router advertisements over this multicast address so that all of the devices on the subnet would be able to identify where the router happened to be this will transfer information such as the ipv6 address information of the router prefix information for the network and prefix length which would then allow the local devices to automatically configure themselves with the appropriate ip addresses you