最新消息: USBMI致力于为网友们分享Windows、安卓、IOS等主流手机系统相关的资讯以及评测、同时提供相关教程、应用、软件下载等服务。

【网络通信】

维修 admin 9浏览 0评论

【网络通信】

网络通信

  • 1 网络通信
    • 1.1 OSI 七层模型
    • 1.2 IP地址
    • 1.3 TCP/IP 协议
    • 1.4 TCP 协议
    • 1.5 FTP 协议
    • 1.6 端口号
    • 1.6 socket
  • 2
  • 3
  • 4
  • 5

1 网络通信

网络通信本质上是一种进程间通信,是位于网络中不同主机上的进程之间的通信,属于 IPC 的一种,
通常称为 socket IPC,

1.1 OSI 七层模型



物理层功能: 主要是基于电器特性发送高低电压(电信号),高电压对应数字1,低电压对应数字0
数据链路层由来: 单纯的电信号0和1没有任何意义,必须规定电信号多少位一组,每组什么意思
数据链路层的功能:定义了电信号的分组方式

网络层由来: 有了ethernet、mac地址、广播的发送方式,世界上的计算机就可以彼此通信了,问题是世界范围的互联网是由一个个彼此隔离的小的局域网组成的,那么如果所有的通信都采用以太网的广播方式,那么一台机器发送的包全世界都会收到,这就不仅仅是效率低的问题了,这会是一种灾难.

传输层的由来:网络层的ip帮我们区分子网,以太网层的mac帮我们找到主机,然后大家使用的都是应用程序,你的电脑上可能同时开启qq,暴风影音,等多个应用程序,那么我们通过ip和mac找到了一台特定的主机,如何标识这台主机上的应用程序,答案就是端口,端口即应用程序与网卡关联的编号。传输层功能:建立端口到端口的通信
补充:端口范围0-65535,0-1023为系统占用端口
tcp协议:
可靠传输,TCP数据包没有长度限制,理论上可以无限长,但是为了保证网络的效率,通常TCP数据包的长度不会超过IP数据包的长度,以确保单个TCP数据包不必再分割。


应用层由来:用户使用的都是应用程序,均工作于应用层,互联网是开发的,大家都可以开发自己的应用程序,数据多种多样,必须规定好数据的组织形式
应用层功能:规定应用程序的数据格式。
例:TCP协议可以为各种各样的程序传递数据,比如Email、WWW、FTP等等。那么,必须有不同协议规定电子邮件、网页、FTP数据的格式,这些应用程序协议就构成了”应用层”。

1.2 IP地址


地址的划分是把第一个字节划分为若干等分。
IP地址根据网络ID的不同分为5种类型,A类地址、B类地址、C类地址、D类地址和E类地址

A类地址:10.0.0.0~126.0.0.0
0111 1111 1111 1111 1111 1111 1111 1111 10.0.0.0
1111 1111 1111 1111 1111 1111 1111 1111 126.0.0.0
网络数 = 126 - 0 = 126个 每个网络容纳 255 X 255 X 255 = 16581375

B类地址:128.0.0.0~191.255.255.255
1111 1111 1111 1111 1111 1111 1111 1111 128.0.0.0
1111 1111 1111 1111 1111 1111 1111 1111 191.255.255.255
网络数 = (191-128)X 255 = 16065个 每个网络容纳 255X255 = 65025
可用的B类网络有16382个,每个网络能容纳6万多个主机

C类地址: 192.0.0.0~ 223.255.255.255
1111 1111 1111 1111 1111 1111 1111 1111 192.0.0.0
1111 1111 1111 1111 1111 1111 1111 1111 223.255.255.255
网络数 = (223-192)X 255 X255 = 2015775个 每个网络容纳 255个

D类地址
⑴ D类地址不分网络地址和主机地址,它的第1个字节的前四位固定为1110。
⑵ D类地址范围:224.0.0.1—239.255.255.254

E类地址
⑴ E类地址也不分网络地址和主机地址,它的第1个字节的前五位固定为11110。
⑵ E类地址范围:240.0.0.1—255.255.255.254

1.3 TCP/IP 协议

HTTP 超文本传输协议(英文: HyperText Transfer Protocol,缩写: HTTP)是一种用于分布式、协作式
和超媒体信息系统的应用层协议。 HTTP 是万维网数据通信的基础。 HTTP 的应用最为广泛,譬如大家经常
会打开网页浏览器查询资料,通过浏览器便可开启 HTTP 通信。
HTTP 协议工作于客户端(用户)、服务器端(网站)模式下,浏览器作为 HTTP 客户端通过 URL 向
HTTP 服务端即 WEB 服务器发送请求。 Web 服务器根据接收到的请求后,向客户端发送响应信息。借助这
种浏览器和服务器之间的 HTTP 通信,我们能够足不出户地获取网络中的各种信息。

1.4 TCP 协议

TCP(Transmission Control Protocol,传输控制协议)是一种面向连接的、可靠的、基于 IP 的传输协议。

①、 TCP 协议工作在传输层,对上服务 socket 接口,对下调用 IP 层;
②、 TCP 是一种面向连接的传输协议,通信之前必须通过三次握手与客户端建立连接关系后才可通信;
③、 TCP 协议提供可靠传输,不怕丢包、乱序。
TCP 协议如何保证可靠传输?
①、 TCP 协议采用发送应答机制,即发送端发送的每个 TCP 报文段都必须得到接收方的应答,才能认
为这个 TCP 报文段传输成功。
②、 TCP 协议采用超时重传机制,发送端在发送出一个 TCP 报文段之后启动定时器,如果在定时时间
内未收到应答,它将重新发送该报文段。
③、由于 TCP 报文段最终是以 IP 数据报发送的,而 IP 数据报到达接收端可能乱序、重复、所以 TCP
协议还会将接收到的 TCP 报文段重排、整理、再交付给应用层。

1.5 FTP 协议

FTP 协议的英文全称为 File Transfer Protocol,简称为 FTP,它是一种文件传输协议,从一个主机向一
个主机传输文件的协议。
FTP 协议同样也是基于客户端-服务器模式,在客户端和服务器之间进行文件传输,
譬如我们通常会使用 FTP 协议在两台主机之间进行文件传输,譬如一台 Ubuntu 系统主机和一台 Windows
系统主机,将一台主机作为 FTP 服务器、另一台主机作为 FTP 客户端,建立 FTP 连接之后,客户端可以从
服务器下载文件,同样也可以将文件上传至服务器。
FTP 除了基本的文件上传/下载功能外,还有目录操作、权限设置、身份验证等机制,许多网盘的文件
传输功能都是基于 FTP 实现的

TCP 协议如何保证可靠传输?
①、 TCP 协议采用发送应答机制,即发送端发送的每个 TCP 报文段都必须得到接收方的应答,才能认
为这个 TCP 报文段传输成功。
②、 TCP 协议采用超时重传机制,发送端在发送出一个 TCP 报文段之后启动定时器,如果在定时时间
内未收到应答,它将重新发送该报文段。
③、由于 TCP 报文段最终是以 IP 数据报发送的,而 IP 数据报到达接收端可能乱序、重复、所以 TCP
协议还会将接收到的 TCP 报文段重排、整理、再交付给应用层。

1.6 端口号

端口号本质上就是一个数字编号,用来在一台主机中唯一标识一个能上网(能够进行网络通信) 的进
程,端口号的取值范围为 0~65535。
通过“IP 地址+端口号”来区分主机不同的进程。

1.6 socket

我们知道两个进程如果需要进行通讯最基本的一个前提能能够唯一的标示一个进程,在本地进程通讯中我们可以使用PID来唯一标示一个进程,但PID只在本地唯一,网络中的两个进程PID冲突几率很大,这时候我们需要另辟它径了,我们知道IP层的ip地址可以唯一标示主机,而TCP层协议和端口号可以唯一标示主机的一个进程,这样我们可以利用ip地址+协议+端口号唯一标示网络中的一个进程。
能够唯一标示网络中的进程后,它们就可以利用socket进行通信了,什么是socket呢?我们经常把socket翻译为套接字,socket是在应用层和传输层之间的一个抽象层,它把TCP/IP层复杂的操作抽象为几个简单的接口供应用层调用已实现进程在网络中通信。

socket起源于UNIX,在Unix一切皆文件哲学的思想下,socket是一种"打开—读/写—关闭"模式的实现,服务器和客户端各自维护一个"文件",在建立连接打开后,可以向自己文件写入内容供对方读取或者读取对方内容,通讯结束时关闭文件。

2

3

4

5

【网络通信】

网络通信

  • 1 网络通信
    • 1.1 OSI 七层模型
    • 1.2 IP地址
    • 1.3 TCP/IP 协议
    • 1.4 TCP 协议
    • 1.5 FTP 协议
    • 1.6 端口号
    • 1.6 socket
  • 2
  • 3
  • 4
  • 5

1 网络通信

网络通信本质上是一种进程间通信,是位于网络中不同主机上的进程之间的通信,属于 IPC 的一种,
通常称为 socket IPC,

1.1 OSI 七层模型



物理层功能: 主要是基于电器特性发送高低电压(电信号),高电压对应数字1,低电压对应数字0
数据链路层由来: 单纯的电信号0和1没有任何意义,必须规定电信号多少位一组,每组什么意思
数据链路层的功能:定义了电信号的分组方式

网络层由来: 有了ethernet、mac地址、广播的发送方式,世界上的计算机就可以彼此通信了,问题是世界范围的互联网是由一个个彼此隔离的小的局域网组成的,那么如果所有的通信都采用以太网的广播方式,那么一台机器发送的包全世界都会收到,这就不仅仅是效率低的问题了,这会是一种灾难.

传输层的由来:网络层的ip帮我们区分子网,以太网层的mac帮我们找到主机,然后大家使用的都是应用程序,你的电脑上可能同时开启qq,暴风影音,等多个应用程序,那么我们通过ip和mac找到了一台特定的主机,如何标识这台主机上的应用程序,答案就是端口,端口即应用程序与网卡关联的编号。传输层功能:建立端口到端口的通信
补充:端口范围0-65535,0-1023为系统占用端口
tcp协议:
可靠传输,TCP数据包没有长度限制,理论上可以无限长,但是为了保证网络的效率,通常TCP数据包的长度不会超过IP数据包的长度,以确保单个TCP数据包不必再分割。


应用层由来:用户使用的都是应用程序,均工作于应用层,互联网是开发的,大家都可以开发自己的应用程序,数据多种多样,必须规定好数据的组织形式
应用层功能:规定应用程序的数据格式。
例:TCP协议可以为各种各样的程序传递数据,比如Email、WWW、FTP等等。那么,必须有不同协议规定电子邮件、网页、FTP数据的格式,这些应用程序协议就构成了”应用层”。

1.2 IP地址


地址的划分是把第一个字节划分为若干等分。
IP地址根据网络ID的不同分为5种类型,A类地址、B类地址、C类地址、D类地址和E类地址

A类地址:10.0.0.0~126.0.0.0
0111 1111 1111 1111 1111 1111 1111 1111 10.0.0.0
1111 1111 1111 1111 1111 1111 1111 1111 126.0.0.0
网络数 = 126 - 0 = 126个 每个网络容纳 255 X 255 X 255 = 16581375

B类地址:128.0.0.0~191.255.255.255
1111 1111 1111 1111 1111 1111 1111 1111 128.0.0.0
1111 1111 1111 1111 1111 1111 1111 1111 191.255.255.255
网络数 = (191-128)X 255 = 16065个 每个网络容纳 255X255 = 65025
可用的B类网络有16382个,每个网络能容纳6万多个主机

C类地址: 192.0.0.0~ 223.255.255.255
1111 1111 1111 1111 1111 1111 1111 1111 192.0.0.0
1111 1111 1111 1111 1111 1111 1111 1111 223.255.255.255
网络数 = (223-192)X 255 X255 = 2015775个 每个网络容纳 255个

D类地址
⑴ D类地址不分网络地址和主机地址,它的第1个字节的前四位固定为1110。
⑵ D类地址范围:224.0.0.1—239.255.255.254

E类地址
⑴ E类地址也不分网络地址和主机地址,它的第1个字节的前五位固定为11110。
⑵ E类地址范围:240.0.0.1—255.255.255.254

1.3 TCP/IP 协议

HTTP 超文本传输协议(英文: HyperText Transfer Protocol,缩写: HTTP)是一种用于分布式、协作式
和超媒体信息系统的应用层协议。 HTTP 是万维网数据通信的基础。 HTTP 的应用最为广泛,譬如大家经常
会打开网页浏览器查询资料,通过浏览器便可开启 HTTP 通信。
HTTP 协议工作于客户端(用户)、服务器端(网站)模式下,浏览器作为 HTTP 客户端通过 URL 向
HTTP 服务端即 WEB 服务器发送请求。 Web 服务器根据接收到的请求后,向客户端发送响应信息。借助这
种浏览器和服务器之间的 HTTP 通信,我们能够足不出户地获取网络中的各种信息。

1.4 TCP 协议

TCP(Transmission Control Protocol,传输控制协议)是一种面向连接的、可靠的、基于 IP 的传输协议。

①、 TCP 协议工作在传输层,对上服务 socket 接口,对下调用 IP 层;
②、 TCP 是一种面向连接的传输协议,通信之前必须通过三次握手与客户端建立连接关系后才可通信;
③、 TCP 协议提供可靠传输,不怕丢包、乱序。
TCP 协议如何保证可靠传输?
①、 TCP 协议采用发送应答机制,即发送端发送的每个 TCP 报文段都必须得到接收方的应答,才能认
为这个 TCP 报文段传输成功。
②、 TCP 协议采用超时重传机制,发送端在发送出一个 TCP 报文段之后启动定时器,如果在定时时间
内未收到应答,它将重新发送该报文段。
③、由于 TCP 报文段最终是以 IP 数据报发送的,而 IP 数据报到达接收端可能乱序、重复、所以 TCP
协议还会将接收到的 TCP 报文段重排、整理、再交付给应用层。

1.5 FTP 协议

FTP 协议的英文全称为 File Transfer Protocol,简称为 FTP,它是一种文件传输协议,从一个主机向一
个主机传输文件的协议。
FTP 协议同样也是基于客户端-服务器模式,在客户端和服务器之间进行文件传输,
譬如我们通常会使用 FTP 协议在两台主机之间进行文件传输,譬如一台 Ubuntu 系统主机和一台 Windows
系统主机,将一台主机作为 FTP 服务器、另一台主机作为 FTP 客户端,建立 FTP 连接之后,客户端可以从
服务器下载文件,同样也可以将文件上传至服务器。
FTP 除了基本的文件上传/下载功能外,还有目录操作、权限设置、身份验证等机制,许多网盘的文件
传输功能都是基于 FTP 实现的

TCP 协议如何保证可靠传输?
①、 TCP 协议采用发送应答机制,即发送端发送的每个 TCP 报文段都必须得到接收方的应答,才能认
为这个 TCP 报文段传输成功。
②、 TCP 协议采用超时重传机制,发送端在发送出一个 TCP 报文段之后启动定时器,如果在定时时间
内未收到应答,它将重新发送该报文段。
③、由于 TCP 报文段最终是以 IP 数据报发送的,而 IP 数据报到达接收端可能乱序、重复、所以 TCP
协议还会将接收到的 TCP 报文段重排、整理、再交付给应用层。

1.6 端口号

端口号本质上就是一个数字编号,用来在一台主机中唯一标识一个能上网(能够进行网络通信) 的进
程,端口号的取值范围为 0~65535。
通过“IP 地址+端口号”来区分主机不同的进程。

1.6 socket

我们知道两个进程如果需要进行通讯最基本的一个前提能能够唯一的标示一个进程,在本地进程通讯中我们可以使用PID来唯一标示一个进程,但PID只在本地唯一,网络中的两个进程PID冲突几率很大,这时候我们需要另辟它径了,我们知道IP层的ip地址可以唯一标示主机,而TCP层协议和端口号可以唯一标示主机的一个进程,这样我们可以利用ip地址+协议+端口号唯一标示网络中的一个进程。
能够唯一标示网络中的进程后,它们就可以利用socket进行通信了,什么是socket呢?我们经常把socket翻译为套接字,socket是在应用层和传输层之间的一个抽象层,它把TCP/IP层复杂的操作抽象为几个简单的接口供应用层调用已实现进程在网络中通信。

socket起源于UNIX,在Unix一切皆文件哲学的思想下,socket是一种"打开—读/写—关闭"模式的实现,服务器和客户端各自维护一个"文件",在建立连接打开后,可以向自己文件写入内容供对方读取或者读取对方内容,通讯结束时关闭文件。

2

3

4

5

发布评论

评论列表 (0)

  1. 暂无评论