nodejs結合socket.io實現websocket通訊功能的方法,socket.iowebsocket

來源:互聯網
上載者:User

nodejs結合socket.io實現websocket通訊功能的方法,socket.iowebsocket

本文執行個體講述了nodejs結合socket.io實現websocket通訊功能的方法。分享給大家供大家參考,具體如下:

因為項目中有需要即時擷取後台資料的情境,之前一直是使用http心跳請求的方法。因為websocket與此模式相比有很大的效能提升,而且可以提高即時性,所以對websocket作了一些研究。這裡是使用nodejs+socket.io來實現的。

達成目標

將原來心跳請求後台資料的方式,修改為通過socket串連後台統一推送的方式。背景資料由別的進程寫入檔案或寫入redis,這裡實現的是讀取檔案的方式。

前期準備

安裝nodejs(略)

伺服器端

建立一個項目目錄,這裡是sockettest
進入sockettest目錄,安裝express模組和socketio模組

npm install --save express@4.10.2npm 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程式設計有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.