这篇文章主要介绍了 nodejs 结合 socket.io 实现 websocket 通信功能的方法, 结合实例形式分析了 nodejs 结合 socket.io 实现 websocket 通信的具体步骤与相关操作技巧, 需要的朋友可以参考下
本文实例讲述了 nodejs 结合 socket.io 实现 websocket 通信功能的方法分享给大家供大家参考, 具体如下:
因为项目中有需要实时获取后台数据的场景, 之前一直是使用 http 心跳请求的方法因为 websocket 与此模式相比有很大的性能提升, 而且可以提高实时性, 所以对 websocket 作了一些研究这里是使用 nodejs+socket.io 来实现的
达成目标
将原来心跳请求后台数据的方式, 修改为通过 socket 连接后台统一推送的方式后台的数据由别的进程写入文件或写入 redis, 这里实现的是读取文件的方式
前期准备
安装 nodejs(略)
服务器端
新建一个项目目录, 这里是 sockettest
进入 sockettest 目录, 安装 express 模块和 socketio 模块
- npm install --save express@4.10.2
- npm install --save socket.io
新建 package.json 文件, 在其中写入如下内容:
- {
- "name": "socket-test",
- "version": "0.0.1",
- "description": "my first socket.io app",
- "dependencies": {
- "express": "^4.10.2",
- "socket.io": "^1.7.2"
- }
- }
新建 index.html, 用于作为默认的访问显示页面, 因为这里不会用到它, 内容随意;
新建 trends.js 文件, 在其中写入内容:
- var app = require('express')();
- var http = require('http').Server(app);
- var io = require('socket.io')(http);
- var fs = require('fs');
- # 默认打开文件
- app.get('/', function(req, res){
- res.sendfile('index.html');
- });
- # 用于存储所有 socket 以广播数据
- var iolist = [];
- # 定义 socket on connection(连入) 事件行为
- io.on('connection', function(socket){
- #将连入 socket 加入列表
- iolist.push(socket);
- #记录 index, 在 disconnect(断开连接) 发生时将对应的 socket 删除
- var sockex = iolist.indexOf(socket);
- #定义 on disconnect 事件行为
- socket.on('disconnect', function(){
- #将断开连接的 socket 从广播列表里删除
- iolist.splice(sockex, 1);
- });
- });
- # 数据广播进程: 每 1 秒钟广播一次
- setInterval(function() {
- # 如果没有正在连接的 socket, 直接返回;
- if (iolist.length <= 0) return;
- var trends = fs.readFileSync('./data/trends.json','utf-8');#trends 数据
- var coins = fs.readFileSync('./data/coins.json','utf-8');#coins 数据
- #向所有 socket 连接发送数据
- for (i in iolist) {
- # 向客户端发送 trends 数据
- iolist[i].emit('trends', trends);
- # 向客户端发送 coins 数据
- iolist[i].emit('coins', coins);
- }
- }, 1000);
- # 服务器侦听在 sockettest.com 的 3000 端口上
- http.listen(3000, function(){
- # 输出到标准输出
- console.log('listening on sockettest.com:3000');
- });
新建 data 目录, 并在下面新建两个文件 trends 与 coins, 用于存放 socket 服务器将要读取的数据
新建 public 目录, 在其中新建一个文件 index.html, 文件内容如下:
- <!-- 引入必要的 js 文件 -->
- <script type="text/javascript" src="http://sockettest:3000/socket.io/socket.io.js"></script>
- <script type="text/javascript">
- // 新建 socket
- var socket = io('http://sockettest.com:3000');
- socketdata(socket);
- function socketdata() {
- #定义接收到 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 目录下的两个文件, 可以看到写入到文件的数据也会实时地推送到客户端这里来
参考文章
http://socket.io/get-started/chat/
希望本文所述对大家 nodejs 程序设计有所帮助
来源: http://www.phperz.com/article/18/0226/362669.html