nodejs如何结合socket.io实现websocket通信功能
这篇文章主要介绍nodejs如何结合socket.io实现websocket通信功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
具体如下:
因为项目中有需要实时获取后台数据的场景,之前一直是使用http心跳请求的方法。因为websocket与此模式相比有很大的性能提升,而且可以提高实时性,所以对websocket作了一些研究。这里是使用nodejs+socket.io来实现的。
达成目标
将原来心跳请求后台数据的方式,修改为通过socket连接后台统一推送的方式。后台的数据由别的进程写入文件或写入redis,这里实现的是读取文件的方式。
前期准备
安装nodejs(略)
服务器端
新建一个项目目录,这里是sockettest进入sockettest目录,安装express模块和socketio模块
npminstall--saveexpress@4.10.2 npminstall--savesocket.io
新建package.json文件,在其中写入如下内容:
{
"name":"socket-test",
"version":"0.0.1",
"description":"myfirstsocket.ioapp",
"dependencies":{
"express":"^4.10.2",
"socket.io":"^1.7.2"
}
}新建index.html,用于作为默认的访问显示页面,因为这里不会用到它,内容随意;新建trends.js文件,在其中写入内容:
varapp=require('express')();
varhttp=require('http').Server(app);
vario=require('socket.io')(http);
varfs=require('fs');
#默认打开文件
app.get('/',function(req,res){
res.sendfile('index.html');
});
#用于存储所有socket以广播数据
variolist=[];
#定义socketonconnection(连入)事件行为
io.on('connection',function(socket){
#将连入socket加入列表
iolist.push(socket);
#记录index,在disconnect(断开连接)发生时将对应的socket删除
varsockex=iolist.indexOf(socket);
#定义ondisconnect事件行为
socket.on('disconnect',function(){
#将断开连接的socket从广播列表里删除
iolist.splice(sockex,1);
});
});
#数据广播进程:每1秒钟广播一次
setInterval(function(){
#如果没有正在连接的socket,直接返回;
if(iolist.length<=0)return;
vartrends=fs.readFileSync('./data/trends.json','utf-8');#trends数据
varcoins=fs.readFileSync('./data/coins.json','utf-8');#coins数据
#向所有socket连接发送数据
for(iiniolist){
#向客户端发送trends数据
iolist[i].emit('trends',trends);
#向客户端发送coins数据
iolist[i].emit('coins',coins);
}
},1000);
#服务器侦听在sockettest.com的3000端口上
http.listen(3000,function(){
#输出到标准输出
console.log('listeningonsockettest.com:3000');
});新建data目录,并在下面新建两个文件trends与coins,用于存放socket服务器将要读取的数据。新建public目录,在其中新建一个文件index.html,文件内容如下:
<!--引入必要的js文件-->
<scripttype="text/javascript"src="http://sockettest:3000/socket.io/socket.io.js"></script>
<scripttype="text/javascript">
//新建socket
varsocket=io('http://sockettest.com:3000');
socketdata(socket);
functionsocketdata(){
#定义接收到coins类型数据时的行为
socket.on('coins',function(msg){
console.log(msg);
}
#定义接收到trends类型数据时的行为
socket.on('trends',function(msg){
console.log(msg);
}
}
</script>代码部署
刚才之所以要建两个index.html文件,是为了能够方便地在既有的web项目中使用nodejs提供的socket服务。这样我们把public/index.html可以部署在别的服务器中,比如nginx或tomcat之类,然后在根目下启动socket的服务器,为其提供socket服务。 首先在刚才的项目根目录下执行
node./trends.js
并保持终端运行,然后再把项目部署在nginx里,通过chrome下访问nginx提供的web服务:
http://hostname/public/index.html
打开开发者模式,就能在console里看到每隔一秒便会收到来自node服务器的socket推送消息了。通过修改data目录下的两个文件,可以看到写入到文件的数据也会实时地推送到客户端这里来。
以上是“nodejs如何结合socket.io实现websocket通信功能”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注恰卡编程网行业资讯频道!
推荐阅读
-
NodeJS怎么实现单点登录
NodeJS怎么实现单点登录这篇文章主要讲解了“NodeJS怎么实...
-
怎么用Vue+NodeJS实现大文件上传
怎么用Vue+NodeJS实现大文件上传本文小编为大家详细介绍“怎...
-
node中的buffer有什么用
node中的buffer有什么用本文小编为大家详细介绍“node中...
-
node中multer的概念是什么
node中multer的概念是什么这篇文章主要介绍“node中mu...
-
nodejs怎么读取文件夹目录的内容
nodejs怎么读取文件夹目录的内容小编给大家分享一下nodejs...
-
nodejs如何结合Socket.IO实现的即时通讯功能
这篇文章主要为大家展示了“nodejs如何结合Socket.IO实现的即时通讯功能”,内容简而易懂,条理清晰,希望能够帮助大家解决...
-
nodejs如何实现TCP服务器端和客户端聊天功能
这篇文章主要介绍了nodejs如何实现TCP服务器端和客户端聊天功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇...
-
Nodejs能够应用于什么场景
这篇文章给大家分享的是有关Nodejs能够应用于什么场景的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。...
-
Nodejs +Websocket如何实现指定发送及群聊
这篇文章主要介绍了Nodejs+Websocket如何实现指定发送及群聊,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读...
-
NodeJs内存占用过高如何排查
这篇文章给大家介绍NodeJs内存占用过高如何排查,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。问题起因最开...
