14 | HTTP有哪些优点?又有哪些缺点?
14 | HTTP有哪些优点?又有哪些缺点?
讲述:Chrono
时长10:59大小12.57M
简单、灵活、易于扩展
应用广泛、环境成熟
无状态
明文
不安全
性能
小结
课下作业
赞 29
提建议
精选留言(29)
- Xiao2019-06-28老师说的对,以前的时候觉得看书或者文章,人家说什么就是什么,而且很绝对。后来慢慢发现,很多东西都是需要结合业务场景来分析的,在这种业务场景是优点,在另外的业务场景就可能是致命的缺点!那句话:脱离业务场景谈技术就是耍流氓!哈哈哈,谢谢老师!
作者回复: 自己思考就有收获,尽信书则不如无书。
43 - 钱2020-03-291:你最喜欢的 HTTP 优点是哪个?最不喜欢的缺点又是哪个?为什么? 最喜欢她的简单,因为简单所以美好,简简单单容易上手,易于理解。 最不喜欢她的不安全和低性能,如果她能做到安全高效,那就不用再去学习别的乱七八糟的协议了,编写RPC接口也就没有其他框架什么事情了,搞微服务应该门槛更低效率更高,当然,她目前做不到,由于考上层以后估计也悬,不过如果基建OK,也许网络带宽不再是瓶颈,她能做到天然的高效传输吧! 2:你能够再进一步扩展或补充论述今天提到这些优点或缺点吗? 简单和易扩展,我认为是矛盾的,很少系统能做到即易扩展又简单,毕竟以后需要什么谁也不能未卜先知,留下扩展的余地毕竟会增加复杂度吧!如果设计的不好,复杂度也许会急剧上升,不过HTTP做的很好貌似没有出现这种情况。不知是为什么?是公共的预定义基本OK吗?其实扩展的不是很多吗?还请老师分享一下。 3:你能试着针对这些缺点提出一些自己的解决方案吗? 有无状态已有方案,可以自由选择 安全性后面也会采用加密的方式来解决 低效这个是相对的,靠上必然会低效,如果基建进一步加强,也许能进一步解决,不过这个看需求和增加的带宽那个更大吧! 明文最早的初心就是分享信息,明文我觉得太正常了,现在多了安全性的需求,所以,才渴望更安全的,此时的HTTP用于分享信息已是一部分功能,她还可以实现各种各样的诉求。 如果协议里设置的有类似开关的东西就好了,可以选择是否有状态、可以选择是否明文、可以选择是否加密,使用者仅需要控制开关就能实现相关的功能,不需自己实现,那就更好了。展开
作者回复: 还是这么认真写作业啊,笑。 1.http/2和http/3可以解决你说的问题。 2.我觉得http一开始的文本格式头结构算是误打误撞,正好即简单又容易扩展,有点像xml。 3.请看后面的http/2。
共 2 条评论13 - レイン小雨2019-06-29老师,我想问一下关于“队头阻塞”的概念,正好上周团队有人分享这方面的知识,当时是说浏览器针对一个域名最多同时建立6个连接通道,也就是支持6个http并发,当一个页面中有100个资源文件需要加载的时候,就只能6个6个的串行加载,第七个请求要等到第一个请求结果返回来之后才能发出。这么理解队头阻塞的概念对吗?
作者回复: 你说的这6个连接是为了解决队头阻塞而实现的并发连接。 而“第七个”实际上是排队等待,还不是队头阻塞。 马上就会讲到这个问题了,再等几天。
共 5 条评论11 - 业余草2019-06-28老师不仅技术好,文章写的也很好。比较喜欢看这种风格的文章,可以加个微信好友吗?我微信:xttblog
作者回复: 抱歉,个人微信用的比较少,可以在GitHub上交流。
共 3 条评论8 - Geek_d59aa72020-07-02老师,问个沙雕问题,什么叫明文传输,难道http里的信息不是转成二进制传输的吗,看网上的意思好像明文传输是直接传输字母和数字??不是二进制?
作者回复: 明文是相对于密文而言的,意思是可以直接看到内容,而密文是经过加密的,看到的是乱码。 可以参考后面的安全篇。
共 2 条评论8 - 欢乐的小马驹2020-03-11老师好,小贴士里面提到了:绝大多数的网站都封禁了80/8080以外的端口号,只允许HTTP进行穿透。 1、最初为什么要封禁其他端口只留80/8080呢? 2、穿透是什么意思?
作者回复: 1.因为80/8080只用于http协议传输网页,禁掉其他端口就降低了被嗅探、攻击的可能性,提高安全性。 2.穿透是个通俗的说法,就是通过80端口可以一路畅通,一直传到后端去处理,而不会在服务器被挡住。
4 - 小丽2019-07-13老师讲的非常透彻,有些话看似简单,却值得琢磨,希望老师多讲一点关于身份认证和安全的东西
作者回复: 下周就会进入安全篇了,详细讲解https、ssl/tls。
3 - -W.LI-2019-06-28老师好!传输的时候序列化方式属于HTTP范畴么?现在大多用的json形式可是cloud和dubbo在高并发情况下dubbo性能比cloud好。网上说是序列化方式不一样。也不晓得是不是
作者回复: http不管body的格式,所以可以自己选择序列化方式。 json的优点是易读易解析,但明文显然格式容易,开销大,所以要求高性能都用专门的二进制序列化。 我用c/c++比较多,对Java不太了解,不好评价,抱歉了。
共 3 条评论3 - Xiao2019-06-28不觉得明文是缺点,因为http本身就是一套标准规范,而且前面也说它是非常灵活的,所以个人觉得明文也是一种场景,用户也可以选择密文传输!
作者回复: 明文是把“双刃剑”,很多时候是优点,但换个场景就是缺点了。 什么事情都是这样,没有绝对,就看应用的场景。
3 - 我的朋友叫垃圾呆2021-01-03老师,我查了资料之后还是不太理解 文本协议和二进制协议,我看之前的文章有说,从http2 开始,变成了二进制协议,这篇文章说 tcp是二进制协议,而http是文本协议,不太能理解两者的区别,在传输信息的时候不都是转换成二进制的字节流进行传输的吗
作者回复: 这种说法主要是以协议是否human readable为判断标准的,就是说传输的数据是否让人直接不借助工具就能够阅读。 对比一下,http协议的状态行、头字段都用的是ASCII码,可以直接看,而tcp的头用的是二进制位,不能直接看。
共 2 条评论3 - 凉人。2020-03-17大概最喜欢应用广泛的特点。这点太适用了。
作者回复: 这也是我最喜欢的特点。
2 - LIKE2021-03-29HTTP. 身份认证,可以通过加入通信双方约定的密钥做摘要算法,完成身份认证。
作者回复: 这个就是要用HTTPS了。
1 - BoyiKia2020-04-29老师,我想问下。你刚刚说的明文传输具体指headr,但是 body也是明文吗?
作者回复: 是的,没有加密,必然是明文。 当然,你可以自己把body加密,但这是在http协议之外的事情了。
2 - 彩色的沙漠2019-06-28虽然使用了HTTPS金融领域还是需要对数据加密和完整性检验,加密对body数据好加密对于header部分不好加密,需要对KV一个一个加密有点麻烦,不过在传输的时候一般把字段都用body传输,header里面不使用自定义字段。
作者回复: 用了https不就都全加密了吗? 你的办法也对,保密的部分放在body里,反正http格式很灵活,收到以后随便解释。
1 - cake2021-11-01“无状态”服务器是不知道这些请求是相互关联的,每次都得问一遍身份信息,不仅麻烦,而且还增加了不必要的数据传输量 老师请问下,"每次都得问一遍身份信息" 这个在没有cookie时是怎么实现的呢
作者回复: 其实和cookie的做法是类似的,也是用自定义头字段,只是cookie给标准化了。
1 - Leolee2021-04-21作业: 1、我最喜欢HTTP的应用广泛,学会了就可以受用很久;我不喜欢HTTP的不安全,因为不安全已经是致命的缺陷了,不然也不会出现HTTPS和HTTP2了; 2、PASS(python的pass,留待以后再写); 3、PASS(python的pass,留待以后再写)。 HTTP优点: 简单、灵活、易于扩展,应用广泛、软硬件环境成熟、无状态 HTTP缺点: 明文传输、不安全、性能不算差但也不够好 HTTP优缺点并存: 明文传输、无状态 简单、灵活、可扩展 HTTP协议很简单,报文格式就是header+body,头部信息也是简单的文本格式,用的也是常见的英文单词。学习使用的门槛很低。正是基于简单这个最基本的设计理念,才有了HTTP最锋利的剑:灵活可扩展!简单相当于一张白纸,你想怎么写都行。 HTTP里的请求方法、URI、状态码、原因短语、头字段等每一个核心组件都没有被写死,允许任意定制、扩充和解释,缺什么功能自己写就可以了。 HTTP不限制具体的下层协议,下层协议可以随意变化,上层的语义却可以始终保持稳定。 应用广泛、软硬件环境成熟 HTTP已经遍布互联网世界,很能找到一个没有使用HTTP的地方。无论应用领域还是开发领域都得到了广泛支持。HTTP天然具有跨语言、跨平台的特性,几乎所有编程语言都有HTTP调用库和外围的开发测试工具。 很多互联网和传统行业公司都购买服务器开办网站、建设数据中心、CDN和高速光纤,持续优化上网体验。 无状态 无状态令服务器不需要额外的资源来记录状态信息,负担轻一些。 无状态令服务器没有状态的差异,很容易组成集群,让负载均衡把请求转发到任意一台服务器,不会因为昨天不一致导致处理出错,直接买多几台服务器就可以轻松实现高并发高可用。 无状态的缺点就是没有记忆能力,也就无法支持需要连续多个步骤的事务操作,每一次都要问一次身份信息,不仅麻烦,也增加了不必要的数据传输量。但这个问题可以通过Cookies解决。 明文 是优点也是缺点; 明文的意思就是协议里的报文header部分,不使用二进制数据,而使用简单可阅读的文本形式。优点就是不需要借助任何外部工具,抓包后直接就可以查看或者修改,开发调试起来很便利。 缺点就是毫无隐私可言,只需要侵入了这个链路里的某个设备,简单地旁路一下浏览,就可以实现对通信的窥视。 不安全 HTTP没有提供有效的手段来确认通信双方的真实身份,虽然有基本的认证机制,但在明文传输面前几乎等同无效。 HTTP也不支持完整性校验,数据在传输过程中很容易被篡改而无法验证真伪。 正是因为这个缺陷,所以出现了HTTPS。 性能 不算差、不够好 因为请求-应答模式决定了按顺序发送的请求序列中有一个请求因为某种原因被阻塞时,后面一长串的请求也会被阻塞,会导致客户端迟迟收不到数据。 其他 出于安全原因,绝大多数网站都封禁了80/8080意外的端口号,只允许HTTP进行穿透,这也是导致HTTP流行的客观原因之一。80/8080是HTTP端口。展开
作者回复: great, keep goint.
- coral2021-04-061. 你最喜欢的 HTTP 优点是哪个?最不喜欢的缺点又是哪个?为什么? 最喜欢明文的传输,一目了然,上手几乎没有门槛,拿来就能用。最不喜欢的是明文可能会被截获带来安全性的问题。当然现在已经有了https(还没有搞清楚它是怎么加密的)很好奇为什么在一开始http设计的时候没有把这个考虑进去。是因为早期的互联网,比较着重在公开的信息,没有这么多隐私的需求吗? 2. 你能够再进一步扩展或补充论述今天提到这些优点或缺点吗? 通讯方式必须一来一回,且需要由客户端发起。服务器无法主动发送信息。这个特点减小了服务器的工作量,但增加了状态变化的监听、即时推送的难度。(但这个需求已经随着网络带宽的增加越来越普遍了) 3. 你能试着针对这些缺点提出一些自己的解决方案吗? 监听的问题,有没有办法增加一条监听通道,认证过身份的客户端就可以接收服务器推送,这个认证需要定时刷新确保客户端alive展开
作者回复: 1.正确,早期的互联网是田园时期,民风淳朴。 2.good。 3.这个就需要由http/2来解决了,不过你的思路很不错。
- 飞翔的葱油饼2021-04-06有个问题啊。老师在上节课中有提到HTTP有可靠传输的特点,这是由于HTTP基于TCP协议,而TCP提供了可靠传输,而这节中提到HTTP的灵活性,其下层使用的传输层协议是可以变的,甚至可以使用UDP,那这样的情况下,HTTP是否就不具有可靠传输性了呢?
作者回复: http不能直接用udp,而是在udp之上的quic,它的下层协议要求必须是可靠的传输。
共 3 条评论1 - Geek_Maggie2021-03-15自己看书总觉得像是学会了但是浮于表面。听了老师课程,结合实际去理解,感觉加深了不少印象
作者回复: 对,多动手做实验,实践出真知。
- 刘杰2021-03-111、我最喜欢HTTP简单、灵活易于扩展的优点,易于扩展就意味着有无限的可能。最不喜欢不安全的缺点,不安全意味着无法知道真实身份是我想要连接的,容易被有心人利用 2、HTTP的另外一个优点应用广泛,可以使我们轻易的将开发的应用部署在服务器上,让大家可以轻易访问 3、关于不安全的,可以使用HTTPS。关于明文问题,可以考虑客户端和服务端自定义一套自己能看懂的编码。展开
作者回复: 说的很好。 明文和不安全都可以用https来解决。