In the OSI reference model, the components of a communication system are distinguished in sevenabstraction layers: Physical, Data Link, Network, Transport, Session, Presentation, and Application.[3]
The model describes communications from the physical implementation of transmittingbits across atransmission medium to the highest-level representation of data of adistributed application. Each layer has well-defined functions and semantics and serves a class of functionality to the layer above it and is served by the layer below it. Established, well-knowncommunication protocols are decomposed in software development into the model's hierarchy of function calls.
TheInternet protocol suite as defined inRFC1122 andRFC1123 is a model of networking developed contemporarily to the OSI model, and was funded primarily by the U.S. Department of Defense. It was the foundation for the development of theInternet. It assumed the presence of generic physical links and focused primarily on the software layers of communication, with a similar but much less rigorous structure than the OSI model.
In comparison, several networking models have sought to create an intellectual framework for clarifying networking concepts and activities,[citation needed] but none have been as successful as the OSI reference model in becoming the standard model for discussing and teaching networking in the field ofinformation technology. The model allows transparent communication through equivalent exchange ofprotocol data units (PDUs) between two parties, through what is known aspeer-to-peer networking (also known as peer-to-peer communication). As a result, the OSI reference model has not only become an important piece among professionals and non-professionals alike, but also in all networking between one or many parties, due in large part to its commonly accepted user-friendly framework.[4]
Communication in the OSI model (example with layers 3 to 5)
The development of the OSI model started in the late 1970s to support the emergence of the diverse computer networking methods that were competing for application in the large national networking efforts in the world (seeOSI protocols andProtocol Wars). In the 1980s, the model became a working product of the Open Systems Interconnection group at theInternational Organization for Standardization (ISO). While attempting to provide a comprehensive description of networking, the model failed to garner reliance during the design of theInternet, which is reflected in the less prescriptiveInternet Protocol Suite, principally sponsored under the auspices of theInternet Engineering Task Force (IETF).
The OSI model was first defined in raw form inWashington, D.C., in February 1978 by French software engineerHubert Zimmermann, and the refined but still draft standard was published by the ISO in 1980.[9]
The drafters of the reference model had to contend with many competing priorities and interests. The rate of technological change made it necessary to define standards that new systems could converge to rather than standardizing procedures after the fact; the reverse of the traditional approach to developing standards.[11] Although not a standard itself, it was a framework in which future standards could be defined.[12]
In May 1983,[13] the CCITT and ISO documents were merged to formThe Basic Reference Model for Open Systems Interconnection, usually referred to as theOpen Systems Interconnection Reference Model,OSI Reference Model, or simplyOSI model. It was published in 1984 by both the ISO, as standard ISO 7498, and the renamed CCITT (now called the Telecommunications Standardization Sector of theInternational Telecommunication Union orITU-T) as standard X.200.
OSI had two major components: an abstract model of networking, called the Basic Reference Model or seven-layer model, and aset of specific protocols. The OSI reference model was a major advance in thestandardisation of network concepts. It promoted the idea of a consistent model of protocol layers, defining interoperability between network devices and software.
The concept of a seven-layer model was provided by the work ofCharles Bachman atHoneywell Information Systems.[14] Various aspects of OSI design evolved from experiences with the NPL network, ARPANET, CYCLADES,EIN, and theInternational Network Working Group (IFIP WG6.1). In this model, a networking system was divided into layers. Within each layer, one or more entities implement its functionality. Each entity interacted directly only with the layer immediately beneath it and provided facilities for use by the layer above it.
The OSI standards documents are available from the ITU-T as the X.200 series of recommendations.[15] Some of the protocol specifications were also available as part of the ITU-T X series. The equivalent ISO/IEC standards for the OSI model were available from ISO. Not all are free of charge.[16]
OSI was an industry effort, attempting to get industry participants to agree on common network standards to provide multi-vendor interoperability.[17] It was common for large networks to support multiple network protocol suites, with many devices unable to interoperate with other devices because of a lack of common protocols. For a period in the late 1980s and early 1990s, engineers, organizations and nations becamepolarized over the issue of which standard, the OSI model or theInternet protocol suite, would result in the best and most robust computer networks.[9][18][19] However, while OSI developed its networking standards in the late 1980s,[20][page needed][21][page needed]TCP/IP came into widespread use on multi-vendor networks forinternetworking.
The OSI model is still used as a reference for teaching and documentation;[22] however, theOSI protocols originally conceived for the model did not gain popularity. Some engineers argue the OSI reference model is still relevant tocloud computing.[23] Others say the original OSI model does not fit today's networking protocols and have suggested instead a simplified approach.[24][25]
Communication protocols enable an entity in one host to interact with a corresponding entity at the same layer in another host. Service definitions, like the OSI model, abstractly describe the functionality provided to a layerN by a layerN−1, whereN is one of the seven layers of protocols operating in the local host (with N=1 being the most basic layer, often represented at the bottom of a list).
At each levelN, two entities at the communicating devices (layer Npeers) exchangeprotocol data units (PDUs) by means of a layer Nprotocol. Each PDU contains a payload, called theservice data unit (SDU), along with protocol-related headers or footers.
Data processing by two communicating OSI-compatible devices proceeds as follows:
The data to be transmitted is composed at the topmost layer of the transmitting device (layerN) into aprotocol data unit (PDU).
ThePDU is passed to layerN−1, where it is known as theservice data unit (SDU).
At layerN−1 theSDU isconcatenated with a header, a footer, or both, producing alayer N−1 PDU. It is then passed to layerN−2.
The process continues until reaching the lowermost level, from which the data is transmitted to the receiving device.
At the receiving device the data is passed from the lowest to the highest layer as a series ofSDUs while being successively stripped from each layer's header or footer until reaching the topmost layer, where the last of the data is consumed.
The physical layer is responsible for the transmission and reception of unstructured raw data between a device, such as anetwork interface controller,Ethernet hub, ornetwork switch, and a physicaltransmission medium. It converts the digital bits into electrical, radio, or optical signals (analogue signals). Layer specifications define characteristics such as voltage levels, the timing of voltage changes, physical data rates, maximum transmission distances, modulation scheme, channel access method and physical connectors. This includes the layout ofpins,voltages, lineimpedance, cable specifications, signal timing and frequency for wireless devices. Bit rate control is done at the physical layer and may define transmission mode assimplex,half duplex, andfull duplex. The components of a physical layer can be described in terms of thenetwork topology. Physical layer specifications are included in the specifications for the ubiquitousBluetooth,Ethernet, andUSB standards. An example of a less well-known physical layer specification would be for theCAN standard.
The physical layer also specifies how encoding occurs over a physical signal, such as electrical voltage or a light pulse. For example, a 1 bit might be represented on a copper wire by the transition from a 0-volt to a 5-volt signal, whereas a 0 bit might be represented by the transition from a 5-volt to a 0-volt signal. As a result, common problems occurring at the physical layer are often related to the incorrect media termination, EMI or noise scrambling, and NICs and hubs that are misconfigured or do not work correctly.
The data link layer providesnode-to-node data transfer—a link between two directly connected nodes. It detects and possibly corrects errors that may occur in the physical layer. It defines the protocol to establish and terminate a connection between two physically connected devices. It also defines the protocol forflow control between them.
IEEE 802 divides the data link layer into two sublayers:[28]
Medium access control (MAC) layer – responsible for controlling how devices in a network gain access to a medium and permission to transmit data.
Logical link control (LLC) layer – responsible for identifying and encapsulating network layer protocols, and controls error checking and frame synchronization.
TheITU-TG.hn standard, which provides high-speed local area networking over existing wires (power lines, phone lines and coaxial cables), includes a complete data link layer that provides botherror correction and flow control by means of aselective-repeatsliding-window protocol.
Security, specifically (authenticated) encryption, at this layer can be applied withMACsec.
The network layer provides the functional and procedural means of transferringpackets from one node to another connected in "different networks". A network is a medium to which many nodes can be connected, on which every node has anaddress and which permits nodes connected to it to transfer messages to other nodes connected to it by merely providing the content of a message and the address of the destination node and letting the network find the way to deliver the message to the destination node, possiblyrouting it through intermediate nodes. If the message is too large to be transmitted from one node to another on the data link layer between those nodes, the network may implement message delivery by splitting the message into several fragments at one node, sending the fragments independently, and reassembling the fragments at another node. It may, but does not need to, report delivery errors.
Message delivery at the network layer is not necessarily guaranteed to be reliable; a network layer protocol may provide reliable message delivery, but it does not need to do so.
A number of layer-management protocols, a function defined in themanagement annex, ISO 7498/4, belong to the network layer. These include routing protocols, multicast group management, network-layer information and error, and network-layer address assignment. It is the function of the payload that makes these belong to the network layer, not the protocol that carries them.[29]
Security, specifically (authenticated) encryption, at this layer can be applied withIPsec.
The transport layer provides the functional and procedural means of transferring variable-length data sequences from a source host to a destination host from one application to another across a network while maintaining the quality-of-service functions. Transport protocols may be connection-oriented or connectionless.
This may require breaking large protocol data units or long data streams into smaller chunks called "segments", since the network layer imposes a maximum packet size called themaximum transmission unit (MTU), which depends on the maximum packet size imposed by all data link layers on the network path between the two hosts. The amount of data in a data segment must be small enough to allow for a network-layer header and a transport-layer header. For example, for data being transferred acrossEthernet, the MTU is 1500 bytes, the minimum size of a TCP header is 20 bytes, and the minimum size of an IPv4 header is 20 bytes, so the maximum segment size is 1500−(20+20) bytes, or 1460 bytes. The process of dividing data into segments is calledsegmentation; it is an optional function of the transport layer. Some connection-oriented transport protocols, such asTCP and the OSI connection-oriented transport protocol (COTP), perform segmentation and reassembly of segments on the receiving side; connectionless transport protocols, such asUDP and the OSI connectionless transport protocol (CLTP), usually do not.
The transport layer also controls the reliability of a given link between a source and destination host through flow control, error control, and acknowledgments of sequence and existence. Some protocols are state- andconnection-oriented. This means that the transport layer can keep track of the segments and retransmit those that fail delivery through the acknowledgment hand-shake system. The transport layer will also provide the acknowledgement of the successful data transmission and sends the next data if no errors occurred.
Reliability, however, is not a strict requirement within the transport layer. Protocols like UDP, for example, are used in applications that are willing to accept some packet loss, reordering, errors or duplication.Streaming media, real-time multiplayer games andvoice over IP (VoIP) are examples of applications in which loss of packets is not usually a fatal problem.
The OSI connection-oriented transport protocol defines five classes of connection-mode transport protocols, ranging from class 0 (which is also known as TP0 and provides the fewest features) to class 4 (TP4, designed for less reliable networks, similar to the Internet). Class 0 contains no error recovery and was designed for use on network layers that provide error-free connections. Class 4 is closest to TCP, although TCP contains functions, such as the graceful close, which OSI assigns to the session layer. Also, all OSI TP connection-modeprotocol classes provide expedited data and preservation of record boundaries. Detailed characteristics of TP0–4 classes are shown in the following table:[30]
a If an excessive number ofPDUs are unacknowledged.
An easy way to visualize the transport layer is to compare it with a post office, which deals with the dispatch and classification of mail and parcels sent. A post office inspects only the outer envelope of mail to determine its delivery. Higher layers may have the equivalent of double envelopes, such as cryptographic presentation services that can be read by the addressee only. Roughly speaking,tunnelling protocols operate at the transport layer, such as carrying non-IP protocols such asIBM'sSNA orNovell'sIPX over an IP network, or end-to-end encryption withIPsec. WhileGeneric Routing Encapsulation (GRE) might seem to be a network-layer protocol, if the encapsulation of the payload takes place only at the endpoint, GRE becomes closer to a transport protocol that uses IP headers but contains complete Layer 2 frames or Layer 3 packets to deliver to the endpoint.L2TP carriesPPP frames inside transport segments.
Although not developed under the OSI Reference Model and not strictly conforming to the OSI definition of the transport layer, theTransmission Control Protocol (TCP) and theUser Datagram Protocol (UDP) of the Internet Protocol Suite are commonly categorized as layer 4 protocols within OSI.
Transport Layer Security (TLS) does not strictly fit inside the model either. It contains characteristics of the transport and presentation layers.[31][32]
The session layer creates the setup, controls the connections, and ends theteardown, between two or more computers, which is called a "session". Common functions of the session layer include user logon (establishment) and user logoff (termination) functions. Including this matter, authentication methods are also built into most client software, such as FTP Client and NFS Client for Microsoft Networks. Therefore, the session layer establishes, manages and terminates the connections between the local and remote applications. The session layer also provides forfull-duplex,half-duplex, orsimplex operation,[citation needed] and establishes procedures for checkpointing, suspending, restarting, and terminating a session between two related streams of data, such as an audio and a video stream in a web-conferencing application. Therefore, the session layer is commonly implemented explicitly in application environments that useremote procedure calls.
The presentation layer establishes data formatting and data translation into a format specified by the application layer during the encapsulation of outgoing messages while being passed down theprotocol stack, and possibly reversed during the deencapsulation of incoming messages when being passed up the protocol stack. For this very reason, outgoing messages during encapsulation are converted into a format specified by the application layer, while the conversion for incoming messages during deencapsulation are reversed.
The presentation layer handles protocol conversion, data encryption, data decryption, data compression, data decompression, incompatibility of data representation between operating systems, and graphic commands. The presentation layer transforms data into the form that the application layer accepts, to be sent across a network. Since the presentation layer converts data and graphics into a display format for the application layer, the presentation layer is sometimes called the syntax layer.[33] For this reason, the presentation layer negotiates the transfer of syntax structure through theBasic Encoding Rules ofAbstract Syntax Notation One (ASN.1), with capabilities such as converting anEBCDIC-codedtext file to anASCII-coded file, orserialization ofobjects and otherdata structures from and toXML.[4]
The application layer is the layer of the OSI model that is closest to the end user, which means both the OSI application layer and the user interact directly with a software application that implements a component of communication between the client and server, such asFile Explorer andMicrosoft Word. Such application programs fall outside the scope of the OSI model unless they are directly integrated into the application layer through the functions of communication, as is the case with applications such asweb browsers andemail programs. Other examples of software are Microsoft Network Software for File and Printer Sharing and Unix/Linux Network File System Client for access to shared file resources.
Application-layer functions typically include file sharing, message handling, and database access, through the most common protocols at the application layer, known as HTTP, FTP, SMB/CIFS, TFTP, and SMTP. When identifying communication partners, the application layer determines the identity and availability of communication partners for an application with data to transmit. The most important distinction in the application layer is the distinction between the application entity and the application. For example, a reservation website might have two application entities: one usingHTTP to communicate with its users, and one for a remote database protocol to record reservations. Neither of these protocols have anything to do with reservations. That logic is in the application itself. The application layer has no means to determine the availability of resources in the network.[4]
Cross-layer functions are services that are not tied to a given layer, but may affect more than one layer.[34] Some orthogonal aspects, such as management andsecurity, involve all of the layers (SeeITU-T X.800 Recommendation[35]). These services are aimed at improving theCIA triad—confidentiality,integrity, andavailability—of the transmitted data.Cross-layer functions are the norm, in practice, because the availability of a communication service is determined by the interaction betweennetwork design andnetwork management protocols.
Specific examples of cross-layer functions include the following:
Management functions, i.e. functions that permit to configure, instantiate, monitor, terminate the communications of two or more entities: there is a specific application-layer protocol,Common Management Information Protocol (CMIP) and its corresponding service,Common Management Information Service (CMIS), they need to interact with every layer in order to deal with their instances.
Multiprotocol Label Switching (MPLS), ATM, and X.25 are 3a protocols. OSI subdivides the Network Layer into three sublayers: 3a) Subnetwork Access, 3b) Subnetwork Dependent Convergence and 3c) Subnetwork Independent Convergence.[36] It was designed to provide a unified data-carrying service for both circuit-based clients and packet-switching clients which provide adatagram-based service model. It can be used to carry many different kinds of traffic, including IP packets, as well as native ATM, SONET, and Ethernet frames. Sometimes one sees reference to a Layer 2.5.
Cross MAC and PHY Scheduling is essential in wireless networks because of the time-varying nature of wireless channels. By scheduling packet transmission only in favourable channel conditions, which requires the MAC layer to obtain channel state information from the PHY layer, network throughput can be significantly improved and energy waste can be avoided.[37][page needed]
Neither the OSI Reference Model, nor anyOSI protocol specifications, outline any programming interfaces, other than deliberately abstract service descriptions. Protocol specifications define a methodology for communication between peers, but the software interfaces are implementation-specific.
The table below presents a list of OSI layers, the original OSI protocols, and someapproximate modern matches. This correspondence is rough: the OSI model contains idiosyncrasies not found in later systems such as the IP stack in modern Internet.[25]
The design of protocols in theTCP/IP model of the Internet does not concern itself with strict hierarchical encapsulation and layering.RFC3439 contains a section entitled "Layeringconsidered harmful".[47] TCP/IP does recognize four broad layers of functionality which are derived from the operating scope of their contained protocols: the scope of the software application; the host-to-host transport path; the internetworking range; and the scope of the direct links to other nodes on the local network.[48]
Despite using a different concept for layering than the OSI model, these layers are often compared with the OSI layering scheme in the following manner:
The Internetapplication layer maps to the OSI application layer, presentation layer, and most of the session layer.
The TCP/IPtransport layer maps to the graceful close function of the OSI session layer as well as the OSI transport layer.
Theinternet layer performs functions as those in a subset of the OSI network layer.
Thelink layer corresponds to the OSI data link layer and may include similar functions as the physical layer, as well as some protocols of the OSI's network layer.
These comparisons are based on the original seven-layer protocol model as defined in ISO 7498, rather than refinements in the internal organization of the network layer.
TheOSI protocol suite that was specified as part of the OSI project was considered by many as too complicated and inefficient, and to a large extent unimplementable.[49][page needed] Taking the "forklift upgrade" approach to networking, it specified eliminating all existing networking protocols and replacing them at all layers of the stack. This made implementation difficult and was resisted by many vendors and users with significant investments in other network technologies. In addition, the protocols included so many optional features that many vendors' implementations were not interoperable.[49][page needed]
Although the OSI model is often still referenced, theInternet protocol suite has become the standard for networking. TCP/IP's pragmatic approach to computer networking and to independent implementations of simplified protocols made it a practical methodology.[49][page needed] Some protocols and specifications in the OSI stack remain in use, one example beingIS-IS, which was specified for OSI as ISO/IEC 10589:2002 and adapted for Internet use with TCP/IP as RFC 1142.[50]
^Spott, Andrew; Leek, Tom; et al."What layer is TLS?".Information Security Stack Exchange.
^Grigonis, Richard (2000). "Open Systems Interconnection (OSI) Model".Computer Telephony Encyclopedia. New York: CMP Books. p. 331.ISBN978-1-929629-51-0.OCLC48138823.
^Mao, Stephen (2009). "Chapter 8: Fundamentals of communication networks". In Wyglinski, Alexander; Nekovee, Maziar; Hou, Thomas (eds.).Cognitive Radio Communications and Networks: Principles and Practice. Elsevier. p. 201.ISBN978-0-08-087932-1.OCLC635292718,528550718.Partial preview atGoogle Books.