TC P/IP
Binary, IP addre ssing
Binary Numbers
When we look inside the packets sent across a TCP/IP network,most ofthe information isrepresented using the binary number syst'em.And in particular,when we discuss that globaladdressing system introduced earlier,we ll discover that tho se global addresses are in fact 32 bitbinary numbe rs.
I find that the best way to introduce the binary numbering system is to learn to count in binary,andthat the best way to do that is to imagine a binary odometer.
You all know about odometer's: they are the displays that show how many kilometers (or miles, ifyour car is old like mine)youve put on your car.
((count in decimal))
((use 8 digit odometer))
Binary,unlike decimal (which has ten digits,0-9),has only two digits:0 and 1.So a binaryodometer will move a bit differently.
((count in binary))
((use 8 digit odometer))
((explain why–bytes))
Now this odometer analogy is useful for a first introduction,and isn't too bad if all you needed toaccomplish was counting from zero(or perhaps identifying small binary numbers).
But it would be tedious, to say that the least, to use this method to, e.g., identify the binaryrepresentation o f 25510,or determining the dec imal o f 101111012 .
Bina ry–decimal
An easier method for converting from binary to decimal is to determine the value of a particular bitin the binary number,based on its placement in the number(sometimes called its significance). It's pretty easy to determine the value of any particular bit:
(1)The least significant (rightmost)bit has a value ofone
(2)Bit n=(n-1)*2
1 0 1 1 1 1 0 1
128 64 32 16 8 4 2 1
To calculate the value of a binary=number, just add up the value of all the bits that are'on', i.e.,equal to one: 128+32+16+8+4+1 189
Decimal to binary
It's not quite as simple to convert from decimal to binary. Here’s one way to do it:
(1)Find the first bit whose value is greater that the value of the decimal number your areconverting(2) If n is that bit found in(1), turn on the bit n-1, if n-1 exists,else go to(5)below
(3)Subtract the value of n-1 from the original decimal number;
(4)Return to(1), repeat using the value you obtained from the subtraction in(3)
(5)Set any other bits to zero
Example:222
X 1 1 0 1 1 1 1 0
256 12864 32 16 8 4 2 1
222-128=94
94-64=30
30-16=14
14-8=6
6-4=2
2-2=0
Global Addressing
Recall from our introduction that a TCP/IP internet employs global addressing, i.e.,every'host'onan entire internetwork is uniquely identified by its address.
Now since TCP/IP is designed to interconnect networks, the way in which the global addressesuniquely identify hosts is by
(1) identifying the network o f that ho st
(2) identifying the host on that network
Conceptually, these global addresses operate something like the addressing in the followingdia gram:
A(2) B(2) C(2)
| | |
|----------|xx|-------------|xx|--------------|
| | |
A(1) B(1) C(1)
((Don't confuse this diagram with the similar one from the previous lecture,where we weredistinguishing local from global addressing.))
Where the letter identifies the network,and the number identifies the host on that network. Notice that,considered in isolation,neither the network portion nor the host portion uniquelyidentifies the host–it is when taken together that this constitutes a global addressing system.IP addressing
The protocol in the TCP/IP suite which specifies addressing is IP, the Internet Protocol. Although comparable to our alpha-numerical addressing in the above diagram, it's not quite ass imp le.
Every'host' in a TCP/IP internet is identified by a 32 bit binary number.An example might be:10101101 11001011 11110000 10101011
Now like our alpha-numerical addressing scheme,part of this 32 bit binary number identifies thenetwork,and part of it identifies the host on that network.
What portion identifies each is not,however,completely fixed.We'll begin our explanation ofthisby considering the original IP address scheme:
Classful IP addressing
In the original scheme,how a 32 bit IP address was divided into network portion and host portionwas based on the values of the first few most significant bits
Clas s A:0xxxxxx xxxxxxxx xxxxxxxx xxxxxxxxle ftmost byte network portion
Clas s B: 10xxxxxx xxxxxxxx xxxxxxxx xxxxxxxxle ftmost 2 byte s network portion
Clas s C: 110xxxxx xxxxxxxx xxxxxxxx xxxxxxxxle ftmost 3 b ytes netwo rk portio n
Clas s D: 1110xxxx xxxxxxxx xxxxxxxx xxxxxxxx
Clas s E: 1111xxx xxxxxxxx xxxxxxxx xxxxxxxx
Only Class A,B,C are important for now.
Dotted Decimal Representation
Since this 32 bit representation isn't very digestable by humans,normally we refer to IP addressesin d ec imal, like this:
1. Break up the 32 bit IP addre ss into four 8 bit chunks.
2. Treating each ofthese'octets'as a separate number, translate them into a decimal
3. Separate each dec imal number from its ne ighbours with a dot
((couple of examples))
And now we should be able to figure out the decimal representation of our three classes of internetaddre s se s:
ClassA:
00000000000000000000000000000000
-01111111 11111111 11111111 11111111
=0.0.0.0 andeverything
127.255.255.255 inbetween
((ex amples))
ClassB:
10000000000000000000000000000000
- 10111111 11111111 11111111 11111111
=128.0.0.0
191.255.255.255
Back to the division into network and host portions: in the case of Class A the first decimal numberdesignates the network,wh' ile the next three can be seen as one big number,designating the host(i.e.,pretend the dots arent there).
Class B, the first two, the net, the final two the host.
Class C, the first three the net, the final one the host.
Special IP addresses
Not every IP address in the 32 bit address space can be assigned to a ho st.
- If all the host bits in a particular Class A,B or C address are set to 0, this refers to the networkitse lf(e g, 192.168.1.0)
If all the host bits are set to 1, then this refers to all the hosts on that network; this isreferred to as the directed broadcast address for that network
(e.g. 172.16.255.255)
(e.g. 10.255.255.255) these addresses can be routed.
If all the bits in the 32 bit address are set to 1, this referred to as the limited broadcast
(255.255.255.255) this addres s cannot be routed.
If all the net bits are set to 0; the'n in my'experience this is meaningless,unless the hostpart is also set to 0; this often refers to this host.
(used in DHCP as source address before the client receives an address lease)
(Linux interprets it as 'this ho st' in a ping, in fact it pings the loopback)
Any address' in the C lass A network 127.0.0.0 refers to the'loopback' interface:a pseudointerface that doesn t rely on the existence of a physical network or even a Network InterfaceCard(NIC)for testing and software relying on a TCP/IP stack without a network connection.Address-space reserved for private Internets
ClassA: 10.0.0.0–10.255.255.255
ClassB: 172.16.0.0–172.31.255.255
Class C: 192.168.0.0–192.168.255.255
Subnetting
-The original class A,B and C addressing scheme isn't very flexible.
If you have a netwo' rk with about 250 hosts,a class C works pretty well,but if you have a networkwith far less, it s a waste of address space.
If you have a networ'k with about 65000 hosts,a class B works,but e.g., if your network has 300hosts,a class isnt going to work,and a class B is a waste.
Class A can accommodate over 10 million hosts.
-For these reasons, subnetting was specified. (RFC 950)
Subnet addresses
RFC 950 discusses optionally subdividing the 32 bit address into three portions. In addition to:
1.A network portion
2.A hostportionthe standard specifies
A subnetportion
-The general id' ea is that,even though an organization might control, say,a particular class B addressspace, it doesnt want just one single LAN or physical network.
-For example, the University of Calgary has 136.159.0.0,but it would probably want to create anumb er o f phys ical networks.
-The process of subnetting involves 'stealing' some number ofbits from the host portion, to designatethe subnet with.
-Bits must be stolen as a contiguous series starting from the most significant host bit. (RFC
950 recommendation.not mathematically required,but universally adhered to)Let's start with a simple example:
Suppose you want to subnet the Class B network address: 172.16.0.0
What you could do is use the third byte to refer to the subnet,and the last byte to refer to the host:
172.16.10.26: subnet 10,host 26
172.16.21.21 : subnet 21,host 21
But,how are network hosts supposed to know what subnet they are on?
Remember,hosts can determine that they are on a class B network and what class B network theyare on,merely by inspecting their IP address.
172.16.0.26 is class B(10xxxxx. . .)
But they cannot determine their subnet by inspecting their address.
Subnet masks
The way you specify a subnet is by adding more information,over and above the IP address. In addition,we must specify a subnet mask:
A subnet mask is a 32 bit number,where all the network and subnet bits are set to 1,and allthe host bits are set to 0
So inour example:
172.16.10.26
IP: 10101100.00011000.00001010.00011010sub mask: 11111111.11111111.11111111.00000000
4. This netmask determines the portion of the 32 bit number used to designate the subnet.-With this in mind, let's move onto a more complex example:
256(-2 for broadcast and net address)for hosts.So we had:
172.16.0.0, 172.16.0.1, 172.168.0.2, . . .
172.16.1.0, . . .
172.16.2.0, . . .
…
But if the portion reserved for th'e subnet doesn't correspond to a byte,we pretty muchhave to work in binary(at least until we re more comfortable)
Example:
Suppose we have the Class C address 192.168.0.0,and we want 6 subnets.
11000000.10101000.00000000.00000000
11111111.11111111.11111111.11100000
(NB 2n=the number of possible values,where n=#bits)
Invalid subnetting
RFC 950 suggests that a subnet designated by“all ones”or“all zeros”(in the subnet portion of theaddress) should not be used.So,e.g., the following would be invalid:
172.16.0.1 (255.255.255.0) ('all zeros')
172.16.255.1 (255.255.255.0) ('all ones')
The r”eason this i's su'ggested is to preserve the interpretation of“all zeros”(meaning'this')and“allones (meaning all).
Normally they are not thus interpreted,but sometimes they are interpreted as invalid. (Theproblem is ambiguity: in certain cases we cannot distinguish a reference to the(classful)networkitself,as opposed to a subnet on that network. For example,does 172.16.0.0 refer to the class Bnetwork itself,or to the all zeros subnet? Does 172.16.255.255 refer to the network broadcast,orthe all ones broadcast address?)
There are a few other cases of invalid subnetting:
1. Borrowing a single bit. (we only get subnets 1 and 0,which RFC 950 recommends against)
2. Borrowing all the bits (no room left for hosts)
3. Borrowing all but one bit(leaves only subnet and broadcast addresses)
(There are cases where 3. is legitimate, in particular for point-to-point,non-broadcast links.)Determining local versus remote delivery
Classful:
If(network address o f dst=network address o f src)Then( local delivery)
Sub netted:
If(dst ip&netmask=src ip&netmask)
Then( local delivery)
B itwise'and'
0&0=1
1&0=0
0&1=0
1&1=1
Justg是一家俄罗斯VPS云服务器提供商,主要提供南非地区的VPS服务器产品,CN2高质量线路网络,100Mbps带宽,自带一个IPv4和8个IPv6,线路质量还不错,主要是用户较少,带宽使用率不高,比较空闲,不拥挤,比较适合面向非洲、欧美的用户业务需求,也适合追求速度快又需要冷门的朋友。justg的俄罗斯VPS云服务器位于莫斯科机房,到美国和中国速度都非常不错,到欧洲的平均延迟时间为40毫秒,...
hostround怎么样?大硬盘服务器,高防服务器。hostround,美国商家,2017年成立,正规注册公司(Company File #6180543),提供虚拟主机、VPS云主机、美国服务器、荷兰服务器租用等。现在有1款特价大硬盘独服,位于达拉斯,配置还不错,本月订购时包括免费 500Gbps DDoS 保护,有兴趣的可以关注一下。点击直达:hostround官方网站地址美国\荷兰独立服务器...
介绍:御速云成立于2021年的国人商家,深圳市御速信息技术有限公司旗下品牌,为您提供安全可靠的弹性计算服务,随着业务需求的变化,您可以实时扩展或缩减计算资源,使用弹性云计算可以极大降低您的软硬件采购成本,简化IT运维工作。主要从事VPS、虚拟主机、CDN等云计算产品业务,适合建站、新手上车的值得选择,拥有华东江苏、华东山东等国内优质云产品;香港三网直连(电信CN2GIA联通移动CN2直连);美国高...