设为首页 收藏本站
查看: 752|回复: 0

[经验分享] nodejs多房间web聊天室

[复制链接]

尚未签到

发表于 2017-2-21 12:58:17 | 显示全部楼层 |阅读模式
一年之前的做的小项目,过了许久,翻出当时的PPT文档总结一下。源码下载:https://github.com/CreekLou/chatRoom
 
Nodejs背景简介
1 ,JavaScript最早是运行在浏览器中,然而浏览器只是提供了一个上下文
2 ,node.js事实上就是另外一种上下文,它允许在后端(脱离浏览器环境)运行JavaScript代码
3 ,Node.js事实上既是一个运行时环境,同时又是一个库

Nodejs架构如下图

DSC0000.jpg

Node.js 的异步机制是基于事件的,所有的磁盘 I/O 、网络通信、数据库查询都以非阻塞,的方式请求,返回的结果由事件循环来处理
 
·事件驱动的回调(事件轮询)
·异步IO避免了频繁的上下文切换
·在node中除了代码,所有一切都是并行执行的
  
DSC0001.jpg
多线程同步式 I/O与单线程异步式 I/O
同步式 I/O (阻塞式):
利用多线程提供吞吐量 
通过事件片分割和线程调度利用多核CPU 
需要由操作系统调度多线程使用多核 CPU 
难以充分利用 CPU  资源 
内存轨迹大,数据局部性弱
符合线性的编程思维 

异步式 I/O (非阻塞式):
单线程即可实现高吞吐量
通过功能划分利用多核CPU 
可以将单进程绑定到单核 CPU 
可以充分利用 CPU  资源 
内存轨迹小,数据局部性强 
不符合传统编程思维 

DSC0002.jpg DSC0003.jpg
Node.js 程序由事件循环开始,到事件循环结束,所有的逻辑都是事件的回调函数,所以 Node.js  始终在事件循环中,程序入口就是事件循环第一个事件的回调函数
DSC0004.jpg
 
 Nodejs核心模块
  1,核心模块是 Node.js  的心脏,它由一些精简而高效的库组成,为 Node.js  提供了基本的 API
2,process:用于描述当前 Node.js  进程状态的对象,提供了一个与操作系统的简单接口,通常在你写本地命令行程序的时候用到。
3,console :用于提供控制台标准输出。(IE)
4,Util:  是一个 Node.js  核心模块,提供常用函数的集合
5,events :是 Node.js  最重要的模块,没有“之一”
6,fs :文件系统,提供了文件的读取、写入、更名、删除、遍历目录、链接等 POSIX  文件系统操作
 
模块httpServer,Nodejs server 采用V8虚拟机
 
[javascript] view plaincopy DSC0005.jpg  



  • var http = require("http");//请求(require)Node.js自带的 http 模块,并且把它赋值给 http 变量  
  • http.createServer(function(request, response) {  
  •       //调用http模块提供的函数: createServer  
  •       response.writeHead(200, {"Content-Type""text/plain"});  
  •       response.write("Hello World");  
  •       response.end();  
  • }).listen(8888);  

 
 
socket.io
socket.io 提供了三种默认的事件:connect 、message 、disconnect 。
当与对方建立连接后自动触发 connect 事件,当收到对方发来的数据后触发 message 事件(通常为 socket.send() 触发),当对方关闭连接后触发 disconnect 事件。
socket.emit() :向建立该连接的客户端广播
socket.broadcast.emit() :向除去建立该连接的客户端的所有客户端广播
io.sockets.emit() :向所有客户端广播,等同于上面两个的和

CLIENT (INDEX.HTML)
 
[javascript] view plaincopy 



  • <script src="/socket.io/socket.io.js"></script> <script>  
  • varsocket=io.connect('http://localhost'); socket.on('news'function (data) {   
  •      console.log(data);   
  •       socket.emit('my other event', { my: 'data' });   
  • });   
  •   
  • </script>  

  SERVER (APP.JS)
 
 
[javascript] view plaincopy 



  • var app = require('express')() ,  
  • server = require('http').createServer(app) ,  
  •  io = require('socket.io').listen(server);   
  • //将 socket.io 绑定到服务器上  
  • server.listen(80);  
  •  app.get('/'function (req, res) {   
  •     res.sendfile(__dirname + '/index.html');   
  • });  
  • //服务器监听所有客户端,并返回该新连接对象  
  •  io.sockets.on('connection'function (socket) {  
  •  socket.emit('news', { hello: 'world'   
  • });   
  • socket.on('my other event'function (data) {   
  • console.log(data);  
  •  });   
  • });  

 
聊天室功能图

 
参考文献:
http://socket.io/
http://nodejs.org/documentation/tutorials/
  https://github.com/CreekLou/chatRoom

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-345314-1-1.html 上篇帖子: nodejs+java混合网站开发实践 下篇帖子: nodejs 通过 JSON-RPC 调用 aria2 接口
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表