(四)应用层

注:文章非原创,来自极客时间 《趣谈网络协议》个人笔记

4.1 HTTP协议

URL叫做统一资源定位符,浏览器会将域名发送给DNS服务器,让它解析为IP地址,然后建立TCP连接,目前使用的TCP协议大部分是1.1,其中默认开启Keep-Alive,这样建立的连接可以在多次请求中复用,其中HTTP的请求格式如下


http协议格式.png

主要分为三部分,请求行、首部、实体。

请求行的方法主要有get post put delete ,get意思就是向服务器请求资源,post为向服务器传递资源,put为向指定的资源上传最新的内容。delete是删除资源的

首部字段是key value通过冒号分割,其中Accept-Charset表示客户端可以接受的字符集,Content-Type是指正文的格式,进行post请求的时候,正文是JSON,那么这个也应该为json。对于一些静态资源,Nginx有Vanish缓存层,缓存过期才会访问Tomcat集群,架构如下:


常见部署形式.png

在HTTP头部中,Cache-control用来控制缓存,其中如果包含max-age则会判断资源的缓存时间是否比指定时间的数值小,当max-age等于0,则请求转发给tomcat集群。if-Modified-Since也是一个关于缓存的

HTTP请求的发送,因为是基于TCP协议的,面向连接,通过stream二进制流方式传给对方,到TCP层变成报文段。

HTTP的返回报文合适如下,也是基于HTTP1.1的


http返回报文.png

其中状态码反映HTTP请求的结果,200 404服务端无法响应等,首部的key value 中 Retry-After表示告诉客户端多长时间以后再次尝试,503错误是服务展示不再和这个值配合,返回头中也包含Content-Type,表示返回的是HTML还是JSON

HTTP1.1在应用层是纯文本的形式进行通信,每次通信都要带上完整的HTTP头,在实时性、并发性上面都存在问题,HTTP2.0会对HTTP的头进行一定的压缩,将key value在两端建立索引表,对应头值发送索引。其中1.1和2.0的主要区别可以如下表示
通信形式.png

4.2 HTTP协议的安全性问题

其中在传输过程中为了避免网络报被截获破解,可以对包中的数据进行加密,加密可以分为对称加密和非对称加密,其中对称加密的加密和解密用的同一个密匙,非对称加密则是不同的,但是对称加密效率要高性能好,所以常用。

在一些支付方面安全性高的情况下可以使用非对称加密,客户端和服务端各维护一对公匙和私匙。

但是如何将公匙传递给对方?一种是放在公网上另一种是建立连接的时候传递给对方,这时候可以发布证书,证书里有公匙,有证书的所有者,还有证书的发布机构和证书的有效期,发布证书的机构成为CA。可以使用以下命令生成证书

openssl req -key cliu8siteprivate.key -new -out cliu8sitecertificate.req

签名机构会给证书卡个章叫做签名算法,其中CA的公匙需要上一层的CA给他签名。基于这些就是HTTPS

HTTPS的基本流程
https的基本流程.png

4.3流媒体协议

其中视频是一组快速播放的图片,每个图片由像素组成,但是如果每个像素都单独存储信息,那么会比较大,可以使用编码来解决,编码就是一个压缩的过程。

视频编码主要有ITU和ISO,在直播的视线中,网络协议将编码好的视频流,从主播端推送到服务器,称为接流,服务端接到视频流之后进行转码从一种编码格式转换成另一种,流处理完毕后等待观众客户端拉流,整个过程如下


流媒体协议.png

那么如何将图片变成二进制流呢?视频分为三种帧,I帧,P帧和B帧,IBBP间隔出现,通过时序进行编码。编码后的二进制流称为网络提取层单元,为了网络上的传输。

推流使用RTMP协议,基于TCP协议。发送数据称为RTMP Packet包,Message的格式如下
message格式.png

其主要流程如下
主要流程.png

其中直播一般都有分发网络,分为中心和边缘层,类似CDN
CDN结构.png

其中客户端通过RTMP拉流的过程如下
RTMP拉流.png

4.3 P2P协议

下载文件可以通过HTTP进行下载,也可以通过FTP 文件传输协议方式进行下载,FTP采用两个TCP连接来传输文件,

FTP的工作模式有主动模式PORT和被动模式PASV。

主动模式下客户端随机打开一个大于 1024 的端口 N,向服务器的命令端口 21 发起连接,同时开放 N+1 端口监听,并向服务器发出 “port N+1” 命令,由服务器从自己的数据端口 20,主动连接到客户端指定的数据端口 N+1。

被动模式下,当开启一个 FTP 连接时,客户端打开两个任意的本地端口 N(大于 1024)和 N+1。第一个端口连接服务器的 21 端口,提交 PASV 命令。然后,服务器会开启一个任意的端口 P(大于 1024),返回“227 entering passive mode”消息,里面有 FTP 服务器开放的用来进行数据传输的端口。客户端收到消息取得端口号之后,会通过 N+1 号端口连接服务器的端口 P,然后在两个端口之间进行数据传输。

以上两种下载方式都会消耗服务器的资源,P2P方式则是资源分散到多台设备上,在这些设备上建立点对点连接。这种方式参与下载的人越多,下载速度越快。

种子.torent文件分为令部分,announce和文件信息,文件信息里有info区,Name字段,每个段的大小,段哈希值等,但是仍然不能避免中心化。

DHT去中心化网络,每个加入这个 DHT 网络的人,都要负责存储这个网络里的资源信息和其他成员的联系信息。

[图片上传失败...(image-2c3d5d-1605665981694)]
p2p技术.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,711评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,079评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,194评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,089评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,197评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,306评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,338评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,119评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,541评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,846评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,014评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,694评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,322评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,026评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,257评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,863评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,895评论 2 351

推荐阅读更多精彩内容

  • 应用层 dns\dhcp\ftp\telnet\ssh\http\smtphttp = TCP+80https =...
    机智的柠檬阅读 510评论 0 0
  • 2.1应用层协议原理 2.1.1网络应用的体系结构 客户机/服务器结构 ■服务器 §7*24小时提供服务 § 永久...
    龟龟51阅读 547评论 0 0
  • client-server architecture 服务器:提供计算服务的设备1.1. 永久提供服务1.2. 永...
    幺姨母阅读 247评论 0 0
  • 文件传输:FTP、TFTP邮件服务:SMTP、POP3、IMAP网络管理:SNMP远程登录:Telnet、SSH网...
    狐小灵阅读 2,074评论 2 0
  • 黑色的海岛上悬着一轮又大又圆的明月,毫不嫌弃地把温柔的月色照在这寸草不生的小岛上。一个少年白衣白发,悠闲自如地倚坐...
    小水Vivian阅读 3,105评论 1 5