zoukankan      html  css  js  c++  java
  • 网络通讯协议

    什么是互联网

      网:由多个节点相互连接组成  eg:渔网、蜘蛛网

      计算机互联网:由多台计算机通过某种介质相互连接而组成

             互联网之所以存在就是为了能让信息共享

    网络编程

      网络编程:指的是编写基于网络的应用程序

      学习网络编程的目的:开发出一款可以利用网络来传输数据的应用程序

                最终目的是就是要编写一个基于C/S结构的应用程序

    cs结构

      建立网络至少需要两台计算机,然后使用网络来传输数据

      1、网络必须联通

      2、在访问数据的一方,必须安装用于访问数据的应用程序

          该应用程序称之为客户端应用程序(client)

         在需要提供数据的一方,必须安装用于共享数据的应用程序

          该应用程序称之为服务端应用程序(server)

           简写为C/S:

          例如:qq   就是一个客户端   服务器在腾讯公司

    还有一个B/S    Browser浏览器/Server

      该结构下传输的数据都是HTML文本数据

    通讯必备的两个条件

      1、物理传播介质(双绞线  光纤  无线电波)

      2、通讯协议(掌握的重点)

    通讯协议

      是由发送方和接收方共同商定的一套规范

    #1、制定协议的目的

         为了通讯双方能够正确解析数据

         例如 国内通讯:双方都用普通话

            国际通讯:双方都用英语

    #2、OSI七层模型的由来

        早些年,一些生产电脑的厂商的设备都不兼容(无法通信),每个公司都有着自己的一套规范,

        只能自己设备之间互相能够通信

        于是国际标准组织就提供了一套开放系统互联模型  OSI  作为世界的互联网的统一标准

    OSI七层模型

      OSI七层:应用层、表示层、会话层、传输层、网络层、数据链路层、物理层

      经过人们长时间的磨合,发现可以把前三层统一归类为应用层

      五层模型:应用层、传输层、网络层、数据链路层、物理层

    物理层

      通过物理介质建立物理连接,可以发送10101001 的二进制数据

      但是单纯的二进制数据无法理解,必须明确一次性收几个,每一段二进制是什么含义

    数据链路层

    以太网(Ethernet)协议工作在数据链路层

    #1、数据如何分组(数据的格式)

      每次发送一个数据帧  每个数据帧包含  head和data

      head:18byte  data:46-1500byte

    head data

      

    head又包含目的地址、源地址

    目标MAC 源MAC 其他 data

      

    数据帧的最大长度为1518,如果数据长度超过将被分片

    #2、MAC地址

      每一台计算机想要联网就必须要具备网卡

      每个网卡必然具备一个全球唯一的MAC地址

      MAC地址可以定位到任意一台计算机,但是如果提前不清楚目标的MAC地址,

      那就需要广播,来确定网口和MAC地址的对应关系

    有了链路层  理论上全世界的计算机就能连到同一个网络了,但是我们不可能将所有计算机设备连接到同一个交换机上

    #3、广播风暴

      当很多同一网络中的计算机同时发送广播,就会形成广播风暴,交换机承受不住高负荷,导致网络瘫痪

    网络层

      ip协议工作在网络层 Internet Protocol Address

      ip协议规定  每一个计算机设备要联网,必须分配一个ip地址

      ip地址是一个逻辑地址  不是固定的,在家和在学校获得的ip地址就不一样

    #1、ip地址的格式

      由4段3位的十进制组成(点分十进制)

      0.0.0.0  -  255.255.255.255

      每个局域网第一个ip是网络地址(主机位是0)  最后一个ip是广播地址(主机位是255)

    #2、网络位与主机位

      ip地址分为两个部分,网络位与主机位

      网络位:主要用来表示所处的局域网地址

      主机位:主要用来表示你这台电脑的具体位置

      区分网络位与主机位主要通过子网掩码

      子网掩码:和ip地址的形式一样,子网掩码位1对应的就是网络位,0对应的就是主机位

    #3、ARP地址解析协议(了解)

      会根据你发的目标ip地址去找到对应目标的MAC地址,从而确保你的数据封包到数据链路层可以正常进行

    总结:

      ip地址分为网络号和主机号,通过网络号可以定位到某一个局域网,再通过主机号定位到某一个计算机

      这样一来就可以通过ip定位到全球任意一台计算机

    源MAC 目标MAC 源IP 目标IP data

       数据包

          

        以太头部        ip头部

    传输层

      TCP/UDP工作在这一层

      传输层要求每一个应用程序捆绑一个端口号

      端口号是一个整数  取值范围 0-65535  0-1023端口是系统保留的,不建议使用,其他都可以用

      至此  可以通过ip+端口号定位全球某一台计算机上的某一个应用程序

    TCP协议(传输控制协议)

      可靠传输协议:就是在发送完数据之后,必须等待接收方返回回复消息,该数据才算发送成功

      如果对方在一段时间内没有返回,就会再次发送数据,超限制次数,就判定连接丢失(超时)

      基于链接的传输:

        要发送数据必须先建立链接,简单来说就是找一条可以到达对方的路,

        如何选择最佳路径由路由协议来控制

    #1、建立连接需要三次握手:

        由于TCP要实现双向通信,为了防止单向通信的情况,A必须要确认B和自己同步,B也要确认A和自己同步

      三次握手成功之后就表示链接建立成功了,只能表示这三次数据传输是可靠的,并不能保障后续的传输数据的可靠

      TCP协议要求在发送数据后,必须接收到对方的回复信息才能确认数据成功发送,如果一段时间内没有收到

      回复信息,会自动重新发送,如果重试的次数多,则表示链接可能已经中断了

    #2、断开链接需要四次挥手:

      1、客户端先发送断开链接请求

      2、服务端确认请求,这样客户端到服务端的链接就中断了

      3、当服务器发完最后的数据后,就向客户端发送断开链接请求

      4、客户端确认断开信息,这样双向链接就全部断开了

      四次挥手的目的主要是保证双方的数据传输已经全部完成,同样是为了保障数据的完整性

    #3、优点:

      保证传输可靠,数据完整

    #4、缺点:

      因为需要传输确认信息,所以对网络消耗较大,效率相对较低

    #5、应用场景:

      重要的数据,在线支付

    UDP协议(用户数据报协议)

      不可靠传输,UDP只管发送,不管对方是否收到

    优点:

      传输效率比TCP高

    缺点:

      传输不可靠

    应用场景:

      对速度要求高,对完整性要求低的,例如对战游戏、视频通话

    应用层

  • 相关阅读:
    今天碰到的angular 中的一个小坑
    mvc 防止客服端多次提交
    自定义通用Distinct去除重复数据的2中方式
    Sql 字符串操作类COALESCE
    SQL Server 性能优化
    Visual Studio Tip: Get Public Key Token for a Strong Named Assembly
    C#发送邮件
    Web打印组件jatoolsPrinter(转载)
    SQL SERVER 2005 同步复制技术(转)
    [Asp.net]常见word,excel,ppt,pdf在线预览方案(转)
  • 原文地址:https://www.cnblogs.com/hesujian/p/10931921.html
Copyright © 2011-2022 走看看