Could IPv6 make NAT / port numbers redundant?





.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{
margin-bottom:0;
}








8

















From what I can tell, each process could get its own IP address, with loads of IP's to spare.



What would the drawbacks be?



Essentially, your host would become a router and each process is a host (in the current system).










share|improve this question





























  • Comments are not for extended discussion; this conversation has been moved to chat.

    – Ron Maupin
    May 30 at 0:46


















8

















From what I can tell, each process could get its own IP address, with loads of IP's to spare.



What would the drawbacks be?



Essentially, your host would become a router and each process is a host (in the current system).










share|improve this question





























  • Comments are not for extended discussion; this conversation has been moved to chat.

    – Ron Maupin
    May 30 at 0:46














8












8








8


3






From what I can tell, each process could get its own IP address, with loads of IP's to spare.



What would the drawbacks be?



Essentially, your host would become a router and each process is a host (in the current system).










share|improve this question
















From what I can tell, each process could get its own IP address, with loads of IP's to spare.



What would the drawbacks be?



Essentially, your host would become a router and each process is a host (in the current system).







ip nat ipv6 protocol-theory transport-protocol






share|improve this question















share|improve this question













share|improve this question




share|improve this question



share|improve this question








edited May 30 at 0:30







Tobiq

















asked May 27 at 19:32









TobiqTobiq

1461 silver badge5 bronze badges




1461 silver badge5 bronze badges
















  • Comments are not for extended discussion; this conversation has been moved to chat.

    – Ron Maupin
    May 30 at 0:46



















  • Comments are not for extended discussion; this conversation has been moved to chat.

    – Ron Maupin
    May 30 at 0:46

















Comments are not for extended discussion; this conversation has been moved to chat.

– Ron Maupin
May 30 at 0:46





Comments are not for extended discussion; this conversation has been moved to chat.

– Ron Maupin
May 30 at 0:46










6 Answers
6






active

oldest

votes


















13


















IPv6 does not have a NAT standard as IPv4 does (NAT breaks the end-to-end premise of IP, and IPv6 was designed to restore that). There is an experimental RFC for IPv6 NAT, but it is a one-to-one NAT at the network layer, rather than something like the IPv4 NAPT that also translates port addresses, and, in fact, the experimental IPv6 NAT RFC expressly forbids that.



If you think about the various transport protocols, TCP and UDP use ports, which are really addresses for those transport protocols. Other transport protocols may use other addressing, and some use no addresses.



Your idea would possibly work with either TCP or UDP, but only one, and probably not with other transport protocols. IPv6 is connectionless, like UDP, so it may work with UDP, but TCP is connection-oriented, and it performs a lot of work that would otherwise need to be performed by the application.



There are requirements for both connectionless and connection-oriented transport protocols. The predecessor to IPv4 actually had the equivalent of IP and TCP as a single protocol, but it became necessary to split them because some transport protocols need to be connectionless.






share|improve this answer


































    9


















    One drawback is that the upper layers would need to be aware of IP addresses, which sort of violates the layering principle. What would then happen if you switched to IPv4? Or something else?



    How would the upper layers tell the network layer that it should start responding to an IP address? Suppose a new application starts up. How does the network layer know there's a new address to respond to?



    IPv6 could theoretically eliminate NAT, but there are still reasons why an organization might want to hide its internal IP addresses.






    share|improve this answer



























    • Comments are not for extended discussion; this conversation has been moved to chat.

      – Ron Maupin
      Jun 5 at 1:44



















    6


















    The need for NATs as a way to share public IP adresses will be gone with IPv6, but NATs may still have some uses for security reasons.



    Removing ports might be possible in theory, but it would be a huge undertaking. Even if you reserve the last 16 bits of the IP adress for port number + 1 bit for TCP/UDP flag, you would need to rework all the software that unpacks the pactet from the 3rd layer into the 4th one to use the bits from IP adress for port number and protocol, instead of data in the packet.



    And that's the "easy" solution when you just put the port nubmers in the IP adress, if you wanted to get rid or port numbers altogether, you would need to change every software and library that uses ports, be it servers, clients, firewalls, etc etc. It would be basicly impossible, every software that says "open server at port X" which would work fine when just going from IPv4 to IPv6 would break instantly if you remove ports altogether.



    It is infinetely more easier to just keep the ports.






    share|improve this answer



























    • Comments are not for extended discussion; this conversation has been moved to chat.

      – Ron Maupin
      May 29 at 22:03



















    4


















    It wouldn't be IPv6. Such a system is of course feasible, but it would be an variation of the IP protocol. Today, IP's contain two parts: a host identifier and a service identifier.



    With your scheme, it would essentially be a service descriptor. This would require changes to DNS (e.g. how do you differentiate between the SMTP server for example.com and the www-server for example.com?)



    I can't see how it would be beneficial over todays system with host:service descriptors. It would not achieve anything not possible today.






    share|improve this answer



























    • Comments are not for extended discussion; this conversation has been moved to chat.

      – Ron Maupin
      May 30 at 0:46



















    0


















    As others have said, having port numbers is a requirement, even if they end up being 'encoded' in the IP address of the service.



    Some applications need more than one port number. For example, most web servers need port 80 and 443 (and maybe another port for websockets or whatever). Such a system would need three IP addresses with encoded ports. Whilst we've got plenty of IPs, it would (at present) mean system-level configuration would be required to support those three port numbers. Using a separate port number means the apps can just start up and use the ports without needing the sysadmin to do some config work first. As others have said - it's just easier to use a port number.



    As for NAT, yes, IPv6 should remove the need for NAT in almost all cases. Some cases remain though, so it probably won't disappear entirely, but wide-spread use is likely to diminish significantly.






    share|improve this answer



























    • Comments are not for extended discussion; this conversation has been moved to chat.

      – Ron Maupin
      May 30 at 0:46



















    0


















    IP Addresses and Ports, though usually seen together, perform very distinct tasks. IP Addresses are used to route traffic to your computer specifically and port numbers are used by applications.



    A very good analogy is sending mail to an apartment building. The address of the building would be equivalent to an IP address and the unit numbers would be analogous to a port number. For this analogy we'll say the building's address is 127 Home Ave. Say you wanted to send a letter to Henry T.T. Peterson, so you send a letter to the building, he doesn't receive it because it needs further direction to his apartment, apartment 80.



    In theory, IPv6 address could take the place of both IPv4 addresses and port numbers, however this violates well-established precedents of networking and there are some major drawbacks:




    • Defeats the very purpose that IPv6 was created to alleviate(concerns about the world running out of IP addresses)

    • Routing tables internal to routers and switches would become exponentially larger while offering no benefit(many address will route to the same physical computer)

    • Every application on every computer will need a unique address and although IPv6 offers many, many times more addresses (2^128 vs 2^32), we will run out rather quickly and then need to create IPv8, then IPv10, then IPv12, we will be racing an exponential curve and that pretty much won't be a fun time.


    As far as NAT goes, this was created for 2 reasons, there were already concerns that the world was running out of (or would run out of) public IP addresses, which was massively alleviated by allowing for organizations and even home networks an incredible amount of IP addresses that can be used internally, and allows for important machines to be "hidden" from the world (such as your database with sensitive information on it, or the CEO's laptop)



    I hope this explanation was helpful; you see, both NAT and port numbers are a good thing, we wouldn't want to replace them with IPv6 because that is a huge step backwards, if anything we'd want to actually expand them, or replace them with something even better






    share|improve this answer






















    • 1





      1. "Defeats the very purpose that IPv6" - No it wouldn't, your computer probably has several IPv6 addresses already with no issues. At least 2^64 addresses are reserved for a typical home network. "Routing tables would become larger" - No they wouldn't, there's just one routing table entry for your whole network. (And when you look from outside of your ISP, there's just one entry for your whole ISP.) You really underestimate how big 2^128 is. Say you treated the last 16 bits as a port number (which is probably not how this would work), you still have 2^112 computer addresses.

      – immibis
      May 28 at 23:54











    • (In reality most computers don't use all 65536 ports either. I'd guesstimate it's less than 100 99% of the time)

      – immibis
      May 28 at 23:56













    • @immibis you covered everything I was thinking while reading the post

      – Tobiq
      May 29 at 10:44













    Your Answer








    StackExchange.ready(function() {
    var channelOptions = {
    tags: "".split(" "),
    id: "496"
    };
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function() {
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled) {
    StackExchange.using("snippets", function() {
    createEditor();
    });
    }
    else {
    createEditor();
    }
    });

    function createEditor() {
    StackExchange.prepareEditor({
    heartbeatType: 'answer',
    autoActivateHeartbeat: false,
    convertImagesToLinks: false,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: null,
    bindNavPrevention: true,
    postfix: "",
    imageUploader: {
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/4.0/"u003ecc by-sa 4.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    },
    noCode: true, onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    });


    }
    });















    draft saved

    draft discarded
















    StackExchange.ready(
    function () {
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fnetworkengineering.stackexchange.com%2fquestions%2f59438%2fcould-ipv6-make-nat-port-numbers-redundant%23new-answer', 'question_page');
    }
    );

    Post as a guest















    Required, but never shown


























    6 Answers
    6






    active

    oldest

    votes








    6 Answers
    6






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    13


















    IPv6 does not have a NAT standard as IPv4 does (NAT breaks the end-to-end premise of IP, and IPv6 was designed to restore that). There is an experimental RFC for IPv6 NAT, but it is a one-to-one NAT at the network layer, rather than something like the IPv4 NAPT that also translates port addresses, and, in fact, the experimental IPv6 NAT RFC expressly forbids that.



    If you think about the various transport protocols, TCP and UDP use ports, which are really addresses for those transport protocols. Other transport protocols may use other addressing, and some use no addresses.



    Your idea would possibly work with either TCP or UDP, but only one, and probably not with other transport protocols. IPv6 is connectionless, like UDP, so it may work with UDP, but TCP is connection-oriented, and it performs a lot of work that would otherwise need to be performed by the application.



    There are requirements for both connectionless and connection-oriented transport protocols. The predecessor to IPv4 actually had the equivalent of IP and TCP as a single protocol, but it became necessary to split them because some transport protocols need to be connectionless.






    share|improve this answer































      13


















      IPv6 does not have a NAT standard as IPv4 does (NAT breaks the end-to-end premise of IP, and IPv6 was designed to restore that). There is an experimental RFC for IPv6 NAT, but it is a one-to-one NAT at the network layer, rather than something like the IPv4 NAPT that also translates port addresses, and, in fact, the experimental IPv6 NAT RFC expressly forbids that.



      If you think about the various transport protocols, TCP and UDP use ports, which are really addresses for those transport protocols. Other transport protocols may use other addressing, and some use no addresses.



      Your idea would possibly work with either TCP or UDP, but only one, and probably not with other transport protocols. IPv6 is connectionless, like UDP, so it may work with UDP, but TCP is connection-oriented, and it performs a lot of work that would otherwise need to be performed by the application.



      There are requirements for both connectionless and connection-oriented transport protocols. The predecessor to IPv4 actually had the equivalent of IP and TCP as a single protocol, but it became necessary to split them because some transport protocols need to be connectionless.






      share|improve this answer





























        13














        13










        13









        IPv6 does not have a NAT standard as IPv4 does (NAT breaks the end-to-end premise of IP, and IPv6 was designed to restore that). There is an experimental RFC for IPv6 NAT, but it is a one-to-one NAT at the network layer, rather than something like the IPv4 NAPT that also translates port addresses, and, in fact, the experimental IPv6 NAT RFC expressly forbids that.



        If you think about the various transport protocols, TCP and UDP use ports, which are really addresses for those transport protocols. Other transport protocols may use other addressing, and some use no addresses.



        Your idea would possibly work with either TCP or UDP, but only one, and probably not with other transport protocols. IPv6 is connectionless, like UDP, so it may work with UDP, but TCP is connection-oriented, and it performs a lot of work that would otherwise need to be performed by the application.



        There are requirements for both connectionless and connection-oriented transport protocols. The predecessor to IPv4 actually had the equivalent of IP and TCP as a single protocol, but it became necessary to split them because some transport protocols need to be connectionless.






        share|improve this answer














        IPv6 does not have a NAT standard as IPv4 does (NAT breaks the end-to-end premise of IP, and IPv6 was designed to restore that). There is an experimental RFC for IPv6 NAT, but it is a one-to-one NAT at the network layer, rather than something like the IPv4 NAPT that also translates port addresses, and, in fact, the experimental IPv6 NAT RFC expressly forbids that.



        If you think about the various transport protocols, TCP and UDP use ports, which are really addresses for those transport protocols. Other transport protocols may use other addressing, and some use no addresses.



        Your idea would possibly work with either TCP or UDP, but only one, and probably not with other transport protocols. IPv6 is connectionless, like UDP, so it may work with UDP, but TCP is connection-oriented, and it performs a lot of work that would otherwise need to be performed by the application.



        There are requirements for both connectionless and connection-oriented transport protocols. The predecessor to IPv4 actually had the equivalent of IP and TCP as a single protocol, but it became necessary to split them because some transport protocols need to be connectionless.







        share|improve this answer













        share|improve this answer




        share|improve this answer



        share|improve this answer










        answered May 28 at 0:53









        Ron MaupinRon Maupin

        73.6k14 gold badges76 silver badges138 bronze badges




        73.6k14 gold badges76 silver badges138 bronze badges




























            9


















            One drawback is that the upper layers would need to be aware of IP addresses, which sort of violates the layering principle. What would then happen if you switched to IPv4? Or something else?



            How would the upper layers tell the network layer that it should start responding to an IP address? Suppose a new application starts up. How does the network layer know there's a new address to respond to?



            IPv6 could theoretically eliminate NAT, but there are still reasons why an organization might want to hide its internal IP addresses.






            share|improve this answer



























            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              Jun 5 at 1:44
















            9


















            One drawback is that the upper layers would need to be aware of IP addresses, which sort of violates the layering principle. What would then happen if you switched to IPv4? Or something else?



            How would the upper layers tell the network layer that it should start responding to an IP address? Suppose a new application starts up. How does the network layer know there's a new address to respond to?



            IPv6 could theoretically eliminate NAT, but there are still reasons why an organization might want to hide its internal IP addresses.






            share|improve this answer



























            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              Jun 5 at 1:44














            9














            9










            9









            One drawback is that the upper layers would need to be aware of IP addresses, which sort of violates the layering principle. What would then happen if you switched to IPv4? Or something else?



            How would the upper layers tell the network layer that it should start responding to an IP address? Suppose a new application starts up. How does the network layer know there's a new address to respond to?



            IPv6 could theoretically eliminate NAT, but there are still reasons why an organization might want to hide its internal IP addresses.






            share|improve this answer














            One drawback is that the upper layers would need to be aware of IP addresses, which sort of violates the layering principle. What would then happen if you switched to IPv4? Or something else?



            How would the upper layers tell the network layer that it should start responding to an IP address? Suppose a new application starts up. How does the network layer know there's a new address to respond to?



            IPv6 could theoretically eliminate NAT, but there are still reasons why an organization might want to hide its internal IP addresses.







            share|improve this answer













            share|improve this answer




            share|improve this answer



            share|improve this answer










            answered May 27 at 20:02









            Ron TrunkRon Trunk

            45.9k3 gold badges43 silver badges95 bronze badges




            45.9k3 gold badges43 silver badges95 bronze badges
















            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              Jun 5 at 1:44



















            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              Jun 5 at 1:44

















            Comments are not for extended discussion; this conversation has been moved to chat.

            – Ron Maupin
            Jun 5 at 1:44





            Comments are not for extended discussion; this conversation has been moved to chat.

            – Ron Maupin
            Jun 5 at 1:44











            6


















            The need for NATs as a way to share public IP adresses will be gone with IPv6, but NATs may still have some uses for security reasons.



            Removing ports might be possible in theory, but it would be a huge undertaking. Even if you reserve the last 16 bits of the IP adress for port number + 1 bit for TCP/UDP flag, you would need to rework all the software that unpacks the pactet from the 3rd layer into the 4th one to use the bits from IP adress for port number and protocol, instead of data in the packet.



            And that's the "easy" solution when you just put the port nubmers in the IP adress, if you wanted to get rid or port numbers altogether, you would need to change every software and library that uses ports, be it servers, clients, firewalls, etc etc. It would be basicly impossible, every software that says "open server at port X" which would work fine when just going from IPv4 to IPv6 would break instantly if you remove ports altogether.



            It is infinetely more easier to just keep the ports.






            share|improve this answer



























            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 29 at 22:03
















            6


















            The need for NATs as a way to share public IP adresses will be gone with IPv6, but NATs may still have some uses for security reasons.



            Removing ports might be possible in theory, but it would be a huge undertaking. Even if you reserve the last 16 bits of the IP adress for port number + 1 bit for TCP/UDP flag, you would need to rework all the software that unpacks the pactet from the 3rd layer into the 4th one to use the bits from IP adress for port number and protocol, instead of data in the packet.



            And that's the "easy" solution when you just put the port nubmers in the IP adress, if you wanted to get rid or port numbers altogether, you would need to change every software and library that uses ports, be it servers, clients, firewalls, etc etc. It would be basicly impossible, every software that says "open server at port X" which would work fine when just going from IPv4 to IPv6 would break instantly if you remove ports altogether.



            It is infinetely more easier to just keep the ports.






            share|improve this answer



























            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 29 at 22:03














            6














            6










            6









            The need for NATs as a way to share public IP adresses will be gone with IPv6, but NATs may still have some uses for security reasons.



            Removing ports might be possible in theory, but it would be a huge undertaking. Even if you reserve the last 16 bits of the IP adress for port number + 1 bit for TCP/UDP flag, you would need to rework all the software that unpacks the pactet from the 3rd layer into the 4th one to use the bits from IP adress for port number and protocol, instead of data in the packet.



            And that's the "easy" solution when you just put the port nubmers in the IP adress, if you wanted to get rid or port numbers altogether, you would need to change every software and library that uses ports, be it servers, clients, firewalls, etc etc. It would be basicly impossible, every software that says "open server at port X" which would work fine when just going from IPv4 to IPv6 would break instantly if you remove ports altogether.



            It is infinetely more easier to just keep the ports.






            share|improve this answer














            The need for NATs as a way to share public IP adresses will be gone with IPv6, but NATs may still have some uses for security reasons.



            Removing ports might be possible in theory, but it would be a huge undertaking. Even if you reserve the last 16 bits of the IP adress for port number + 1 bit for TCP/UDP flag, you would need to rework all the software that unpacks the pactet from the 3rd layer into the 4th one to use the bits from IP adress for port number and protocol, instead of data in the packet.



            And that's the "easy" solution when you just put the port nubmers in the IP adress, if you wanted to get rid or port numbers altogether, you would need to change every software and library that uses ports, be it servers, clients, firewalls, etc etc. It would be basicly impossible, every software that says "open server at port X" which would work fine when just going from IPv4 to IPv6 would break instantly if you remove ports altogether.



            It is infinetely more easier to just keep the ports.







            share|improve this answer













            share|improve this answer




            share|improve this answer



            share|improve this answer










            answered May 28 at 9:04









            Dogukan - Malt.fr - WordPressDogukan - Malt.fr - WordPress

            1613 bronze badges




            1613 bronze badges
















            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 29 at 22:03



















            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 29 at 22:03

















            Comments are not for extended discussion; this conversation has been moved to chat.

            – Ron Maupin
            May 29 at 22:03





            Comments are not for extended discussion; this conversation has been moved to chat.

            – Ron Maupin
            May 29 at 22:03











            4


















            It wouldn't be IPv6. Such a system is of course feasible, but it would be an variation of the IP protocol. Today, IP's contain two parts: a host identifier and a service identifier.



            With your scheme, it would essentially be a service descriptor. This would require changes to DNS (e.g. how do you differentiate between the SMTP server for example.com and the www-server for example.com?)



            I can't see how it would be beneficial over todays system with host:service descriptors. It would not achieve anything not possible today.






            share|improve this answer



























            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 30 at 0:46
















            4


















            It wouldn't be IPv6. Such a system is of course feasible, but it would be an variation of the IP protocol. Today, IP's contain two parts: a host identifier and a service identifier.



            With your scheme, it would essentially be a service descriptor. This would require changes to DNS (e.g. how do you differentiate between the SMTP server for example.com and the www-server for example.com?)



            I can't see how it would be beneficial over todays system with host:service descriptors. It would not achieve anything not possible today.






            share|improve this answer



























            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 30 at 0:46














            4














            4










            4









            It wouldn't be IPv6. Such a system is of course feasible, but it would be an variation of the IP protocol. Today, IP's contain two parts: a host identifier and a service identifier.



            With your scheme, it would essentially be a service descriptor. This would require changes to DNS (e.g. how do you differentiate between the SMTP server for example.com and the www-server for example.com?)



            I can't see how it would be beneficial over todays system with host:service descriptors. It would not achieve anything not possible today.






            share|improve this answer














            It wouldn't be IPv6. Such a system is of course feasible, but it would be an variation of the IP protocol. Today, IP's contain two parts: a host identifier and a service identifier.



            With your scheme, it would essentially be a service descriptor. This would require changes to DNS (e.g. how do you differentiate between the SMTP server for example.com and the www-server for example.com?)



            I can't see how it would be beneficial over todays system with host:service descriptors. It would not achieve anything not possible today.







            share|improve this answer













            share|improve this answer




            share|improve this answer



            share|improve this answer










            answered May 27 at 20:04









            vidarlovidarlo

            2631 silver badge7 bronze badges




            2631 silver badge7 bronze badges
















            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 30 at 0:46



















            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 30 at 0:46

















            Comments are not for extended discussion; this conversation has been moved to chat.

            – Ron Maupin
            May 30 at 0:46





            Comments are not for extended discussion; this conversation has been moved to chat.

            – Ron Maupin
            May 30 at 0:46











            0


















            As others have said, having port numbers is a requirement, even if they end up being 'encoded' in the IP address of the service.



            Some applications need more than one port number. For example, most web servers need port 80 and 443 (and maybe another port for websockets or whatever). Such a system would need three IP addresses with encoded ports. Whilst we've got plenty of IPs, it would (at present) mean system-level configuration would be required to support those three port numbers. Using a separate port number means the apps can just start up and use the ports without needing the sysadmin to do some config work first. As others have said - it's just easier to use a port number.



            As for NAT, yes, IPv6 should remove the need for NAT in almost all cases. Some cases remain though, so it probably won't disappear entirely, but wide-spread use is likely to diminish significantly.






            share|improve this answer



























            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 30 at 0:46
















            0


















            As others have said, having port numbers is a requirement, even if they end up being 'encoded' in the IP address of the service.



            Some applications need more than one port number. For example, most web servers need port 80 and 443 (and maybe another port for websockets or whatever). Such a system would need three IP addresses with encoded ports. Whilst we've got plenty of IPs, it would (at present) mean system-level configuration would be required to support those three port numbers. Using a separate port number means the apps can just start up and use the ports without needing the sysadmin to do some config work first. As others have said - it's just easier to use a port number.



            As for NAT, yes, IPv6 should remove the need for NAT in almost all cases. Some cases remain though, so it probably won't disappear entirely, but wide-spread use is likely to diminish significantly.






            share|improve this answer



























            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 30 at 0:46














            0














            0










            0









            As others have said, having port numbers is a requirement, even if they end up being 'encoded' in the IP address of the service.



            Some applications need more than one port number. For example, most web servers need port 80 and 443 (and maybe another port for websockets or whatever). Such a system would need three IP addresses with encoded ports. Whilst we've got plenty of IPs, it would (at present) mean system-level configuration would be required to support those three port numbers. Using a separate port number means the apps can just start up and use the ports without needing the sysadmin to do some config work first. As others have said - it's just easier to use a port number.



            As for NAT, yes, IPv6 should remove the need for NAT in almost all cases. Some cases remain though, so it probably won't disappear entirely, but wide-spread use is likely to diminish significantly.






            share|improve this answer














            As others have said, having port numbers is a requirement, even if they end up being 'encoded' in the IP address of the service.



            Some applications need more than one port number. For example, most web servers need port 80 and 443 (and maybe another port for websockets or whatever). Such a system would need three IP addresses with encoded ports. Whilst we've got plenty of IPs, it would (at present) mean system-level configuration would be required to support those three port numbers. Using a separate port number means the apps can just start up and use the ports without needing the sysadmin to do some config work first. As others have said - it's just easier to use a port number.



            As for NAT, yes, IPv6 should remove the need for NAT in almost all cases. Some cases remain though, so it probably won't disappear entirely, but wide-spread use is likely to diminish significantly.







            share|improve this answer













            share|improve this answer




            share|improve this answer



            share|improve this answer










            answered May 28 at 9:36









            Ralph BoltonRalph Bolton

            101




            101
















            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 30 at 0:46



















            • Comments are not for extended discussion; this conversation has been moved to chat.

              – Ron Maupin
              May 30 at 0:46

















            Comments are not for extended discussion; this conversation has been moved to chat.

            – Ron Maupin
            May 30 at 0:46





            Comments are not for extended discussion; this conversation has been moved to chat.

            – Ron Maupin
            May 30 at 0:46











            0


















            IP Addresses and Ports, though usually seen together, perform very distinct tasks. IP Addresses are used to route traffic to your computer specifically and port numbers are used by applications.



            A very good analogy is sending mail to an apartment building. The address of the building would be equivalent to an IP address and the unit numbers would be analogous to a port number. For this analogy we'll say the building's address is 127 Home Ave. Say you wanted to send a letter to Henry T.T. Peterson, so you send a letter to the building, he doesn't receive it because it needs further direction to his apartment, apartment 80.



            In theory, IPv6 address could take the place of both IPv4 addresses and port numbers, however this violates well-established precedents of networking and there are some major drawbacks:




            • Defeats the very purpose that IPv6 was created to alleviate(concerns about the world running out of IP addresses)

            • Routing tables internal to routers and switches would become exponentially larger while offering no benefit(many address will route to the same physical computer)

            • Every application on every computer will need a unique address and although IPv6 offers many, many times more addresses (2^128 vs 2^32), we will run out rather quickly and then need to create IPv8, then IPv10, then IPv12, we will be racing an exponential curve and that pretty much won't be a fun time.


            As far as NAT goes, this was created for 2 reasons, there were already concerns that the world was running out of (or would run out of) public IP addresses, which was massively alleviated by allowing for organizations and even home networks an incredible amount of IP addresses that can be used internally, and allows for important machines to be "hidden" from the world (such as your database with sensitive information on it, or the CEO's laptop)



            I hope this explanation was helpful; you see, both NAT and port numbers are a good thing, we wouldn't want to replace them with IPv6 because that is a huge step backwards, if anything we'd want to actually expand them, or replace them with something even better






            share|improve this answer






















            • 1





              1. "Defeats the very purpose that IPv6" - No it wouldn't, your computer probably has several IPv6 addresses already with no issues. At least 2^64 addresses are reserved for a typical home network. "Routing tables would become larger" - No they wouldn't, there's just one routing table entry for your whole network. (And when you look from outside of your ISP, there's just one entry for your whole ISP.) You really underestimate how big 2^128 is. Say you treated the last 16 bits as a port number (which is probably not how this would work), you still have 2^112 computer addresses.

              – immibis
              May 28 at 23:54











            • (In reality most computers don't use all 65536 ports either. I'd guesstimate it's less than 100 99% of the time)

              – immibis
              May 28 at 23:56













            • @immibis you covered everything I was thinking while reading the post

              – Tobiq
              May 29 at 10:44
















            0


















            IP Addresses and Ports, though usually seen together, perform very distinct tasks. IP Addresses are used to route traffic to your computer specifically and port numbers are used by applications.



            A very good analogy is sending mail to an apartment building. The address of the building would be equivalent to an IP address and the unit numbers would be analogous to a port number. For this analogy we'll say the building's address is 127 Home Ave. Say you wanted to send a letter to Henry T.T. Peterson, so you send a letter to the building, he doesn't receive it because it needs further direction to his apartment, apartment 80.



            In theory, IPv6 address could take the place of both IPv4 addresses and port numbers, however this violates well-established precedents of networking and there are some major drawbacks:




            • Defeats the very purpose that IPv6 was created to alleviate(concerns about the world running out of IP addresses)

            • Routing tables internal to routers and switches would become exponentially larger while offering no benefit(many address will route to the same physical computer)

            • Every application on every computer will need a unique address and although IPv6 offers many, many times more addresses (2^128 vs 2^32), we will run out rather quickly and then need to create IPv8, then IPv10, then IPv12, we will be racing an exponential curve and that pretty much won't be a fun time.


            As far as NAT goes, this was created for 2 reasons, there were already concerns that the world was running out of (or would run out of) public IP addresses, which was massively alleviated by allowing for organizations and even home networks an incredible amount of IP addresses that can be used internally, and allows for important machines to be "hidden" from the world (such as your database with sensitive information on it, or the CEO's laptop)



            I hope this explanation was helpful; you see, both NAT and port numbers are a good thing, we wouldn't want to replace them with IPv6 because that is a huge step backwards, if anything we'd want to actually expand them, or replace them with something even better






            share|improve this answer






















            • 1





              1. "Defeats the very purpose that IPv6" - No it wouldn't, your computer probably has several IPv6 addresses already with no issues. At least 2^64 addresses are reserved for a typical home network. "Routing tables would become larger" - No they wouldn't, there's just one routing table entry for your whole network. (And when you look from outside of your ISP, there's just one entry for your whole ISP.) You really underestimate how big 2^128 is. Say you treated the last 16 bits as a port number (which is probably not how this would work), you still have 2^112 computer addresses.

              – immibis
              May 28 at 23:54











            • (In reality most computers don't use all 65536 ports either. I'd guesstimate it's less than 100 99% of the time)

              – immibis
              May 28 at 23:56













            • @immibis you covered everything I was thinking while reading the post

              – Tobiq
              May 29 at 10:44














            0














            0










            0









            IP Addresses and Ports, though usually seen together, perform very distinct tasks. IP Addresses are used to route traffic to your computer specifically and port numbers are used by applications.



            A very good analogy is sending mail to an apartment building. The address of the building would be equivalent to an IP address and the unit numbers would be analogous to a port number. For this analogy we'll say the building's address is 127 Home Ave. Say you wanted to send a letter to Henry T.T. Peterson, so you send a letter to the building, he doesn't receive it because it needs further direction to his apartment, apartment 80.



            In theory, IPv6 address could take the place of both IPv4 addresses and port numbers, however this violates well-established precedents of networking and there are some major drawbacks:




            • Defeats the very purpose that IPv6 was created to alleviate(concerns about the world running out of IP addresses)

            • Routing tables internal to routers and switches would become exponentially larger while offering no benefit(many address will route to the same physical computer)

            • Every application on every computer will need a unique address and although IPv6 offers many, many times more addresses (2^128 vs 2^32), we will run out rather quickly and then need to create IPv8, then IPv10, then IPv12, we will be racing an exponential curve and that pretty much won't be a fun time.


            As far as NAT goes, this was created for 2 reasons, there were already concerns that the world was running out of (or would run out of) public IP addresses, which was massively alleviated by allowing for organizations and even home networks an incredible amount of IP addresses that can be used internally, and allows for important machines to be "hidden" from the world (such as your database with sensitive information on it, or the CEO's laptop)



            I hope this explanation was helpful; you see, both NAT and port numbers are a good thing, we wouldn't want to replace them with IPv6 because that is a huge step backwards, if anything we'd want to actually expand them, or replace them with something even better






            share|improve this answer














            IP Addresses and Ports, though usually seen together, perform very distinct tasks. IP Addresses are used to route traffic to your computer specifically and port numbers are used by applications.



            A very good analogy is sending mail to an apartment building. The address of the building would be equivalent to an IP address and the unit numbers would be analogous to a port number. For this analogy we'll say the building's address is 127 Home Ave. Say you wanted to send a letter to Henry T.T. Peterson, so you send a letter to the building, he doesn't receive it because it needs further direction to his apartment, apartment 80.



            In theory, IPv6 address could take the place of both IPv4 addresses and port numbers, however this violates well-established precedents of networking and there are some major drawbacks:




            • Defeats the very purpose that IPv6 was created to alleviate(concerns about the world running out of IP addresses)

            • Routing tables internal to routers and switches would become exponentially larger while offering no benefit(many address will route to the same physical computer)

            • Every application on every computer will need a unique address and although IPv6 offers many, many times more addresses (2^128 vs 2^32), we will run out rather quickly and then need to create IPv8, then IPv10, then IPv12, we will be racing an exponential curve and that pretty much won't be a fun time.


            As far as NAT goes, this was created for 2 reasons, there were already concerns that the world was running out of (or would run out of) public IP addresses, which was massively alleviated by allowing for organizations and even home networks an incredible amount of IP addresses that can be used internally, and allows for important machines to be "hidden" from the world (such as your database with sensitive information on it, or the CEO's laptop)



            I hope this explanation was helpful; you see, both NAT and port numbers are a good thing, we wouldn't want to replace them with IPv6 because that is a huge step backwards, if anything we'd want to actually expand them, or replace them with something even better







            share|improve this answer













            share|improve this answer




            share|improve this answer



            share|improve this answer










            answered May 28 at 14:47









            DreadedEntityDreadedEntity

            91 bronze badge




            91 bronze badge











            • 1





              1. "Defeats the very purpose that IPv6" - No it wouldn't, your computer probably has several IPv6 addresses already with no issues. At least 2^64 addresses are reserved for a typical home network. "Routing tables would become larger" - No they wouldn't, there's just one routing table entry for your whole network. (And when you look from outside of your ISP, there's just one entry for your whole ISP.) You really underestimate how big 2^128 is. Say you treated the last 16 bits as a port number (which is probably not how this would work), you still have 2^112 computer addresses.

              – immibis
              May 28 at 23:54











            • (In reality most computers don't use all 65536 ports either. I'd guesstimate it's less than 100 99% of the time)

              – immibis
              May 28 at 23:56













            • @immibis you covered everything I was thinking while reading the post

              – Tobiq
              May 29 at 10:44














            • 1





              1. "Defeats the very purpose that IPv6" - No it wouldn't, your computer probably has several IPv6 addresses already with no issues. At least 2^64 addresses are reserved for a typical home network. "Routing tables would become larger" - No they wouldn't, there's just one routing table entry for your whole network. (And when you look from outside of your ISP, there's just one entry for your whole ISP.) You really underestimate how big 2^128 is. Say you treated the last 16 bits as a port number (which is probably not how this would work), you still have 2^112 computer addresses.

              – immibis
              May 28 at 23:54











            • (In reality most computers don't use all 65536 ports either. I'd guesstimate it's less than 100 99% of the time)

              – immibis
              May 28 at 23:56













            • @immibis you covered everything I was thinking while reading the post

              – Tobiq
              May 29 at 10:44








            1




            1





            1. "Defeats the very purpose that IPv6" - No it wouldn't, your computer probably has several IPv6 addresses already with no issues. At least 2^64 addresses are reserved for a typical home network. "Routing tables would become larger" - No they wouldn't, there's just one routing table entry for your whole network. (And when you look from outside of your ISP, there's just one entry for your whole ISP.) You really underestimate how big 2^128 is. Say you treated the last 16 bits as a port number (which is probably not how this would work), you still have 2^112 computer addresses.

            – immibis
            May 28 at 23:54





            1. "Defeats the very purpose that IPv6" - No it wouldn't, your computer probably has several IPv6 addresses already with no issues. At least 2^64 addresses are reserved for a typical home network. "Routing tables would become larger" - No they wouldn't, there's just one routing table entry for your whole network. (And when you look from outside of your ISP, there's just one entry for your whole ISP.) You really underestimate how big 2^128 is. Say you treated the last 16 bits as a port number (which is probably not how this would work), you still have 2^112 computer addresses.

            – immibis
            May 28 at 23:54













            (In reality most computers don't use all 65536 ports either. I'd guesstimate it's less than 100 99% of the time)

            – immibis
            May 28 at 23:56







            (In reality most computers don't use all 65536 ports either. I'd guesstimate it's less than 100 99% of the time)

            – immibis
            May 28 at 23:56















            @immibis you covered everything I was thinking while reading the post

            – Tobiq
            May 29 at 10:44





            @immibis you covered everything I was thinking while reading the post

            – Tobiq
            May 29 at 10:44



















            draft saved

            draft discarded



















































            Thanks for contributing an answer to Network Engineering Stack Exchange!


            • Please be sure to answer the question. Provide details and share your research!

            But avoid



            • Asking for help, clarification, or responding to other answers.

            • Making statements based on opinion; back them up with references or personal experience.


            To learn more, see our tips on writing great answers.




            draft saved


            draft discarded














            StackExchange.ready(
            function () {
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fnetworkengineering.stackexchange.com%2fquestions%2f59438%2fcould-ipv6-make-nat-port-numbers-redundant%23new-answer', 'question_page');
            }
            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown









            Popular posts from this blog

            Bruad Bilen | Luke uk diar | NawigatsjuunCommonskategorii: BruadCommonskategorii: RunstükenWikiquote: Bruad

            Færeyskur hestur Heimild | Tengill | Tilvísanir | LeiðsagnarvalRossið - síða um færeyska hrossið á færeyskuGott ár hjá færeyska hestinum

            He _____ here since 1970 . Answer needed [closed]What does “since he was so high” mean?Meaning of “catch birds for”?How do I ensure “since” takes the meaning I want?“Who cares here” meaningWhat does “right round toward” mean?the time tense (had now been detected)What does the phrase “ring around the roses” mean here?Correct usage of “visited upon”Meaning of “foiled rail sabotage bid”It was the third time I had gone to Rome or It is the third time I had been to Rome