初识网络 --- 浅了解一些基础概念

本文涉及的产品
数据传输服务 DTS,数据迁移 small 3个月
推荐场景:
MySQL数据库上云
数据传输服务 DTS,数据同步 1个月
简介: 初识网络 --- 浅了解一些基础概念

初识网络

在每台计算机独立的情况下:假设现在有三台计算机,每台计算机各持有一个业务。那么现在有个程序员处理业务时,如果想要处理业务1就要操作计算机1,处理业务2就要操作计算机2,这样的效率明显不高

那么如果能将三台计算机都连接到一台服务器中,那么三台计算机就可以通过将业务发送到服务器,服务器再发送到指定的计算机中,就可以实现只操作一台计算机就可以处理三个业务。这就是网络互联的基本原理

局域网与广域网

那么假如现在有不同地方的多台计算机想要互联怎么办呢。同样的网络连接原理,将同个地方的多台计算机的数据上传到一台可以称为“交换机”的机器,交换机在将数据发送到中间的一系列实现网络连接的机器上,再发送到另一个地方的交换机最后传入另一个地方的多台计算机中。像这样的在一个区域内可以通过中间的桥梁实现互联的就可以称为局域网

909b765c8c4630a18c9def42e3422576.png事实上中间的这块桥梁在现实中就是各运营商为用户实现的,这是一个非常庞大的工程量。

相对于局域网和广域网而言,这两个只是一个相对的概念,并不能具体化。一个家庭;一个学校;一个国家都可以被看作是一个局域网


初识协议

本篇文章首先对协议有一个初步的认识

协议就是一种‘约定’,而协议存在的本质:是为了减少通信成本。为什么这么说呢?

举个例子:现在有两个人在近距离的进行交流,一个人向另一个人提问一个是否问题,这个人可以根据另一个人回答的语言进行判断。但如果这两个人相距了1公里双方都可以看到对方肢体动作进行交流的情况下,因为距离较远所以想要让对方听到所讲的话就得需要很大声,这样双方的通信成本就提高了。所以这种情况下,双方就可以通过提前约定好另一种的回答方式,例如点头表示肯定,摇头表示否定。这样子通过对方的肢体动作就可以判断出答案。

像上述的例子就是在两人约定好某种规则后,可以在一定程度上减少了通信的成本。

对于网络而言亦是如此,现实生活上网络是可以在很大的范围内进行通信的,所以距离肯定也会有较长的情况,因此通信的问题和成本就会随着距离的变长而提高。因此网络问题的本质就是传输的距离变长了

同时在计算机之间会存在着多种的计算机产商,多种的操作系统,多种的网络设备型号。因此为了实现这些有不同的操作系统不同的产商组成的计算机之间的通信,所有的产商或者操作系统之间就必须要指定一个协议,然后大家共同遵守这个协议,这就是网络协议

协议分层

假如现在有两个人在打电话,那么为了防止两个人各说一门语言导致通信出现障碍,那么两人就约定好都说普通话,这就是语言层面的协议。然后两个可能用的是不同品牌的电话,为了这部电话能够接收到对方传来了语音,所以电话之间也需要制定好协议。那么像这种打电话之间就会出现两层的协议,这就是协议分层

对于网络而言肯定不止就两层协议这么少,网络通信是一个更加复杂的过程,因此会有很多层的协议。

分层的特点:

  1. 把软件进行模块化,可以很好的进行解耦,解耦以后如果把通信设备进行更换,上层不用改变,而如果上层语言改变,底层不需要改变。所以对任何一层做任何修改并不影响其他层
  2. 功能比较集中,耦合度比较高的模块放在一层,也就是高内聚,每一层解决特定的问题,功能解耦

OSI七层模型


分层名称
功能 功能概览
7 应用层 针对特定应用的协议 针对每个应用的协议
6 表示层 设备固有数据格式和网络标准数据格式的转换 接受不同表现的信息
5 会话层 通信管理,负责建立和断开网络连接 何时建立、断开连接,保持多久连接
4 传输层 管理两个节点之间的数据传输,负责可靠传输 是否有数据丢失
3 网络层 地址管理和路由选择 经过那个路由器传递到目的地址
2 数据链路层 互联设备之间传送和识别数据帧 数据帧和比特流之间的转换
1 物理层 以0 1 代表电压的高低,界定连接器和网线的规格 比特流和电子信号之间的转换

TCP/IP 四层(五层)模型

TCP/IP是一组协议的代名词,它还包括许多协议,组成了TCP/IP协议簇.

TCP/IP通讯协议采用了5层的层级结构,每一层都呼叫它的下一层所提供的网络来完成自己的需求

物理层 负责光/电信号的传递方式,物理层的能力决定了最大传输速率、传输距离、抗干扰性等. 集线器(Hub)工作在物理层
数据链路层 负责设备之间的数据帧的传送和识别. 例如网卡设备的驱动、帧同步、数据差错校验等工作
网络层 负责地址管理和路由选择. 例如在IP协议中, 通过IP地址来标识一台主机, 并通过路由表的方式规划出两台主机之间的数据传输的线路(路由)
传输层 负责两台主机之间的数据传输. 如传输控制协议 (TCP), 能够确保数据可靠的从源主机发送到目标主机
应用层 负责应用程序间沟通,如简单电子邮件传输(SMTP)、文件传输协议(FTP)、网络远程访问协议(Telnet)等。网络编程主要就是针对应用层

因为物理层考虑较少,所以通常会叫作TCP/IP四层模型

网络传输基本流程

数据传输条件:

数据包交付能力:如果两台很远的主机之间要传递数据,首先要先有把数据交付给另一台主机的能力

路径选择的能力:要明确数据传输到哪台主机。

容错纠错的能力:如果出错了就要重新传递一份。

数据解析能力:数据传递过去主机要识别这是什么,然后才能使用这个数据。

而这里的每一层都有自己的协议,每一层协议都解决当前层的问题。

协议报头

协议每一层都有,而每个协议都要有报头

报头:

例如快递,除了买的商品还有快递单,这个快递单就是快递的报头。快递小哥通过快递单找到买家,快递单就是快递公司自己定的协议

因此传输数据时总会有多一点的数据,多出来的就叫报头

协议通常是通过协议报头来表达的。每一份数据最终在被发送或者在不同的协议层中,都要有自己的报头

局域网通信原理

同一个局域网里的不同主机是可以直接连接的

每一台主机都有网卡,每一张网卡都有自己的地址,叫做MAC地址用来标识网卡的唯一性MAC地址虽然全球唯一,但是不应用于全球,只是在局域网中标识自己的唯一性云服务器的MAC地址是个虚拟地址

在操作系统中输入指令— ifconfig 就可以看到MAC地址

一个局域网中会有很多的主机,如果主机1想要跟主机2发送消息的时候其他所有主机也都能收到,但是其他主机在内部做协议判断后发现并不是发给自己的就会自动丢弃。最终只有主机2收到

以太网发送消息的原则是任意一个时刻只允许一个主机在局域网中发消息。否则就会发生碰撞,类似于系统中的临界资源

令牌环网:谁持有令牌环谁发送数据没有令牌的主机就不能发送消息,类似于系统中的锁

传输流程图

两台计算机之间通过TCP/IP协议通讯的过程:


edffdb8ea1e4930511d8206dffb1279c.png

跨网段的主句进行传输需要通过一个或者多个路由器:


9de7ebd010b7b34c68c807415a7255fa.png

数据包封装和分用

不同的协议层对数据包有不同的称谓,在传输层叫做段(segment),在网络层叫做数据报 (datagram),在链路层叫做帧(frame)。

应用层数据通过协议栈发到网络上时,每层协议都要加上一个数据首部(header),称为封装

数据包封装:

  1. 向下交付的时候每一层都会添加自己的报头,报文=报头+有效载,再把报文向下交付
  2. 向上解包的时候,因为同一层有相同的协议,所以能识别报头,它会解开报头,把有效载荷在向上解包。这样就形成了对称的结构

一个设备至少要横跨两个网络才能实现数据报跨网络转发,路由器也必须至少横跨两个网络,所以路由器必须有两个网络接口。在路由器部分传递给令牌环驱动程序的时候,加上的报头是令牌环协议(重新封装报头),虽然这样跟左边不一样了,但是并不影响对称性

相关实践学习
RocketMQ一站式入门使用
从源码编译、部署broker、部署namesrv,使用java客户端首发消息等一站式入门RocketMQ。
Sqoop 企业级大数据迁移方案实战
Sqoop是一个用于在Hadoop和关系数据库服务器之间传输数据的工具。它用于从关系数据库(如MySQL,Oracle)导入数据到Hadoop HDFS,并从Hadoop文件系统导出到关系数据库。 本课程主要讲解了Sqoop的设计思想及原理、部署安装及配置、详细具体的使用方法技巧与实操案例、企业级任务管理等。结合日常工作实践,培养解决实际问题的能力。本课程由黑马程序员提供。
目录
相关文章
|
10小时前
|
机器学习/深度学习 计算机视觉
卷积神经网络中池化层的概念介绍
卷积神经网络中池化层的概念介绍
27 0
|
11小时前
|
机器学习/深度学习
卷积神经网络的全连接层的概念
卷积神经网络的全连接层的概念
28 0
|
10小时前
|
存储 分布式计算 监控
Hadoop【基础知识 01+02】【分布式文件系统HDFS设计原理+特点+存储原理】(部分图片来源于网络)【分布式计算框架MapReduce核心概念+编程模型+combiner&partitioner+词频统计案例解析与进阶+作业的生命周期】(图片来源于网络)
【4月更文挑战第3天】【分布式文件系统HDFS设计原理+特点+存储原理】(部分图片来源于网络)【分布式计算框架MapReduce核心概念+编程模型+combiner&partitioner+词频统计案例解析与进阶+作业的生命周期】(图片来源于网络)
77 2
|
10小时前
|
存储 算法 网络协议
【探索Linux】P.26(网络编程套接字基本概念—— socket编程接口 | socket编程接口相关函数详细介绍 )
【探索Linux】P.26(网络编程套接字基本概念—— socket编程接口 | socket编程接口相关函数详细介绍 )
13 0
|
10小时前
|
存储 网络协议 Unix
【探索Linux】P.25(网络编程套接字基本概念 —— 预备知识)
【探索Linux】P.25(网络编程套接字基本概念 —— 预备知识)
8 0
|
10小时前
|
运维 网络协议 安全
第一节-网络的基本概念
第一节-网络的基本概念
13 0
|
10小时前
|
机器学习/深度学习 人工智能 编解码
【AI 生成式】生成对抗网络 (GAN) 的概念
【5月更文挑战第4天】【AI 生成式】生成对抗网络 (GAN) 的概念
【AI 生成式】生成对抗网络 (GAN) 的概念
|
10小时前
|
机器学习/深度学习 人工智能 自然语言处理
【AI 初识】递归神经网络 (RNN) 概念
【5月更文挑战第2天】【AI 初识】递归神经网络 (RNN) 概念
|
10小时前
|
数据中心
【专栏】交换机的电口和光口,包括它们的概念、特点、应用场景及区别。做网络的这个常识得懂!
【4月更文挑战第28天】本文详细探讨了交换机的电口和光口,包括它们的概念、特点、应用场景及区别。电口采用RJ45接口,适合短距离、低成本的局域网连接,而光口利用光纤进行高速、长距离传输,适用于大型数据中心和广域网。电口与光口的主要区别在于传输介质、距离、带宽、成本、抗干扰能力和安装维护难度。选择时需根据传输距离、带宽需求、成本及网络环境来决定。了解这些知识能帮助我们更好地设计和管理网络系统。