本文主要是介绍网络编程基础,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
网络编程基础
一、CS 与 BS
1.CS 客户端与服务端之间的关系
2.BS 浏览器与服务端之间的关系
# C/S架构与socket的关系:
我们学习socket就是为了完成C/S架构的开发
二、什么是网络?
网络=物理连接介质+互联网通信协议
# OSI七层协议
应用层
表示层
会话层
传输层
网络层
数据链路层
物理层
# 又可以分为5层 将应用层 表示层 会话层合在了一起
应用层
传输层
网络层
数据链路层
物理层
# 其实还是可以在分为4层,将 数据链路层和物理层合为了物理层,但是我们主要研究5层就好了
三、为什么要有网络
# 为了方便数据的传输/通信,之前叫信息高速公路,现在叫互联网
四、物理层
# 功能:主要是基于电器特性发送高低电压,高电压对应数字1,低电压对应数字0
五、数据链路层
数据链路层由来:单纯的电信号0和1没有任何意义,必须规定电信号多少位一组,每组什么意思,每个组称为帧
# 数据链路层的功能:定义了电信号的分组方式
'''
在这一层最重要就是Mac地址,假如从物理层传递来一组数据,然后数据链路层就会给这一层数据变成两个部分------头部和数据
头部是由固定的18个字节组成的,6个字节标记着源主机的Mac地址,6个字节标记着目标主机的Mac地址,还有6个字节是数据类型
然后数据部分就是数据,数据链路层就把数据打包成了这样
'''
1、以太网协议
# 在数据链路层 支持的是以太网协议
早期的时候各个公司都有自己的分组方式,后来形成了统一的标准,即以太网协议ethernet
ethernet规定:
# 1.一组电信号构成一个数据包,叫做'帧'
# 2.每一数据帧分成:报头head和数据data两部分
head包含:(固定18个字节)
发送者/源地址,6个字节
接收者/目标地址:6个字节
数据类型:6个字节
data包含:最短46字节,最长1500字节
数据包的具体内容:
head长度+data长度=最短64字节,最长1518字节,超过最大限制就分片发送
1.以太数据称之为数据帧,分为head+data两部分,其head长度固定
2.规定但凡是接入互联网的主机必须有一块网卡,网卡上有一个mac地址,且世界唯一
3.以太网协议的通信采用的是广播的通信方式==》计算机通信靠吼
2、mac地址
# 头部中包含的源和目标地址由来:ethernet规定接入internet的设备都必须具备网卡,发送端和接受端的地址便是指网卡的地址,即mac地址
# mac地址:每块网卡出厂时都被烧制上一个世界唯一的mac地址,长度为48位2进制,通常由12位16进制数表示(前六位是厂商编号,后六位是流水线号)
3、广播
有了mac地址,同一网络内的两台主机就可以通信了(一台主机通过arp协议获取另外一台主机的mac地址)
# ethernet采用最原始的方式,广播的方式进行通信,既计算机通信基本靠吼。
'''
计算机通讯为什么叫吼呢,是因为比如局域网中,我向目标主机发送了数据,然后到了交换机,然后就开始像广播一样通知到了局域网内每一个计算机,然后每个计算机通过Mac地址来判断是不是自己要接受这个数据,不是自己就把包扔掉,正因为通知到了每一个计算机,所以就是广播----吼,那是不是每次都需要吼呢,答案是不是的,交换机有个记忆Mac地址的功能,当他的Mac记忆表没有这个Mac地址的时候 才会吼
'''
六、网络层
网络的由来:有了ethernet、mac地址、广播的发送方式,世界上的计算机就可以彼此通信了,问题是世界范围的互联网是由一个个彼此隔离的小的局域网组成的,那么如果所有的通信都采用以太网的广播方式,那么一台机器发送的包全世界都会收到,这就不仅仅是效率低的问题,这会是一种灾难
1.IP协议
规定网络地址的协议叫ip协议,它定义的地址称之为ip地址,广泛的采用的v4版本既ipv4,规定网络地址由32位2进制表示
范围:0.0.0.0-255.255.255.255
一个ip地址通常携程四段十进制数:例如 172.16.10.1
# ip地址分成两部分:
网络部分:标识子网
主机部分:标识主机
注意:单纯的ip地址段只是标识了ip地址的种类,从网络部分或主机部分都无法辨识一个ip所处的子网
例:172.16.10.1与172.16.10.2并不能确定二者处于同一个子网
# IP+MAC+端口=》标识全世界范围内独一无二的一个基于网络通信的软件
# IPV4目前主流,地址不够用了,正在推IPV6
2.子网掩码
所谓 子网掩码 ,就是标识自网络特征的一个参数。它在形式上等同于ip地址,也是一个32位二进制数字,它的网络部分全部位1,主机部分全部位0。比如,ip地址172.16.10.1,如果已知网络部分是前23位,主机部分是后8位,那么子网掩码就是:11111111.11111111.11111111.00000000,写成十进制就是255.255.255.0
知道 子网掩码 我们就能判断,任意两个ip地址是否处在同一个子网络(局域网)。方式是将两个ip地址与子网掩码分别进行AND运算(两个数位都为1,运算结果为1,否则为0)然后比较结果是否相同,如果是的话,就表明它们在同一个子网络中,否则就不是
# 总结:ip协议的主要作用主要是有两个,一个是为每一台计算机分配ip地址,另一个是确定那些地址在同一个子网络
3.IP数据包
ip数据包也分为head和data部分,无须为ip包定义单独的栏位,直接放入以太网包的data部分
head:长度为20-60字节
data:最长为65515字节
以太网数据包的'数据'部分,最长只有1500字节,因此,如果ip数据包超过了1500字节,它就需要分割成几个以太网数据包,分开发送了
"""
网络层也会去封装一个头,这个头则主要是IP地址,头里面会包括本主机的IP地址和目标主机的IP地址,IP地址是会转化成Mac地址,具体因为ARP协议,这个我们稍后再说
"""
4.ARP协议
arp协议的由来:计算机通信基本靠吼,既广播的方式,所有上层的包到最后都要封装上以太网头,然后通过以太网协议发送,在谈及以太网协议的时候,我们了解到,通信时基于mac 的广播方式实现,计算机在发包时,获取自身的mac时容易的,如何获取目标主机的mac,就需要通过arp协议
# arp协议功能:广播的方式发送数据包,获取目标主机的mac地址
# 协议工作方式:每台主机ip都是已知的
工作方式:
1.首先通过ip地址和子网掩码区分出自己所处的子网
2.如果处于同一网络,通过arp获取网关的mac地址
3.这个包会以广播的方式在发送端所处的子网内传输,所有主机接收后拆开包,发现目标ip为自己的,就响应,返回自己的mac地址。
1.通信的第一步先拿到目标主机的ip地址
2.判断出目标主机与自己是否在一个子网里
# 如果在一个子网里,数据包的走向:
源主机---》本地交换机---》目标主机
# 如果不在一个子网里,数据包的走向:
源主机---》本地交换机---》本地路由器---》公网---》目标路由器---》目标交换机---》目标主机
'''
如果在一个子网里 源主机想传给目标主机一段数据,知道自己的IP地址但是不知道目标主机的Mac只知道目标的IP,就会将这段数据去打包,目标的Mac地址写为FF.FF.FF.FF,传给交换机,交换机因为懂ARP协议所以看到目标的Mac地址是这样的就立刻懂了,大吼一声,传给所有的计算机,计算机也都懂ARP协议啊,看到这个Mac格式 就会分析IP地址是不是他自己,不是则把包丢掉,是就接受这段数据,这就是如果在一个子网里,数据包的走向具体流程
如果不在一个子网,源主机想传给目标主机一段数据,知道自己的IP地址但是不知道目标主机的Mac只知道目标的IP,就会将这段数据去打包,目标的Mac地址写为FF.FF.FF.FF,传给交换机,交换机发现这个不在局域网里面,便传给网关----路由器,注意,路由器这里就传到公网,把Mac地址换成了网关的Mac地址,然后再去传输到目标的局域网,通过IP地址转化成Mac地址去寻找目标主机
IP地址能转换成Mac地址 都是因为ARP协议的功劳
'''
七、传输层
传输层的由来:网络层的ip帮我们区分子网,以太网层的mac帮我们找到主机,然后大家使用的都是应用程序,你的电脑上可能同时开启QQ,暴风影音,等多个应用程序。
我们通过ip和mac找到了一台特定的主机,如何标识这台主机上都要应用程序,答案就是端口,端口既应用程序与网卡关联的编号
# 传输层的功能:建立端口到端口的通信
端口范围0-65535,0-1023为系统占用端口
1. TCP协议
可靠传输,TCP数据包没有长度限制,理论上可以无限长,但是为了保证网络的效率,通常TCP数据包的长度不会超过IP数据包的长度,以确保单个TCP数据包不必再分割
"""
TCP协议为什么说是可靠的协议,因为C(客户端)----------------S(服务端)的传输中,C传输了一个请求,S必有回应,所以才说是可靠的协议,那么具体的请求流程是什么样子的呢
"""
# 三次握手连接
'''
C向S发送了请求,询问能不能建立连接通道,S同意了,然后S向C也发送了请求,C也同意了,但是大家会纳闷,这不是4次握手嘛,因为中间有两次都是S向C发送了请求,所以说把这两次都合在了一块,同时发送了,所以就是三次握手连接
'''
# 4次握手断开连接
"""
在C和S建立好互相连接的时候,S或者C就会向对方发出断开连接的请求,所以对方也会同意,但是这次不能同意的时候也发出断开最后连接的请求,因为这个时候可能最后的连接还在传输数据,等传输彻底结束后,就会发送断开最后连接的请求,这个时候在同意,就彻底断开连接了
"""
# 半连接池
2. udp 协议
不可靠传输, 报头 部分一共只有8个字节,总长度不超过65535字节,正好放进一个ip数据包
八、应用层
应用层由来:用户使用的都是应用程序,均工作应用层,互联网是开发的,大家都可以开发自己的应用程序,数据多种多样,必须规定好数据的组织形式
# 应用层功能:规定应用程序的数据格式
例:TCP协议可以为各种各样的程序传递数据,比如Email,WWWW,FTP等等。那么,必须有不同协议规定电子邮件,网页,ftp数据的格式,这些应用程序协议就构成了应用层
1.socket(套接字)
#套接字 socket 将传输层,网络层,数据链路层,物理层封装端口,只专心研发应用程序
我们知道,两个进程如果需要进行通讯,最基本的一个前提,以为的标识一个进程,再本地进程通讯中,我们可以使用PDI来唯一标识一个进程,但PID旨在本地唯一,网络中的两个进程PID冲突几率很大,这时候我们需要另辟它径,我们知道IP层的ip地址可以唯一标示主机,而TCP层协议和端口号可以唯一标示主机的一个进程,这样哦我们可以利用ip地址+协议+端口号唯一标示网络中的一个进程
能够唯一标识网络中的进城后,他们就可以利用socket进行通信了
# 什么是socket ?
我们常把socket翻译为套接字,socket实在应用层和传输层之间的一个抽象层,它把TCP/IP层复杂的操作抽象为几个简单的接口供应层调用已实现进程再网络中通信
socket起源于UNIX,在Unix一切皆文件哲学的思想下,socket是一种 打开-读/写-关闭 模式的实现,服务器的客户端各自维护一个 文件 在建立连接打开后,可以向自己文件写入内容共对方读取,或者读取对方内容,通讯结束时关闭文件
子网划分概念
子网划分时通过借用ip地址的若干位主机位来充当子网地址的,从而将原来的网络分为若干个彼此隔离的子网实现的
# 注意:arp协议通过ip地址获取目标主机的mac地址这一过程使用的时广播的方式,这个广播地址就是通过子网地址与子网掩码计算而来的,只有计算出的这一子网内的主机才能收到这个arp广播包
# 子网划分与clan都可以做到隔离广播域,知识子网划分时三层隔离,vlan时二层隔离
子网划分步骤
1.确定要划分的子网数以及每个子网的主机数
2.求出子网数目对用的二进制的位数N及主机数目对应的二进制数的位数M
3.对该ip地址的元子网掩码,将其主机地址部分的前N位置1(其余位置0)或后M位置0(其余位置1)既得出该IP地址划分子网后的子网掩码
划分子网注意事项
1.在子网划分是不仅需要考虑目前需要,还应该了解将来需要多少子网和主机,子网掩码使用较多的主机位,可以得到更多子网,节约了ip地址资源,若将来需要更多的子网时,不用再重新分配ip地址,但每个子网的主机数量有限;反之,子网掩码使用较少的主机位,每个子网的主机数允许有更大的增长,但可用子网数有限。
2.一般来说,一个网络中的节点数太多,网络会因为广播通信而饱和,所以网络中的主机数量的增长时有限的,也就是说,再条件允许的情况下,应将更多的主机位用于子网位。
为什么要子网划分
internet组织机构定义了物种IP地址,用于主机的有A,B,C三类地址。其中A类网络有126个,每个A类网络可能有16,777,214台主机,他们处于同一广播域。而在同一广播域中有这么多结点时不可能的,网络会因为广播通信而饱和,结果造成16,777,214个地址大部分没有分配出去,形成了浪费。而另一方面,随着互联网应用的不断扩大,IP地址资源越来越少。为了实现更小的广播域帮更好的利用主机地址中的每一位,可以把基于类的IP网络进一步分为更小的网络,每个子网有路由器界定冰分配一个薪的子网网络地址,子网地址是借用基于类的网络地址的主机部分创建的。划分子网后,通过使用掩码,把子网隐藏起来,是的从外部看网络没有变化,这就是子网掩码
# 简单的说:一个公司不可能使用254个公网地址,A公司想用6个地址,B公司也想用6个地址,如果把这两个公司的地址都放在一个大网段里面,这两个公司的地址就能够直接互通
子网划分优点
1.减少网络流量
2.提高网络性能
3.简化管理
4.易于扩大地理范围
子网划分与VLAN
子网划分完毕后,链接再同一台交换机上的不同子网的计算机,站在三层的角度属于不同的局域网,但是他们都是连接再同一台交互机上,站在二层角度,就是同一个局域网,说白了一个数据包的广播还是会g该交互机所有的端口,所以,子网划分通常与vlan配合使用
# 二层隔离和三层隔离
两台计算机加入不同的交换机,称之为二层隔离
子网地址不同,称之为三层隔离
结论:
1.二层隔离与三层隔离需要保持一致
2.二层联通,三层可以隔离,这几台机器可能在连接同一个交换机,但是不在同一个局域网
VLAN
VLAN(Virtual LAN),翻译成中文是“虚拟局域网”。LAN可以是由少数几台家用计算机构成的网络,也可以是数以百计的计算机构成的企业网络。VLAN所指的LAN特指使用路由器分割的网络——也就是广播域。
简单来说,同一个VLAN中的用户间通信就和在一个局域网内一样,同一个VLAN中的广播只有VLAN中的 成员才能听到,而不会传输到其他的VLAN中去,从而控制不必要的广播风暴的产生。
这篇关于网络编程基础的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!