Difference between revisions of "Internet Standard organizations"
(23 intermediate revisions by the same user not shown) | |||
Line 18: | Line 18: | ||
*ICANN - The Internet Corporation for Assigned Names and Numbers (ICANN) is a non-profit organization based in the United States that coordinates IP address allocation, the management of domain names used by DNS, and the protocol identifiers or port numbers used by TCP and UDP protocols. ICANN creates policies and has overall responsibility for these assignments. | *ICANN - The Internet Corporation for Assigned Names and Numbers (ICANN) is a non-profit organization based in the United States that coordinates IP address allocation, the management of domain names used by DNS, and the protocol identifiers or port numbers used by TCP and UDP protocols. ICANN creates policies and has overall responsibility for these assignments. | ||
*IANA - The Internet Assigned Numbers Authority (IANA) is a department of ICANN responsible for overseeing and managing IP address allocation, domain name management, and protocol identifiers for ICANN. | *IANA - The Internet Assigned Numbers Authority (IANA) is a department of ICANN responsible for overseeing and managing IP address allocation, domain name management, and protocol identifiers for ICANN | ||
** the coordination of the assignment of technical protocol parameters including the management of the address and routing parameter area (ARPA) top-level domain | |||
** the administration of certain responsibilities associated with Internet DNS root zone management such as generic (gTLD) and country code (ccTLD) Top-Level Domains | |||
** the allocation of Internet numbering resources | |||
= Major L1 networking hardware standards = | |||
These standards are at physical layer 1 of OSI model. | |||
[[File:Major-hardware_standards.PNG|none|500px|left|Major-hardware_standards]] | |||
= Major L2 networking standards = | |||
These standards are at data link layer 2 of OSI model. These are unlikely defined by RFCs and are maintained by engineering and communication organizations. | |||
[[File:Data_Link_Networking_Standards.png|none|left|Data_Link_Networking_Standards]] | |||
= Ethernet history = | |||
We have 2 Ethernet standards: | |||
*IEEE 802.3 Ethernet standard which has been updated several times to include new technologies | |||
*The DIX Ethernet standard which is now referred to Ethernet II | |||
The differences between framing styles are minimal. The most significant difference between the two standards is the addition of a Start Frame Delimiter (SFD) and the change of the Type field to a Length field in the 802.3. | |||
Ethernet II is the Ethernet frame format used in TCP/IP networks. | |||
*1973 - Ethernet - invented by Dr Robert Metcalf of Xerox corp | |||
*1980 - DIX standard called now Ethernet II - Digital Equipment Corp, INtel and Xerox (DIX) 10Mb/s Ethernet over coaxial cable | |||
*1983 - IEEE 802.3 10 BASE-5 - 10 Mb/s Ethernet over thick coaxial cable | |||
*1985 - IEEE 802.3a 10 BASE-2 - 10 Mb/s Ethernet over thin coaxial cable | |||
*1990 - IEEE 802.3i 10 BASE-T - 10 Mb/s Ethernet over twisted pair | |||
*1993 - IEEE 802.3j 10 BASE-F - 10 Mb/s Ethernet over fiber optic | |||
*1995 - IEEE 802.3u 100 BASE-xx - Fast Ethernet 100 Mb/s over twisted pair and fiber (various standards) | |||
*1998 - IEEE 802.3z 1000 BASE-X - Gigabit Ethernet over fiber optic | |||
*1999 - IEEE 802.3ab 1000 BASE-T - Gigabit Ethernet over twisted pair | |||
*2002 - IEEE 802.3ae 10G BASE-xx - 10 Gigabit Ethernet over fiber (various standards) | |||
*2006 - IEEE 802.3an 10G BASE T - Gigabit Ethernet over twisted pair | |||
== Ethernet 802.3 versus Ethernet II == | |||
802.3 (which uses 802.2 LLC format) has a Length field in the same place that Ethernet II has a Type field. | |||
'''IEEE 802.3''' with 802.2 LLC (used by Spanning-Tree, ISIS) use the highlighted bytes for a Length field. 802.3 Upper-layer protocols are decoded via the 802.2 LLC Header / SNAP bytes. The SNAP bytes are used to decode protocols using traditional ethertype values; SNAP is only included when the 802.2 LLC DSAP / SSAP = 0xAAAA. | |||
+----+----+------+------+------+------+-----+ | |||
| DA | SA | Len | LLC | SNAP | Data | FCS | | |||
+----+----+------+------+------+------+-----+ | |||
^^^^^^^^ | |||
DA Destination MAC Address (6 bytes) | |||
SA Source MAC Address (6 bytes) | |||
Len Length of Data field (2 bytes: <= 0x05DC or 1500 decimal) <--- | |||
LLC 802.2 LLC Header (3 bytes) | |||
SNAP (5 bytes) | |||
Data Protocol Data (46 - 1500 bytes) plus padding if required | |||
FCS Frame Checksum (4 bytes) | |||
'''Ethernet II''' - RFC 894 use these bytes for Type. Upper-layer protocols are decoded via the Type field | |||
+----+----+------+------+-----+ | |||
| DA | SA | Type | Data | FCS | | |||
+----+----+------+------+-----+ | |||
^^^^^^^^ | |||
DA Destination MAC Address (6 bytes) | |||
SA Source MAC Address (6 bytes) | |||
Type Protocol Type (2 bytes: >= 0x0600 or 1536 decimal) <--- | |||
Data Protocol Data (46 - 1500 bytes) plus padding if required | |||
FCS Frame Checksum (4 bytes) | |||
Generic view comparison | |||
[[File:Ethernet802.3vsethernetII.png|none|left|Ethernet802.3vsethernetII]] | |||
== Ethernet frame sizes == | |||
Minimum frame size is 64 bytes and max is 1518 Bytes, not including a Preamble and Start Frame Delimiter. | |||
IEEE 802.3ac standard, released in 1998, extended the maximum allowable frame size to 1522 bytes by adding 4 Bytes of 802.1Q VLAN Tag field. | |||
= L3 Internet Protocol IPv4/IPv6 = | |||
== IPv4 == | |||
Internet Datagram Header | |||
0 1 2 3 | |||
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 | |||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | |||
|Version| IHL |Type of Service| Total Length | | |||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | |||
| Identification |Flags| Fragment Offset | | |||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | |||
| Time to Live | Protocol | Header Checksum | | |||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | |||
| Source Address | | |||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | |||
| Destination Address | | |||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | |||
| Options | Padding | | |||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | |||
The IP header structure is as follows: | |||
{| style="font-family: Arial, Helvetica, sans-serif; letter-spacing: normal; orphans: auto; text-indent: 0px; text-transform: none; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px" border="1" cellpadding="2" cellspacing="0" bgcolor="#99CCFF" width="400" | |||
|- class="blacktext" style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 0, 0); font-size: 12px" | |||
| style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" bgcolor="#FFFFFF" valign="top" width="12%" | <div align="right">4</div> | |||
| style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" bgcolor="#FFFFFF" valign="top" width="10%" | <div align="right">8</div> | |||
| colspan="2" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" bgcolor="#FFFFFF" valign="top" | <div align="right">16</div> | |||
| colspan="4" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" bgcolor="#FFFFFF" valign="top" | <div align="right">32 bits</div> | |||
|- class="blacktext" style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 0, 0); font-size: 12px" | |||
| style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" width="12%" | <center>Ver.</center> | |||
| style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" width="10%" | <center>IHL</center> | |||
| colspan="2" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" nowrap="nowrap" valign="top" | <center>Type of service</center> | |||
| colspan="4" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" align="center" valign="top" | Total length | |||
|- class="blacktext" style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 0, 0); font-size: 12px" | |||
| colspan="4" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" | <center>Identification</center> | |||
| style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" width="16%" | <center>Flags</center> | |||
| colspan="3" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" nowrap="nowrap" valign="top" | Fragment offset | |||
|- class="blacktext" style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 0, 0); font-size: 12px" | |||
| colspan="2" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" | <center>Time to live</center> | |||
| colspan="2" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" align="center" valign="top" | Protocol | |||
| colspan="4" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" nowrap="nowrap" valign="top" | <center>Header checksum</center> | |||
|- class="blacktext" style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 0, 0); font-size: 12px" | |||
| colspan="8" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" | <center>Source address</center> | |||
|- class="blacktext" style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 0, 0); font-size: 12px" | |||
| colspan="8" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" | <center>Destination address</center> | |||
|- class="blacktext" style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 0, 0); font-size: 12px" | |||
| colspan="8" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" | <center>Option + Padding</center> | |||
|- class="blacktext" style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 0, 0); font-size: 12px" | |||
| colspan="8" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" | <center>Data</center> | |||
|- class="blacktext" style="font-family: Arial, Helvetica, sans-serif; color: rgb(0, 0, 0); font-size: 12px" bgcolor="#FFFFFF" | |||
| colspan="8" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px" valign="top" | <div align="center"><span class="blackitalic" style="font-family: Arial, Helvetica, sans-serif; font-size: 12px; color: rgb(0, 0, 0); font-style: italic">IP header structure</span><br/></div> | |||
|} | |||
The IPv4 header structure is as follows: | |||
{| class="wikitable" style="font-size: 14px; margin: 0px auto; border-style: solid; border-color: rgb(170, 170, 170); border-collapse: collapse; color: black; font-family: sans-serif; line-height: 22.3999996185303px; text-align: center; background-color: rgb(249, 249, 249);" | |||
|- | |||
! style="border-top-color: rgb(170, 170, 170); border-left-color: rgb(170, 170, 170); border-style: solid none none solid; padding: 0.2em; background-color: rgb(242, 242, 242);" | ''Offsets'' | |||
! style="border-top-color: rgb(170, 170, 170); border-right-color: rgb(170, 170, 170); border-bottom-color: rgb(170, 170, 170); border-style: solid solid solid none; padding: 0.2em; background-color: rgb(242, 242, 242);" | [http://en.wikipedia.org/wiki/Octet_(computing) Octet] | |||
! colspan="8" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 0 | |||
! colspan="8" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 1 | |||
! colspan="8" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 2 | |||
! colspan="8" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 3 | |||
|- | |||
! style="border-right-color: rgb(170, 170, 170); border-bottom-color: rgb(170, 170, 170); border-left-color: rgb(170, 170, 170); border-style: none solid solid; padding: 0.2em; background-color: rgb(242, 242, 242);" | [http://en.wikipedia.org/wiki/Octet_(computing) Octet] | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | [http://en.wikipedia.org/wiki/Bit Bit] | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 0 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 1 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 2 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 3 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 4 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 5 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 6 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 7 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 8 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 14.40625px; background-color: rgb(242, 242, 242);" | 9 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 10 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 11 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 12 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 13 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 14 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 15 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 16 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 17 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 18 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 19 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 20 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 21 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 22 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 23 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 24 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 25 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 26 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 27 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 28 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 29 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 30 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; width: 15.40625px; background-color: rgb(242, 242, 242);" | 31 | |||
|- | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 0 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 0 | |||
| colspan="4" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#Version Version] | |||
| colspan="4" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#IHL IHL] | |||
| colspan="6" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#DSCP DSCP] | |||
| colspan="2" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#ECN ECN] | |||
| colspan="16" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#Total_Length Total Length] | |||
|- | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 4 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 32 | |||
| colspan="16" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#Identification Identification] | |||
| colspan="3" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#Flags Flags] | |||
| colspan="13" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#Fragment_Offset Fragment Offset] | |||
|- | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 8 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 64 | |||
| colspan="8" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#TTL Time To Live] | |||
| colspan="8" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#Protocol Protocol] | |||
| colspan="16" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#Header_Checksum Header Checksum] | |||
|- | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 12 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 96 | |||
| colspan="32" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#Source_address Source IP Address] | |||
|- | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 16 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 128 | |||
| colspan="32" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em;" | [http://en.wikipedia.org/wiki/IPv4#Destination_address Destination IP Address] | |||
|- | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 20 | |||
! style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background-color: rgb(242, 242, 242);" | 160 | |||
| colspan="32" rowspan="4" style="border-style: solid; border-color: rgb(170, 170, 170); padding: 0.2em; background: rgb(255, 208, 208);" | [http://en.wikipedia.org/wiki/IPv4#Options Options] (if IHL > 5)<br/><br/> | |||
|} | |||
== IPv6 == | |||
{| width="396" border="1" cellpadding="2" cellspacing="0" bordercolor="#FFFFFF" bgcolor="#99CCFF" style="font-family: Arial, Helvetica, sans-serif;" | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| width="12%" valign="top" bgcolor="#FFFFFF" | <div align="right">4</div> | |||
| width="12%" valign="top" bgcolor="#FFFFFF" | <div align="right">4</div> | |||
| width="23%" valign="top" bgcolor="#FFFFFF" | <div align="right">16</div> | |||
| width="24%" valign="top" bgcolor="#FFFFFF" | <div align="right">24</div> | |||
| width="29%" valign="top" bgcolor="#FFFFFF" | <div align="right">32 bits</div> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| width="12%" valign="top" | <center>Ver.</center> | |||
| width="12%" valign="top" | <center>Priority</center> | |||
| colspan="3" valign="top" | <center>Flow label</center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="3" valign="top" | <center>Payload length</center> | |||
| width="24%" valign="top" | <center>Next header</center> | |||
| width="29%" valign="top" | <center>Hop limit</center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="5" valign="top" | <center><br/>Source address<br/>(128 Bits)</center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="5" valign="top" | <center><br/>Destination address<br/>(128 bits)</center> | |||
|- bgcolor="#FFFFFF" class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="5" valign="top" | <div align="center"><span class="blackitalic" style="font-style: italic;">IPv6 header structure</span></div> | |||
|} | |||
= L4 TCP/UDP = | |||
== TCP Transmission Control Protocol == | |||
Stateful, connection-orientated, reliable | |||
The TCP header structure is as follows, IETF RFC 793 defined | |||
<div align="left" style="color: rgb(0, 0, 51); font-family: Arial, Helvetica, sans-serif;"> | |||
{| width="400" border="1" cellpadding="2" cellspacing="0" bordercolor="#FFFFFF" bgcolor="#99CCFF" | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="8" valign="top" bgcolor="#FFFFFF" | <div align="right">16</div> | |||
| width="12%" valign="top" bgcolor="#FFFFFF" | <div align="right">32 bits</div> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="8" valign="top" | <center>Source port</center> | |||
| width="12%" valign="top" | Destination port | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="9" valign="top" | <center>Sequence number (16)</center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="9" valign="top" | <center>Acknowledgement number (16)</center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| width="12%" valign="top" | <center>Data Offset aka hdr len</center> | |||
| width="13%" valign="top" | <center>Resrvd</center> | |||
| width="4%" valign="top" | <center>U</center> | |||
| width="4%" valign="top" | <center>A</center> | |||
| width="4%" valign="top" | <center>P</center> | |||
| width="4%" valign="top" | <center>R</center> | |||
| width="4%" valign="top" | <center>S</center> | |||
| width="4%" valign="top" | <center>F</center> | |||
| width="12%" valign="top" | <center>Window (16)</center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="8" valign="top" | <center>Checksum</center> | |||
| width="12%" valign="top" | <center>Urgent pointer</center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="9" valign="top" | <center>Option (0 or 32 if any) + Padding</center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="9" valign="top" | <center>Data</center> | |||
|- bgcolor="#FFFFFF" class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="9" valign="top" | <div align="center"><span class="blackitalic" style="font-style: italic;">TCP header structure</span></div> | |||
|} | |||
</div> | |||
'''Control bits''' - 6 bits. The control bits may be (from right to left): | |||
*U (URG) Urgent pointer field significant. | |||
*A (ACK) Acknowledgment field significant. | |||
*P (PSH) Push function. | |||
*R (RST) Reset the connection. | |||
*S (SYN) Synchronize sequence numbers. | |||
*F (FIN) No more data from sender. | |||
'''Window''' - 16 bits. The number of data octets which the sender of this segment is willing to accept, beginning with the octet indicated in the acknowledgment field. | |||
[[File:TCP_connection_establishment.PNG|none|500px|left|TCP_connection_establishment]] | |||
== UDP User Datagram Protocol == | |||
Best-effort transport protocol, stateless, connectionless, unreliable, No Flow Control, not connection-oriented | |||
The UDP header structure is shown as follows, defined by IETF RFC 768 | |||
<div align="left" style="color: rgb(0, 0, 51); font-family: Arial, Helvetica, sans-serif;"> | |||
{| width="396" border="1" cellpadding="2" cellspacing="0" bordercolor="#FFFFFF" bgcolor="#99CCFF" | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| width="48%" valign="top" bgcolor="#FFFFFF" | <div align="right"><font color="black">16</font></div> | |||
| width="52%" valign="top" bgcolor="#FFFFFF" | <div align="right"><font color="black">32 bits</font></div> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| width="48%" valign="top" | <center><font color="black">Source port</font></center> | |||
| width="52%" valign="top" | <center><font color="black">Destination port</font></center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| width="48%" valign="top" | <center><font color="black">Length</font></center> | |||
| width="52%" valign="top" | <center><font color="black">Checksum</font></center> | |||
|- class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="2" valign="top" | <center><br/><font color="black">Data</font><br/></center> | |||
|- bgcolor="#FFFFFF" class="blacktext" style="color: rgb(0, 0, 0);" | |||
| colspan="2" valign="top" | <div align="center"><span class="blackitalic" style="font-style: italic;">UDP header structure</span></div> | |||
|} | |||
</div> |
Latest revision as of 20:13, 11 November 2014
Standards organizations include:
- The Internet Society (ISOC) is responsible for promoting open development, evolution, and Internet use throughout the world. ISOC facilitates the open development of standards and protocols for the technical infrastructure of the Internet, including the oversight of the Internet Architecture Board (IAB).
- The Internet Architecture Board (IAB) is responsible for the overall management and development of Internet standards. The IAB provides oversight of the architecture for protocols and procedures used by the Internet. The IAB consists of 13 members, including the chair of the Internet Engineering Task Force (IETF). IAB members serve as individuals and not representatives of any company, agency, or other organization.
- The Internet Engineering Task Force (IETF) mission is to develop, update, and maintain Internet and TCP/IP technologies. One of the key responsibilities of the IETF is to produce Request for Comments (RFC) documents, which are a memorandum describing protocols, processes, and technologies for the Internet. The IETF consists of working groups (WGs), the primary mechanism for developing IETF specifications and guidelines. WGs are short term, and after the objectives of the group are met, the WG is terminated.
- The Institute of Electrical and Electronics Engineers is a professional organization for those in the electrical engineering and electronics fields who are dedicated to advancing technological innovation and creating standards. The IEEE 802.3 and IEEE 802.11 standards are significant IEEE standards in computer networking. The IEEE 802.3 standard defines Media Access Control (MAC) for wired Ethernet. This technology is usually for LANs, but also has wide-area network (WAN) applications. The 802.11 standard defines a set of standards for implementing wireless local-area networks (WLANs). This standard defines the Open Systems Interconnection (OSI) physical and data link MAC for wireless communications.
- International Organization for Standardization (ISO), is the world’s largest developer of international standards for a wide variety of products and services. ISO is not an acronym for the organization’s name; rather the ISO term is based on the Greek word “isos”, meaning equal. It is known for its Open Systems Interconnection (OSI) reference model. ISO published the OSI reference model in 1984 to develop a layered framework for networking protocols. However, due to the rising popularity of the TCP/IP suite, developed by Robert Kahn, Vinton Cerf, and others, the OSI protocol suite was not chosen as the protocol suite for the Internet. Instead, the TCP/IP protocol suite was selected. The OSI protocol suite was implemented on telecommunications equipment and can still be found in legacy telecommunication networks.
- EIA - The Electronic Industries Alliance (EIA), previously known as the Electronics Industries Association, is an international standards and trade organization for electronics organizations. The EIA is best known for its standards related to electrical wiring, connectors, and the 19-inch racks used to mount networking equipment.
- TIA - The Telecommunications Industry Association (TIA) is responsible for developing communication standards in a variety of areas including radio equipment, cellular towers, Voice over IP (VoIP) devices, satellite communications, and more. Many of their standards are produced in collaboration with the EIA.
- ITU-T - The International Telecommunications Union-Telecommunication Standardization Sector (ITU-T) is one of the largest and oldest communication standard organizations. The ITU-T defines standards for video compression, Internet Protocol Television (IPTV), and broadband communications, such as a digital subscriber line (DSL). For example, when dialing another country, ITU country codes are used to make the connection.
- ICANN - The Internet Corporation for Assigned Names and Numbers (ICANN) is a non-profit organization based in the United States that coordinates IP address allocation, the management of domain names used by DNS, and the protocol identifiers or port numbers used by TCP and UDP protocols. ICANN creates policies and has overall responsibility for these assignments.
- IANA - The Internet Assigned Numbers Authority (IANA) is a department of ICANN responsible for overseeing and managing IP address allocation, domain name management, and protocol identifiers for ICANN
- the coordination of the assignment of technical protocol parameters including the management of the address and routing parameter area (ARPA) top-level domain
- the administration of certain responsibilities associated with Internet DNS root zone management such as generic (gTLD) and country code (ccTLD) Top-Level Domains
- the allocation of Internet numbering resources
Major L1 networking hardware standards
These standards are at physical layer 1 of OSI model.
Major L2 networking standards
These standards are at data link layer 2 of OSI model. These are unlikely defined by RFCs and are maintained by engineering and communication organizations.
Ethernet history
We have 2 Ethernet standards:
- IEEE 802.3 Ethernet standard which has been updated several times to include new technologies
- The DIX Ethernet standard which is now referred to Ethernet II
The differences between framing styles are minimal. The most significant difference between the two standards is the addition of a Start Frame Delimiter (SFD) and the change of the Type field to a Length field in the 802.3.
Ethernet II is the Ethernet frame format used in TCP/IP networks.
- 1973 - Ethernet - invented by Dr Robert Metcalf of Xerox corp
- 1980 - DIX standard called now Ethernet II - Digital Equipment Corp, INtel and Xerox (DIX) 10Mb/s Ethernet over coaxial cable
- 1983 - IEEE 802.3 10 BASE-5 - 10 Mb/s Ethernet over thick coaxial cable
- 1985 - IEEE 802.3a 10 BASE-2 - 10 Mb/s Ethernet over thin coaxial cable
- 1990 - IEEE 802.3i 10 BASE-T - 10 Mb/s Ethernet over twisted pair
- 1993 - IEEE 802.3j 10 BASE-F - 10 Mb/s Ethernet over fiber optic
- 1995 - IEEE 802.3u 100 BASE-xx - Fast Ethernet 100 Mb/s over twisted pair and fiber (various standards)
- 1998 - IEEE 802.3z 1000 BASE-X - Gigabit Ethernet over fiber optic
- 1999 - IEEE 802.3ab 1000 BASE-T - Gigabit Ethernet over twisted pair
- 2002 - IEEE 802.3ae 10G BASE-xx - 10 Gigabit Ethernet over fiber (various standards)
- 2006 - IEEE 802.3an 10G BASE T - Gigabit Ethernet over twisted pair
Ethernet 802.3 versus Ethernet II
802.3 (which uses 802.2 LLC format) has a Length field in the same place that Ethernet II has a Type field.
IEEE 802.3 with 802.2 LLC (used by Spanning-Tree, ISIS) use the highlighted bytes for a Length field. 802.3 Upper-layer protocols are decoded via the 802.2 LLC Header / SNAP bytes. The SNAP bytes are used to decode protocols using traditional ethertype values; SNAP is only included when the 802.2 LLC DSAP / SSAP = 0xAAAA.
+----+----+------+------+------+------+-----+ | DA | SA | Len | LLC | SNAP | Data | FCS | +----+----+------+------+------+------+-----+ ^^^^^^^^ DA Destination MAC Address (6 bytes) SA Source MAC Address (6 bytes) Len Length of Data field (2 bytes: <= 0x05DC or 1500 decimal) <--- LLC 802.2 LLC Header (3 bytes) SNAP (5 bytes) Data Protocol Data (46 - 1500 bytes) plus padding if required FCS Frame Checksum (4 bytes)
Ethernet II - RFC 894 use these bytes for Type. Upper-layer protocols are decoded via the Type field
+----+----+------+------+-----+ | DA | SA | Type | Data | FCS | +----+----+------+------+-----+ ^^^^^^^^ DA Destination MAC Address (6 bytes) SA Source MAC Address (6 bytes) Type Protocol Type (2 bytes: >= 0x0600 or 1536 decimal) <--- Data Protocol Data (46 - 1500 bytes) plus padding if required FCS Frame Checksum (4 bytes)
Generic view comparison
Ethernet frame sizes
Minimum frame size is 64 bytes and max is 1518 Bytes, not including a Preamble and Start Frame Delimiter. IEEE 802.3ac standard, released in 1998, extended the maximum allowable frame size to 1522 bytes by adding 4 Bytes of 802.1Q VLAN Tag field.
L3 Internet Protocol IPv4/IPv6
IPv4
Internet Datagram Header
0 1 2 3 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ |Version| IHL |Type of Service| Total Length | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Identification |Flags| Fragment Offset | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Time to Live | Protocol | Header Checksum | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Source Address | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Destination Address | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ | Options | Padding | +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
The IP header structure is as follows:
4
|
8
|
16
|
32 bits
| ||||
Total length | |||||||
Fragment offset | |||||||
Protocol | |||||||
IP header structure
|
The IPv4 header structure is as follows:
Offsets | Octet | 0 | 1 | 2 | 3 | ||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Octet | Bit | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 |
0 | 0 | Version | IHL | DSCP | ECN | Total Length | |||||||||||||||||||||||||||
4 | 32 | Identification | Flags | Fragment Offset | |||||||||||||||||||||||||||||
8 | 64 | Time To Live | Protocol | Header Checksum | |||||||||||||||||||||||||||||
12 | 96 | Source IP Address | |||||||||||||||||||||||||||||||
16 | 128 | Destination IP Address | |||||||||||||||||||||||||||||||
20 | 160 | Options (if IHL > 5) |
IPv6
4
|
4
|
16
|
24
|
32 bits
|
Source address (128 Bits) | ||||
Destination address (128 bits) | ||||
IPv6 header structure
|
L4 TCP/UDP
TCP Transmission Control Protocol
Stateful, connection-orientated, reliable
The TCP header structure is as follows, IETF RFC 793 defined
16
|
32 bits
| |||||||
Destination port | ||||||||
TCP header structure
|
Control bits - 6 bits. The control bits may be (from right to left):
- U (URG) Urgent pointer field significant.
- A (ACK) Acknowledgment field significant.
- P (PSH) Push function.
- R (RST) Reset the connection.
- S (SYN) Synchronize sequence numbers.
- F (FIN) No more data from sender.
Window - 16 bits. The number of data octets which the sender of this segment is willing to accept, beginning with the octet indicated in the acknowledgment field.
UDP User Datagram Protocol
Best-effort transport protocol, stateless, connectionless, unreliable, No Flow Control, not connection-oriented
The UDP header structure is shown as follows, defined by IETF RFC 768
16
|
32 bits
|
Data | |
UDP header structure
|