计算机网络编程必备知识--一篇就够啦

1.基础知识

1).网络

网络是由若干结点和连接这些结点的链路组成,网络中的结点可以是计算机,交换机、路由器等设备。 网络设备有:交换机、路由器、集线器 传输介质有:双绞线、同轴电缆、光纤

下图是一个简单的网络示意图:

image-20220322151044082.png

2).互联网

把多个网络连接起来就构成了互联网。 目前最大的互联网就是我们常说的因特网。

image-20220322151900978.png

3).IP地址

IP地址的目的:在网络中唯一标识一台主机;

IP 地址就是给因特网上的每一个主机(或路由器)的每一个接口分配的一个在全世界范围内唯一的标识符。 IP 地址因其特殊的结构使我们可以在因特网上很方便地进行寻址。

IP 地址有分 IPV4 和 IPV6 两种类别格式, IPV4 是类似”A.B.C.D” 的格式,它是 32 位的,用“.”分成四个段,每个段是 8 个位(值为 0-255),用 10 进制表示。 IPV6 地址是 128位,格式类似”XXXX:XXXX:XXXX:XXXX:XXXX:XXXX:XXXX:XXXX” , 用“:“分成 8 个段,每个段 16 个位,用 4 个 16 进制数表示。

◼ IPV4 地址示例: “192.168.31.1”

◼ IPV6 地址示例: “2001:0db8:3c4d:0015:0000:0000:1a2f:1a2b“

接下来描述的 IP 地址默认都指的是 IPV4 的地址。 为了便于寻址,了解目标主机的位置,每个 IP 地址由网络号和主机号两个部分构成。同一个物理网络上所有的主机都使用同一个网络号,只是主机号不同。

IP 地址组成:

image-20220322153135812.png

IP 地址分类:

image-20220322153210271.png

由于每类地址的开头是固定的,因此每类地址都有自己的范围:

◼ A 类: IP 地址范围为 0.0.0.0~127.255.255.255。

◼ B 类: IP 地址范围为 128.0.0.0~191.255.255.255。

◼ C 类: IP 地址范围为 192.0.0.0~223.255.255.255。

D 类和 E 类一般不使用  .

使用命令“ifconfig”可以在 linux 查看自己的 ip 地址;

4).MAC地址

在局域网中,硬件地址又称为物理地址或者 MAC 地址,长度 48 位,是固化在计算机适 配器的 ROM 中的地址。因此假定连接在局域网上的一台计算机的适配器坏了而我们更换了 一个新的适配器,那么这台计算机的局域网的“地址”也就改变了,虽然这台计算机的地理 位置没有发生变化。其次,当我们把一个笔记本从一个城市带到另一个城市时,虽然地理位 置改变了,但是电脑在局域网中的“地址”仍然不变。由此可见,局域网上某个主机的“地 址”根本不能告诉我们这台主机位于什么地方。 在网络上方便的寻找某个主机,还得依靠 ip 地址进行  ;

MAC示例:使用ifconfig命令;

5).端口号

端口号就是应用程序的代号;
那么也就是说我们通过一个ip地址+端口号就可以指定一个主机上的应用程序:ip+port;
实现A主机上的一个进程和B主机上的一个进程实现通信: 源主机的应用程序:ip+port 和目的主机的应用程序ip+port就可以通讯了;
常见的端口号:
Web服务器:80
ssh:22
Mysql:3306
1024以下的都是一些知名的端口号.

6).网络协议

网络协议就是一组网络规则的集合,是我们共同遵守的约定或标准。常见的协议:

HTTP: 超文本传输协议

◼ FTP: 文件传输协议

◼ TELNET : 是 internet 远程登陆服务的标准协议。

TCP : 传输控制协议(TCP, Transmission Control Protocol)是一种面向连接的、可 靠的、基于字节流的传输层通信协议

UDP :用户数据报协议

◼ IP : Internet Protocol 简称 IP,又译为网际协议或互联网协议

◼ ICMP :因特网控制报文协议

◼ ARP : 地址解析协议,是根据 IP 地址获取 MAC 地址的协议

◼ RARP : 逆地址解析协议

2.网络分层模型

1)OSI 的 7 层模型与 tcp/ip 协议族体系 4 层结构

image-20220322160039763.png

2).数据链路层

数据链路层的主要功能是:通过各种控制协议,将有差错的物理信道变为无差错的、能可靠传输数据帧的数据链路。

在计算机网络中由于各种干扰的存在,物理链路是不可靠的。因此,这一层的主要功能是在物理层提供的比特流的基础上,通过差错控制,使有差错的物理线路变为无差错的数据链路,即提供可靠的通过物理介质传输数据的方法。

该层通常又被分为介质访问控制(MAC)和逻辑链路控制(LLC)两个子层。

◼ MAC 子层的主要任务是解决共享型网络中多用户对信道竞争的问题,完成网络介质的访问控制;

◼ LLC 子层的主要任务是建立和维护网络连接,执行差错校验、流量控制和链路控制。

TCP/IP 协议体系结构中,数据链路层的功能描述为实现网卡接口的网络驱动程序,以处理数据在物理媒介上的传输,不同的物理网络具有不同的电气特性,网络驱动程序隐藏了这些细节,为上层协议提供了一个统一的接口。

这一层主要关注的三个基本问题是:封装成帧,透明传输和差错检测。

3).网络层

网络层实现数据包的选路和转发。广域网或者说互联网通常使用众多分级的路由器来连接分散的主机或者局域网,因此,通信的两台主机一般不是直接相连的,而是通过多个中间结点(路由器)连接的。网络层的任务就是选择这些中间结点,以确定两台主机之间的通信路径。同时,网络层对上层协议隐藏了网络拓扑连接的细节,使得在传输层和网络应用程序看来,通信的双方是直接相连的。

网络层最核心的协议是 IP 协议(Internet Protocol,因特网协议)。 IP 协议根据数据包的目的 IP 地址来决定何如投递它。如果数据包不能直接发送给目标主机,那么 IP 协议就是为它寻找一个合适的吓一跳路由器,并将数据包交付给该路由器来转发。多次重复这一过程,数据包最终到达目标主机,或者由于发送失败而被丢弃。可见, IP 协议使用逐跳的方式确定通信路径。

网络层另外一个重要的协议是 ICMP 协议(因特网控制报文协议)。它是 IP 协议的重要补充,主要用于检测网络连接。

IP 协议为上层协议提供无状态、无连接、不可靠的服务。无状态是指通信双方不同步传输数据的状态信息,因此所有 IP 数据报的发送、传输和接收都是相互独立、没有上下文关系的。这种服务最大的缺点是无法处理乱序和重复的 IP数据报。 虽然 IP 数据报头部提供了一个标识字段用以唯一标识一个 IP 数据报,但它是被用来处理 IP 分片和重组的,而不是用来指示接收顺序的。无状态的优点是简单、高效。无须为保持通信状态而分配一些内核资源,也无须再每次通信时携带状态信息。

无连接是指 IP 通信双方都不长久地维持对方的任何信息。这样,上层协议每次发送数据的时候,都必须明确指定对方的 IP 地址。

不可靠是指 IP 协议不能保证 IP 数据报准确地到达接收端,它只是承诺尽最大努力。

IPV4 头部结构如下

image-20220322160423423.png

4)传输层

传输层为两台主机上的应用程序提供端到端的通信。与网络层使用的逐跳通信的方式不同,传输层只关心通信的起始端和目的端,而不在乎数据包的中转过程。

传输层协议主要有三个: TCP 协议、 UDP 协议和 SCTP 协议

TCP 协议(传输控制协议)为应用层提供可靠的、面向连接的和基于流的服务。 TCP 协议使用超时重传、确认应答等方式来确保数据包被正确的发送至目的端,因此 TCP 服务是可靠的。使用 TCP 协议通信的双方必须先建立 TCP 连接,并在内核中为该连接维持一些必要的数据结构,比如连接状态,读写缓冲区等。当通信结束时,双方必须关闭连接以释放这些内核数据。 TCP 服务是基于流的,基于流的数据没有边界(长度)限制,它源源不断地从通信地一端流入另一端。发送端可以逐个字节地向数据流中写入数据,接收端可以逐个字节地将它们读出。

TCP 协议报头:

image-20220322160540504.png

UDP 协议(用户数据报协议)则与 TCP 协议完全相反,它为应用层提供不可靠、无连接、基于数据报地服务。“不可靠”意味着 UDP 协议无法保证数据从发送端正确地传送到目的端。如果数据在中途丢失,或者目的端通过数据校验发现数据错误而将其丢弃,则 UDP协议只是简单地通知应用程序发送失败。因此,如果要使 UDP 协议可靠,那么应用程序通常要自己处理数据确认、超时重传等逻辑。 UDP 是无连接的,即通信双发不保持一个长久的联系,因此应用程序每次发送数据都要明确指定 接收端的地址。基于数据报的服务,是相对基于流的服务而言的。每次 UDP 数据报都有一个长度,接收端必须以该长度为最小单位将其所有内容一次性读出,否则数据将被截断。

SCTP 协议(流控制传输协议)是一种相对较新的传输层协议,它是为了在因特网上传输电话信号而设计的。这里暂时不讨论 SCTP 协议。

5) 应用层

应用层负责处理应用程序的逻辑。(HTTP协议)

6)为什么要分层?

各层之间是独立的;
灵活性好;
结构上可分割开;
易于实现和维护;
能促进标准化工作;

3.网络应用程序通信流程

如下图,应用程序 A 要将数据”hello” 传给网络上另外一台主机上的应用程序 B, 数据“hello”从应用层发送给传输层后,传输层在数据前面加上 tcp 协议或 udp 协议的报头,将整条报文发给网络层,网络层添加自己的 IP 报头,再将整条数据发送给数据链路层。数据链路层将数据封装成能在网络中独立传输的数据单元,即数据帧。封装好的数据帧通过网络传输到另一台主机,然后再从下层依次拆包,将数据部分送往应用层。应用程序 B 就得到 了数据” hello” 。

image-20220322160813287.png

4.tcp服务器客户端编程流程

TCP 提供的是面向连接的、可靠的、字节流服务。 TCP 的服务器端和客户端编程流程如下:

image-20220323181116367.png

socket()方法是用来创建一个套接字,有了套接字就可以通过网络进行数据的收发。这也是为什么进行网络通信的程序首先要创建一个套接字。创建套接字时要指定使用的服务类型,使用 TCP 协议选择流式服务(SOCK_STREAM) 。 bind()方法是用来指定套接字使用的 IP 地址和端口。 IP 地址就是自己主机的地址,如果主机没有接入网络,测试程序时可以使用回环地址“127.0.0.1”。端口是一个 16 位的整形值,一般 0-1024 为知名端口,如 HTTP 使用的 80 号端口。这类端口一般用户不能随便使用。其次, 1024-4096 为保留端口, 用户一般也不使用。 4096 以上为临时端口,用户可以使用。在Linux 上, 1024 以内的端口号,只有 root 用户可以使用。 listen()方法是用来创建监听队列。 监听队列有两种,一个是存放未完成三次握手的连接,一种是存放已完成三次握手的连接。 listen()第二个参数就是指定已完成三次握手队列的长度。 accept()处理存放在 listen 创建的已完成三次握手的队列中的连接。每处理一个连接,则accept()返回该连接对应的套接字描述符。如果该队列为空,则 accept 阻塞。

connect()方法一般由客户端程序执行,需要指定连接的服务器端的 IP 地址和端口。该方法执行后,会进行三次握手, 建立连接。

image-20220324115148370.png

send()方法用来向 TCP 连接的对端发送数据。 send()执行成功,只能说明将数据成功写入到发送端的发送缓冲区中,并不能说明数据已经发送到了对端。 send()的返回值为实际写入到发送缓冲区中的数据长度。 recv()方法用来接收 TCP 连接的对端发送来的数据。 recv()从本端的接收缓冲区中读取数据,如果接收缓冲区中没有数据,则 recv()方法会阻塞。返回值是实际读到的字节数,如果recv()返回值为 0, 说明对方已经关闭了 TCP 连接。 close()方法用来关闭 TCP 连接。此时,会进行四次挥手。

image-20220324191411085.png

  • 49
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

雪星猫宇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值