作者: 手插口袋_ 笔名:晓枫 [请尊重原创,盗版必究,转载请指明出处]
废话:本来打算开始写Docker系列的,但是时间上有些仓促,非专业的技术点理解起来比较费劲,所以至今也没总结出实际的东西,深感抱歉,有时间会不间断发布。
废话不说了,技术点介绍,描述来源于网络(想看就看,不想看就直接跳过介绍看后面)
WebSocket protocol 是HTML5一种新的协议。它实现了浏览器与服务器全双工通信(full-duplex)。一开始的握手需要借助HTTP请求完成。
Websocket 是全双工通讯(说白了就是俩都可以通讯,服务器也可以给客户端发消息,客户端也能给服务器发消息)。也是基于TCP的,效率是很高的,首先这个技术的底层选用,就决定了完全可以用wb这个技术做高并发应用,而且开发非常快!!代码非常简单!!最重要的是稳定性,扩展性等等都有保证,等会儿说为什么说都有保证。
WB 不同于TCP的三次握手。 WB是先进行一次HTTP请求,这个请求头不同于普通HTTP请求,等会贴出来讲解。然后服务器开始辨认请求头,如果是WB的请求头,则开始进行普通的TCP连接,即三次握手(不懂的TCP的,出门百度)。如果不是WB的HTTP请求头,那就是按普通的HTTP请求处理。
流程梳理: HTTP特殊请求(有个特殊的头) ---- 》 服务请接收判断 ----- 》 认出来了,确实是WB请求头,开启TCP 三次握手,建立连接后,和TCP一样了就------》没有认出来,不是WB的请求头,按普通HTTP请求处理。
为什么要用websocket
解决轮询问题,顾名思义就是轮回查询,轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP request,然后由服务器返回最新的数据给客户端的浏览器。这种传统的HTTP request 的模式带来很明显的缺点 – 浏览器需要不断的向服务器发出请求,然而HTTP request 的header是非常长的,里面包含的有用数据可能只是一个很小的值,这样会占用很多的带宽(来源百度百科)。当AJAX技术的涌现(不懂AJAX出门百度),有人用AJAX实时一步刷新来改变,虽然可达到全双工通信,但依然需要发出请求,所以AJAX只适用于小事件的处理比较合适一些。但是websocket可以解决轮询的问题。
什么场景适合使用
可以满足很多很多的事情,贴几张功能图来简单展示:
1.及时通讯(大部分都是为了做这个功能才用的websocket)
2.计算在线人数,以及列表
3.强制下线功能
截图太累,我就不一一列举了,还有很多,自己开脑洞吧。
那么到这里你大概知道websocket是什么东西了,我的目标是搭建一个,可以支持百万并发量的即时消息服务,但是如果简历上有这么一条的话,那么你就会觉得月薪过万真的好少,所以跟着作者一步一步来完成高级技术的掌握者吧。
虽然现在我也不会,也毫无头绪,但是既然目标已经有了。那么这件事就完成百分之51了。
学习是一种信仰,分享是一种态度。
友情提示:文章更新会很慢(近期会更新截图上的实现),因为要达到内个目标,需要很多次尝试,很多第三方技术的选用测试等等。所以大家可以一起评论讨论。
记住一点,我的目的不是为了完成百万级并发量,而是要彻底的知道如何实现百万并发量的每一步。
学习必须是互动的,不然就会是孤独的,孤独容易使人放弃。
共同学习,写下你的评论
评论加载中...
作者其他优质文章