IS-IS
OSI model by layer |
---|
Internet history timeline |
Early research and development:
Merging the networks and creating the Internet:
Commercialization, privatization, broader access leads to the modern Internet:
Examples of Internet services:
|
Intermediate System to Intermediate System (IS-IS, also written ISIS) is a routing protocol designed to move information efficiently within a computer network, a group of physically connected computers or similar devices. It accomplishes this by determining the best route for data through a packet switching network.
The IS-IS protocol is defined in ISO/IEC 10589:2002[2][3] as an international standard within the Open Systems Interconnection (OSI) reference design.
In 2005, IS-IS was called "the de facto standard for large service provider network backbones".[4]
Description
[edit]IS-IS is an interior gateway protocol, designed for use within an administrative domain or network. This is in contrast to exterior gateway protocols, primarily Border Gateway Protocol (BGP), which is used for routing between autonomous systems.[5]
IS-IS is a link-state routing protocol, operating by reliably flooding link state information throughout a network of routers. Each IS-IS router independently builds a database of the network's topology, aggregating the flooded network information. Like the OSPF protocol, IS-IS uses Dijkstra's algorithm for computing the best path through the network. Packets (datagrams) are then forwarded, based on the computed ideal path, through the network to the destination.
History
[edit]The IS-IS protocol was developed by a team of people working at Digital Equipment Corporation as part of DECnet Phase V.
The Internet Engineering Task Force (IETF) published IS-IS in 1990[6], but that RFC was later retracted and marked as historic[7] because it republished a draft rather than a final version of the International Organization for Standardization (ISO) standard, causing confusion.
The protocol was standardized by ISO in 1992 as ISO 10589, for communication between network devices that are termed Intermediate Systems (as opposed to end systems or hosts) by the ISO. The purpose of IS-IS was to make the routing of datagrams possible using the ISO-developed OSI protocol stack called Connectionless-mode Network Service (CLNS). IS-IS was developed at roughly the same time that the Internet Engineering Task Force IETF was developing a similar protocol called OSPF. IS-IS was later extended to support routing of datagrams in the Internet Protocol (IP), the network-layer protocol of the global Internet. This version of the IS-IS routing protocol was then called Integrated IS-IS.[8]
IS-IS terminology
[edit]In IS-IS world there is slightly different terminology which comes from ISO wording. Below is the ISO terminology and its counterpart which is widely used in standards and related documentation.
- Intermediate system - router
- Designated intermediate system - designated router
- End system - host
- Circuit - link
- Adjacency - neighborship
Circuit types
[edit]Compared to OSPF, IS-IS has only two circuit types - broadcast (LAN) and P2P. Therefore, designs such as P2MP are unavailable in IS-IS.
Packet types
[edit]IS-IS adjacency can be either broadcast or point-to-point.
- IS-IS Hello PDU (IIH)
- The IS-IS hello packets needs to be exchanged periodically between 2 routers to establish adjacency. Based on the negotiation, one of them will be selected as DIS (Designated IS). This hello packet will be sent separately for Level-1 or Level-2.: There are 3 IS-IS hello packets depending on the circuit type -
- LAN L1 (PDU type 15)
- LAN L2 (PDU type 16)
- P2P (PDU type 17). As can be seen, on point-to-point links there are no separate hello packets per level, while on broadcast links - there are.
- Link State PDU (LSP)
- This contains the actual route information. This LSP can contain many type–length–values (TLVs). LSP header is called LSP ID and consists of System ID, Pseudonode ID and Fragment ID. : In example of LSP ID 1921.6820.0002.02-01
- 1921.6820.0002 is System ID (that generated this LSP),
- 02 is Pseudonode ID,
- 01 is Fragment ID.
- If Pseudonode ID is equal to zero, then this is a real intermediate system. Any value different from zero means that this LSP is generated by DIS (Pseudonode).
- If LSP is too big, then it gets fragmented. In order to indicate this, Fragment ID is used. If Fragment ID is equal to zero, then no fragmentation has occurred.
- Complete Sequence Number PDU (CSNP)
- This packet will be sent only by the DIS. By default, for every 10 seconds, CSNP packet will be transmitted by DIS. This will contain the list of LSP IDs along with sequence number and checksum.
- Partial Sequence Number PDU (PSNP)
- If the router which receives CSNP packet finds some discrepancy in its own database, it will send an PSNP request asking the DIS to send specific LSP back to it.
IS-IS addressing and NET
[edit]From regular TCP/IP world we are used to know that each Layer 3 interface (including loopback) has its own IPv4 or IPv6 address. The most important point is that loopback interface always stays up (unless deleted) compared to physical or logical interfaces.
Therefore, ISO choose a different approach - instead of assigning layer 3 address to each interface, single address is assigned to loopback interface, while other interfaces are considered as unnumbered. This single address is called NET (Network Entity Title).
On a single intermediate system there can be up to 3 NET addresses. This is useful during migration from one area to another.
NET consists of Area, System ID and NSEL. Area itself consists of AFI (Address Family Identifier) and Area ID.
Area can have variable length of 1 - 13 bytes, System ID is 6 bytes and NSEL - 1 byte.
Let's check on an example NET of 49.0100.1921.6821.1138.00. Here,
- 49 is AFI, and in case of 49 it means "private address space", similar to RFC1918 for IPv4.,
- 0100 is Area ID,
- 49.0100 is Area,
- 1921.6821.1138 is System ID,
- 00 is NSEL, which must be zero. If not zero, then no IS-IS adjacency is formed.
Hostname resolution
[edit]Let's imagine, that engineer examines L2 or L1 database, or needs to view a specific LSP. Each LSP has LSP ID, consisting of System ID, Pseudonode ID and Fragment ID. Because generally System ID is router's loopback address, remembering which loopback address to which router is not always convenient.
Similar thing happens with OSPF, when LSDB or specific LSA is checked - they are listed by Advertising router, which is actually an IP. In case of OSPF, in order to overcome difficulty of remembering router IPs or consulting with list, local DNS resolution can be configured. But as it might be understood, this is not very convenient and fast way, especially during troubleshooting ongoing issues.
IS-IS solves this problem in a very elegant manner - in each LSP there is TLV 137, which displays hostname of the router. By this means, all routers know hostnames of other routers in the level by examining LSPs. That's why when viewing LSP in L2 or L1 database, they are displayed by hostname, not System ID.
From the other hand, if needed, hostnames and their matching System IDs can be easily seen from IS-IS.
Areas and levels
[edit]In IS-IS there is conception of areas, but here it works differently from OSPF. First of all, in contrary to OSPF, in IS-IS area is terminated on router, not link.
In IS-IS, backbone area consists of contiguous Level 2 routers. Level 1 areas can be thought of stub areas in OSPF, where very limited reachability information is available. L2/L1 routers act like area border routers (ABRs) between L1 routers and L2 routers by keeping two databases - L1 database and L2 database.
Here is very important role of L2/L1 router - if it is connected to L2 router in another area, then it sets ATT (ATTached bit) in its L1 LSP. L1 routers which receive this LSP (with ATT bit) add default route to originator of this LSP. This is different from OSPF, where ABR generates default route to stub area routers and send it via LSA 3.
Another difference of router in L1 area in IS-IS from router in stub area in OSPF is that L1 router can inject external routes into area, which travels up to L2/L1 router. With that, it resembles NSSA area in OSPF (where you cannot have external routes from backbone area, but you can inject external routes to NSSA area which are then translated to regular LSA 5 external routes by NSSA ABR).
However, by default, external L1 routes are not injected from L1 to L2. This can be changed by policy on L2/L1 router, which accepts L1 external routes and originates them into L2.
In case of OSPF, if one day it is needed to inject external routes into OSPF domain from stub area, this can be done only by changing area type from stub to NSSA, which causes tearing down OSPF neighborship. In IS-IS, this happens hit-less.
Wide metrics
[edit]When IS-IS was initially introduced, TLVs for IS reachability (TLV 2) and IP reachability (TLVs 128 and 130) could have interface metric no more than 63 (6 bits) and total accumulated path metric of no more than 1023 (10 bits).
Obviously, nowadays with higher link speeds and more hops it would be challenging to stay within these limits.
Therefore, 2 new TLVs - TLV 22 for Extended IS reachability and TLV 135 for Extended IP reachability - were introduced. With this, now link metric can be up to 16.7 million (24 bits) and total accumulated path metric can be up to 4 billion (32 bits).
Older style metric is therefore called narrow metrics, while new style metric - wide metrics.
Wide metrics or narrow metrics can be set on level base.
Adjacency formation
[edit]Compared to OSPF, in IS-IS rules of adjacency formation are much simpler.
- L1 router cannot form any adjacency with L2 router under any conditions.
- L1 router can form L1 adjacency with other L1 router if their areas match.
- L1 router can form L1 adjacency with L2/L1 router if their areas match.
- L2 router can form L2 adjacency with other L2 router regardless of their areas (they don't need to match).
- L2 router can form L2 adjacency with other L2/L1 router regardless of their areas (they don't need to match).
- L2/L1 router can form only L2 adjacency with other L2/L1 router if their areas don't match.
- L2/L1 router can form both L2 and L1 adjacency with other L2/L1 router if their areas match.
Broadcast segments and designated intermediate system
[edit]On broadcast networks IS-IS is prone to issue, similar to OSPF, when all routers on the broadcast segment need to form adjacency and exchange LSPs. Therefore, number of LSPs increase in square.
In order to overcome this issue, on each LAN segment a designated intermediate system (DIS) is elected. The router with the highest priority and System ID wins. But, if a new router shows up and has better priority or System ID, then it is elected as a new DIS.
Elected DIS router is a pseudonode, which uses resources (including System ID) of one real router. DIS describes adjacency between routers in the broadcast segment in hub-spoke manner, where DIS is the hub while other routers (including router, promoted to DIS) are spokes.
Pseudonode ID in LSPs, originated from DIS, always have Pseudonode ID field different from zero.
All routers on the LAN segment form adjacency with only DIS and exchanges LSPs with it.
The function of DIS is to send periodic CSNPs on the LAN segment and reply to PSNPs from other routers. In case of DIS failure a new DIS will be elected in the segment. The role of DIS is not as critical as of DR in OSPF. That's why there is no backup DIS (BDIS) elected in IS-IS compared to BDR in OSPF.
Authentication
[edit]IS-IS supports both simple password and MD5 authentication types. In IS-IS, per-level or per-interface authentication is possible.
In addition, to protect from replay attack, IS-IS uses increasing Sequence number in IIH.
IPv6 support and multi-topology
[edit]Because IS-IS encapsulates its PDUs into Layer 2 frame, it does not depend on Layer 3 protocols, such as IPv4 or IPv6. This is different from OSPF, which uses IPv4. Therefore, when IPv6 came up, adding IPv6 support to OSPF would require re-writing the protocol. That is how OSPFv3 was created.
In case of IS-IS, TLV 232 for IPv6 interface address and TLV 236 for IPv6 reachability were added to support IPv6. And of course, IPv6 needs to be enabled on the interface.
In order to display supported Layer 3 protocols, also called NLPID (Network Layer Protocol ID), TLV 129 is used. Here, IPv4 has code of 0xCC, while IPv6 - 0x8E.
There might be an issue, if IPv4 and IPv6 topologies do not overlap. This could happen due to misconfiguration or intentionally (if some routers between do not support IPv6). For this situations, multi-topology support is added to IS-IS.
TLV 229 was added to display supported multi-topologies, such as IPv4 unicast and IPv6 unicast.
If multi-topology is enabled, IS-IS will calculate separate SPF tree for IPv4 and IPv6. This means twice the resource usage, but from the other side, this prevents traffic blackholing.
When multi-topology is enabled, then IS-IS will use TLV 222 for Multi-topology IS reachability, TLV 235 for Multi-topology IP reachability and TLV 236 for Multi-topology IPv6 reachability.
Other uses
[edit]IS-IS is also used as the control plane for IEEE 802.1aq Shortest Path Bridging (SPB). SPB allows for shortest-path forwarding in an Ethernet mesh network context utilizing multiple equal cost paths. This permits SPB to support large Layer 2 topologies, with fast convergence, and improved use of the mesh topology.[9] Combined with this is single point provisioning for logical connectivity membership. IS-IS is therefore augmented with a small number of TLVs and sub-TLVs, and supports two Ethernet encapsulating data paths, 802.1ad Provider Bridges and 802.1ah Provider Backbone Bridges. SPB requires no state machine or other substantive changes to IS-IS, and simply requires a new Network Layer Protocol Identifier (NLPID) and set of TLVs. This extension to IS-IS is defined in the IETF proposed standard RFC 6329.
Related protocols
[edit]References
[edit]- ^ "X.225 : Information technology – Open Systems Interconnection – Connection-oriented Session protocol: Protocol specification". Archived from the original on 1 February 2021. Retrieved 10 March 2023.
- ^ "ISO/IEC 10589:2002 – Information technology – Telecommunications and information exchange between systems – Intermediate System to Intermediate System intra-domain routeing information exchange protocol for use in conjunction with the protocol for providing the connectionless-mode network service (ISO 8473)". ISO website. International Organization for Standardization (ISO). November 2002. Retrieved May 24, 2017.
- ^ "Free-of-charge PDF copy of ISO/IEC 10589:2002". ISO website. International Organization for Standardization. Retrieved May 24, 2017.
- ^ Gredler, Hannes; Goraiski, Walter (2005). The complete IS-IS routing protocol. Springer. p. 1. ISBN 1-85233-822-9.
- ^ J. Hawkinson; T. Bates (March 1996). Guidelines for creation, selection, and registration of an Autonomous System (AS). Network Working Group. doi:10.17487/RFC1930. BCP 6. RFC 1930. Best Current Practice 6. Updated by RFC 6996 and 7300.
- ^ D. Oran, ed. (February 1990). OSI IS-IS Intra-domain Routing Protocol. Network Working Group. doi:10.17487/RFC1142. RFC 1142. Historic. Obsoleted by RFC 7142.
- ^ M. Shand; L. Ginsberg (February 2014). Reclassification of RFC 1142 to Historic. Internet Engineering Task Force. doi:10.17487/RFC7142. ISSN 2070-1721. RFC 7142. Informational. Obsoletes RFC 1142.
- ^ R. Callon (December 1990). Use of OSI IS-IS for Routing in TCP/IP and Dual Environments. Network Working Group. doi:10.17487/RFC1195. RFC 1195. Proposed Standard. Updated by RFC 1349, 5304 and 5302.
- ^ D. Allan; N. Bragg; P. Unbehagen (April 2011). D. Fedyk; P. Ashwood-Smith (eds.). IS-IS Extensions Supporting IEEE 802.1aq Shortest Path Bridging. Internet Engineering Task Force. doi:10.17487/RFC6329. ISSN 2070-1721. RFC 6329. Proposed Standard.
External links
[edit]- IS-IS standard (ISO/IEC 10589:2002, Second Edition) – free-of-charge PDF version
- OSPF and IS-IS: A Comparative Anatomy by Dave Katz, Juniper
- Collection of RFCs pertaining to IS-IS Archived 2013-06-02 at the Wayback Machine
- IS-IS and OSPF difference discussion (Vishwas Manral, Manav Bhatia and Yasuhiro Ohara)
- Google Quagga IS-IS implementation
- Sample isisd.conf file: used with Quagga