Engineering:Router (computing)

From HandWiki
Short description: Device that forwards data packets between computer networks
Rack containing a service-provider–class router connected to multiple networks

A router[lower-alpha 1] is a networking device that forwards data packets between computer networks.[2][3] Routers perform the traffic directing functions between networks and on the global Internet. Data sent through a network, such as a web page or email, is in the form of data packets. A packet is typically forwarded from one router to another router through the networks that constitute an internetwork (e.g. the Internet) until it reaches its destination node.[4]

A router is connected to two or more data lines from different IP networks.[lower-alpha 2] When a data packet comes in on one of the lines, the router reads the network address information in the packet header to determine the ultimate destination. Then, using information in its routing table or routing policy, it directs the packet to the next network on its journey.

The most familiar type of IP routers are home and small office routers that simply forward IP packets between the home computers and the Internet. More sophisticated routers, such as enterprise routers, connect large business or ISP networks up to the powerful core routers that forward data at high speed along the optical fiber lines of the Internet backbone.

A carrier class router with 10G/40G/100G interfaces and redundant processor/power/fan modules

Routers can be built from standard computer parts but are mostly specialized purpose-built computers. Early routers used software-based forwarding, running on a CPU. More sophisticated devices use application-specific integrated circuits (ASICs) to increase performance or add advanced filtering and firewall functionality.

Operation

When multiple routers are used in interconnected networks, the routers can exchange information about destination addresses using a routing protocol. Each router builds up a routing table, a list of routes, between two computer systems on the interconnected networks.[5]

The software that runs the router is composed of two functional processing units that operate simultaneously, called planes:[6]

  • Control plane: A router maintains a routing table that lists which route should be used to forward a data packet, and through which physical interface connection. It does this using internal pre-configured directives, called static routes, or by learning routes dynamically using a routing protocol. Static and dynamic routes are stored in the routing table. The control-plane logic then strips non-essential directives from the table and builds a forwarding information base (FIB) to be used by the forwarding plane.
  • Forwarding plane: This unit forwards the data packets between incoming and outgoing interface connections. It reads the header of each packet as it comes in, matches the destination to entries in the FIB supplied by the control plane, and directs the packet to the outgoing network specified in the FIB.

Applications

A typical home or small office DSL router showing the telephone socket (left, white) to connect it to the internet using ADSL, and Ethernet jacks (right, yellow) to connect it to home computers and printers.

A router may have interfaces for multiple types of physical layer connections, such as copper cables, fiber optic, or wireless transmission. It can also support multiple network layer transmission standards. Each network interface is used to enable data packets to be forwarded from one transmission system to another. Routers may also be used to connect two or more logical groups of computer devices known as subnets, each with a unique network prefix.

Routers may provide connectivity within enterprises, between enterprises and the Internet, or between internet service providers' (ISPs') networks. The largest routers (such as the Cisco CRS-1 or Juniper PTX) interconnect the various ISPs, or may be used in large enterprise networks.[7] Smaller routers usually provide connectivity for typical home and office networks.

All sizes of routers may be found inside enterprises.[8] The most powerful routers are usually found in ISPs, academic and research facilities. Large businesses may also need more powerful routers to cope with ever-increasing demands of intranet data traffic. A hierarchical internetworking model for interconnecting routers in large networks is in common use.[9]

Access, core and distribution

A screenshot of the LuCI web interface used by OpenWrt. This page configures Dynamic DNS.

Access routers, including small office/home office (SOHO) models, are located at home and customer sites such as branch offices that do not need hierarchical routing of their own. Typically, they are optimized for low cost. Some SOHO routers are capable of running alternative free Linux-based firmware like Tomato, OpenWrt, or DD-WRT.[10]

Distribution routers aggregate traffic from multiple access routers. Distribution routers are often responsible for enforcing quality of service across a wide area network (WAN), so they may have considerable memory installed, multiple WAN interface connections, and substantial onboard data processing routines. They may also provide connectivity to groups of file servers or other external networks.[11]

In enterprises, a core router may provide a collapsed backbone interconnecting the distribution tier routers from multiple buildings of a campus, or large enterprise locations. They tend to be optimized for high bandwidth, but lack some of the features of edge routers.[12]

Security

External networks must be carefully considered as part of the overall security strategy of the local network. A router may include a firewall, VPN handling, and other security functions, or they may be handled by separate devices. Routers also commonly perform network address translation which restricts connections initiated from external connections but is not recognized as a security feature by all experts.[13] Some experts argue that open source routers are more secure and reliable than closed source routers because open-source routers allow mistakes to be quickly found and corrected.[14]

Routing different networks

Routers are also often distinguished on the basis of the network in which they operate. A router in a local area network (LAN) of a single organisation is called an interior router. A router that is operated in the Internet backbone is described as exterior router. While a router that connects a LAN with the Internet or a wide area network (WAN) is called a border router, or gateway router.[15]

Internet connectivity and internal use

Routers intended for ISP and major enterprise connectivity usually exchange routing information using the Border Gateway Protocol (BGP). RFC 4098 defines the types of BGP routers according to their functions:[16]

  • Edge router: Placed at the edge of an ISP network, where the router is used to peer with the bilateral peers of upstream IP transit providers, through IXP or Private Network Interconnect (PNI) peers through extensive use of Exterior Border Gateway Protocol (eBGP).[citation needed]
  • Provider edge router: An MPLS-specific router in the network's access layer that interconnects with customer edge routers to provide layer 2 or layer 3 VPN services.[citation needed]
  • Subscriber edge router (also called a customer edge router): Located at the edge of the subscriber's network, it also uses EBGP to its provider's autonomous system. It is typically used in an (enterprise) organization.
  • Inter-provider border router: A BGP router for interconnecting ISPs that maintains BGP sessions with other BGP routers in ISP Autonomous Systems.
  • Core router: Resides within an Autonomous System as a backbone to carry traffic between edge routers.[17]
  • Within an ISP: In the ISP's autonomous system, a router uses internal BGP to communicate with other ISP edge routers, other intranet core routers, or the ISP's intranet provider border routers.
  • Internet backbone: The Internet no longer has a clearly identifiable backbone, unlike its predecessor networks. See default-free zone (DFZ). The major ISPs' system routers make up what could be considered to be the current Internet backbone core.[18] ISPs operate all four types of the BGP routers described here. An ISP core router is used to interconnect its edge and border routers. Core routers may also have specialized functions in virtual private networks based on a combination of BGP and Multiprotocol Label Switching protocols.[19]
  • Port forwarding: Routers are also used for port forwarding between private Internet-connected servers.[8]
  • Voice, data, fax, and video processing routers: Commonly referred to as access servers or gateways, these devices are used to route and process voice, data, video and fax traffic on the Internet. Since 2005, most long-distance phone calls have been processed as IP traffic (VOIP) through a voice gateway. Use of access server-type routers expanded with the advent of the Internet, first with dial-up access and another resurgence with voice phone service.
  • Larger networks commonly use multilayer switches, with layer-3 devices being used to simply interconnect multiple subnets within the same security zone, and higher-layer switches when filtering, translation, load balancing, or other higher-level functions are required, especially between zones.

History

The first ARPANET router, the Interface Message Processor, was delivered to UCLA August 30, 1969, and went online October 29, 1969.

The concept of an interface computer was first proposed by Donald Davies for the NPL network in 1966.[20] The same idea was conceived by Wesley Clark the following year for use in the ARPANET.[21] Named Interface Message Processors (IMPs), these computers had fundamentally the same functionality as a router does today. The idea for a router (called gateway at the time) initially came about through an international group of computer networking researchers called the International Network Working Group (INWG). Set up in 1972 as an informal group to consider the technical issues involved in connecting different networks, it became a subcommittee of the International Federation for Information Processing later that year.[22] These gateway devices were different from most previous packet switching schemes in two ways. First, they connected dissimilar kinds of networks, such as serial lines and local area networks. Second, they were connectionless devices, which had no role in assuring that traffic was delivered reliably, leaving that function entirely to the hosts. This particular idea, the end-to-end principle, had been previously pioneered in the CYCLADES network.[23]

The idea was explored in more detail, with the intention to produce a prototype system as part of two contemporaneous programs. One was the initial DARPA-initiated program, which created the TCP/IP architecture in use today.[24] The other was a program at Xerox PARC to explore new networking technologies, which produced the PARC Universal Packet system; due to corporate intellectual property concerns it received little attention outside Xerox for years.[25] Some time after early 1974, the first Xerox routers became operational. The first true IP router was developed by Ginny Strazisar at BBN, as part of that DARPA-initiated effort, during 1975–1976.[26] By the end of 1976, three PDP-11-based routers were in service in the experimental prototype Internet.[27]

The first multiprotocol routers were independently created by staff researchers at MIT and Stanford in 1981 and both were also based on PDP-11s. Stanford's router program was led by William Yeager and MIT's by Noel Chiappa.[28][29][30][31] Virtually all networking now uses TCP/IP, but multiprotocol routers are still manufactured. They were important in the early stages of the growth of computer networking when protocols other than TCP/IP were in use. Modern routers that handle both IPv4 and IPv6 are multiprotocol but are simpler devices than ones processing AppleTalk, DECnet, IPX, and Xerox protocols.

From the mid-1970s and in the 1980s, general-purpose minicomputers served as routers. Modern high-speed routers are network processors or highly specialized computers with extra hardware acceleration added to speed both common routing functions, such as packet forwarding, and specialized functions such as IPsec encryption. There is substantial use of Linux and Unix software-based machines, running open source routing code, for research and other applications. The Cisco IOS operating system was independently designed. Major router operating systems, such as Junos and NX-OS, are extensively modified versions of Unix software.

Forwarding

The main purpose of a router is to connect multiple networks and forward packets destined either for directly attached networks or more remote networks. A router is considered a layer-3 device because its primary forwarding decision is based on the information in the layer-3 IP packet, specifically the destination IP address. When a router receives a packet, it searches its routing table to find the best match between the destination IP address of the packet and one of the addresses in the routing table. Once a match is found, the packet is encapsulated in the layer-2 data link frame for the outgoing interface indicated in the table entry. A router typically does not look into the packet payload,[32] but only at the layer-3 addresses to make a forwarding decision, plus optionally other information in the header for hints on, for example, quality of service (QoS). For pure IP forwarding, a router is designed to minimize the state information associated with individual packets.[33] Once a packet is forwarded, the router does not retain any historical information about the packet.[lower-alpha 3]

The routing table itself can contain information derived from a variety of sources, such as a default or static routes that are configured manually, or dynamic entries from routing protocols where the router learns routes from other routers. A default route is one that is used to route all traffic whose destination does not otherwise appear in the routing table; it is common – even necessary – in small networks, such as a home or small business where the default route simply sends all non-local traffic to the Internet service provider. The default route can be manually configured (as a static route); learned by dynamic routing protocols; or be obtained by DHCP.[lower-alpha 4][34]

A router can run more than one routing protocol at a time, particularly if it serves as an autonomous system border router between parts of a network that run different routing protocols; if it does so, then redistribution may be used (usually selectively) to share information between the different protocols running on the same router.[35]

Besides deciding to which interface a packet is forwarded, which is handled primarily via the routing table, a router also has to manage congestion when packets arrive at a rate higher than the router can process. Three policies commonly used are tail drop, random early detection (RED), and weighted random early detection (WRED). Tail drop is the simplest and most easily implemented: the router simply drops new incoming packets once buffer space in the router is exhausted. RED probabilistically drops datagrams early when the queue exceeds a pre-configured portion of the buffer, until reaching a pre-determined maximum, when it drops all incoming packets, thus reverting to tail drop. WRED can be configured to drop packets more readily dependent on the type of traffic.

Another function a router performs is traffic classification and deciding which packet should be processed first. This is managed through QoS, which is critical when Voice over IP is deployed, so as not to introduce excessive latency.[36]

Yet another function a router performs is called policy-based routing where special rules are constructed to override the rules derived from the routing table when a packet forwarding decision is made.[37]

Some of the functions may be performed through an application-specific integrated circuit (ASIC) to avoid overhead of scheduling CPU time to process the packets. Others may have to be performed through the CPU as these packets need special attention that cannot be handled by an ASIC.[38]

See also

Notes

  1. Pronounced /ˈrtər/ in British English, /ˈrtər/ in American and Australian English.[1]
  2. As opposed to a network switch, which connects data lines from one single network
  3. In some router implementations, the forwarding action can increment a counter associated with the routing table entry for the collection of statistical data.
  4. A router can serve as a DHCP client or as a DHCP server.

References

  1. router (3rd ed.), Oxford University Press, September 2005, http://oed.com/search?searchType=dictionary&q=router  (Subscription or UK public library membership required.)
  2. Medhi, Deepankar; Ramasamy, Karthik (2007). Network Routing: Algorithms, Protocols, and Architectures. Elsevier. pp. 19. ISBN 9780120885886. https://books.google.com/books?id=IM-Y2W0RIF0C&dq=%22router+is+a+specialized+computer%22&pg=PA19. 
  3. Kundu, Sudakshina (2009). Fundamentals of Computer Networks, 2nd Ed.. New Delhi: PHI Learning. pp. 85–86, 124. ISBN 9788120334526. https://books.google.com/books?id=OMoHmEQHosAC&q=router%20is%20a. 
  4. "Overview Of Key Routing Protocol Concepts: Architectures, Protocol Types, Algorithms and Metrics". Tcpipguide.com. http://www.tcpipguide.com/free/t_OverviewOfKeyRoutingProtocolConceptsArchitecturesP.htm. 
  5. "Cisco Networking Academy's Introduction to Routing Dynamically". Cisco. http://www.ciscopress.com/articles/article.asp?p=2180210&seqNum=4. 
  6. H. Khosravi & T. Anderson (November 2003), Requirements for Separation of IP Control and Forwarding, doi:10.17487/RFC3654, RFC 3654, https://tools.ietf.org/html/rfc3654 
  7. "Setting uo Netflow on Cisco Routers". MY-Technet.com date unknown. http://my-technet.com/index.php/cisco/setting-up-netflow-on-cisco-routers/. 
  8. 8.0 8.1 "Windows Home Server: Router Setup". Microsoft Technet 14 Aug 2010. http://social.technet.microsoft.com/wiki/contents/articles/windows-home-server-router-setup.aspx. 
  9. Oppenheimer, Pr (2004). Top-Down Network Design. Indianapolis: Cisco Press. ISBN 978-1-58705-152-4. 
  10. "SOHO Network Requirements Planning and Implementation" (in en). https://www.examcollection.com/certification-training/network-plus-soho-network-requirements-planning-and-implementation.html. 
  11. "How Do WiFi Extenders Work? Repeater, Booster, Extender?" (in en-US). 2021-02-25. https://ispfamily.com/how-do-wifi-extenders-work/. 
  12. "Hierarchical Network Design Overview (1.1) > Cisco Networking Academy Connecting Networks Companion Guide: Hierarchical Network Design | Cisco Press". https://www.ciscopress.com/articles/article.asp?p=2202410&seqNum=4. 
  13. "Security Considerations Of NAT". University of Michigan. http://www.safecomputing.umich.edu/protect-personal/download/nat_security.pdf. 
  14. "Global Internet Experts Reveal Plan for More Secure, Reliable Wi-Fi Routers - and Internet" (Press release). 14 October 2015. Archived from the original on 2015-10-20.
  15. Tamara Dean (2009). Network+ Guide to Networks. Cengage Learning. pp. 272. ISBN 9781423902454. 
  16. H. Berkowitz (June 2005), Terminology for Benchmarking BGP Device Convergence in the Control Plane, doi:10.17487/RFC4098, RFC 4098, https://tools.ietf.org/html/rfc4098 
  17. "M160 Internet Backbone Router". Juniper Networks. http://www.juniper.net/techpubs/qrc/m160-qrc.pdf. 
  18. "Virtual Backbone Routers". IronBridge Networks, Inc. September, 2000. http://www.telecomsportal.com/Assets_papers/Routers_&_Netman/Ironbridge_Virt_Bbone_Route.pdf. 
  19. E. Rosen; Y. Rekhter (April 2004), BGP/MPLS VPNs 
  20. Roberts, Dr. Lawrence G. (May 1995). "The ARPANET & Computer Networks". http://www.packet.cc/files/arpanet-computernet.html. "Then in June 1966, Davies wrote a second internal paper, "Proposal for a Digital Communication Network" In which he coined the word packet,- a small sub part of the message the user wants to send, and also introduced the concept of an interface computer to sit between the user equipment and the packet network." 
  21. Pelkey, James. "4.7 Planning the ARPANET: 1967-1968 in Chapter 4 - Networking: Vision and Packet Switching 1959 - 1968". The History of Computer Communications. https://historyofcomputercommunications.info/section/4.7/planning-the-arpanet-1967-1968/. 
  22. Davies, Shanks, Heart, Barker, Despres, Detwiler and Riml, "Report of Subgroup 1 on Communication System", INWG Note No. 1.
  23. Bennett, Richard (September 2009). "Designed for Change: End-to-End Arguments, Internet Innovation, and the Net Neutrality Debate". Information Technology and Innovation Foundation. pp. 7, 11. https://www.itif.org/files/2009-designed-for-change.pdf. 
  24. Vinton Cerf, Robert Kahn, "A Protocol for Packet Network Intercommunication", IEEE Transactions on Communications, Volume 22, Issue 5, May 1974, pp. 637 - 648.
  25. David Boggs, John Shoch, Edward Taft, Robert Metcalfe, "Pup: An Internetwork Architecture" , IEEE Transactions on Communications, Volume 28, Issue 4, April 1980, pp. 612- 624.
  26. "Ms. Ginny Strazisar". 21 December 2015. http://www.ithistory.org/honor-roll/ms-ginny-strazisar. 
  27. Craig Partridge, S. Blumenthal, "Data networking at BBN"; IEEE Annals of the History of Computing, Volume 28, Issue 1; January–March 2006.
  28. Valley of the Nerds: Who Really Invented the Multiprotocol Router, and Why Should We Care? , Public Broadcasting Service, Accessed August 11, 2007.
  29. Router Man , NetworkWorld, Accessed June 22, 2007.
  30. David D. Clark, "M.I.T. Campus Network Implementation", CCNG-2, Campus Computer Network Group, M.I.T., Cambridge, 1982; pp. 26.
  31. Pete Carey, "A Start-Up's True Tale: Often-told story of Cisco's launch leaves out the drama, intrigue", San Jose Mercury News, December 1, 2001.
  32. "Packet Forwarding and Routing on IPv4 Networks - System Administration Guide: IP Services". https://docs.oracle.com/cd/E23823_01/html/816-4554/gcvjj.html. 
  33. Roberts, Lawrence (22 July 2003). "The Next Generation of IP - Flow Routing". http://www.packet.cc/files/FlowPaper/NextGenerationofIP-FlowRouting.htm. 
  34. David Davis (April 19, 2007). "Cisco administration 101: What you need to know about default routes". http://www.techrepublic.com/article/cisco-administration-101-what-you-need-to-know-about-default-routes. 
  35. Diane Teare (March 2013). Implementing Cisco IP Routing (ROUTE): Foundation Learning Guide. Cisco Press. pp. 330–334. 
  36. Donahue, Gary A. (2007-06-21) (in en). Network Warrior. "O'Reilly Media, Inc.". ISBN 978-0-596-10151-0. https://books.google.com/books?id=VqebAgAAQBAJ&dq=Network+Warrior+Voice+over+IP+is+a+udp&pg=PA419. 
  37. Diane Teare (March 2013). "Chapter 5: Implementing Path Control". Implementing Cisco IP-Routing (ROUTE): Foundation Learning Guide. Cisco Press. pp. 330–334. 
  38. Schudel, Gregg; Smith, David (2007-12-29) (in en). Router Security Strategies: Securing IP Network Traffic Planes. Pearson Education. ISBN 978-0-13-279673-6. https://books.google.com/books?id=DZT7I2U58UoC&dq=that+cannot+be+handled+by+an+ASIC&pg=PT93. 

External links