WebSocket通信機能をnodejsに実装する方法

亚连
リリース: 2018-06-12 11:54:19
オリジナル
1448 人が閲覧しました

この記事では、WebSocket通信機能を実現するためにnodejsとsocket.ioを組み合わせた方法を主に紹介し、WebSocket通信を実現するためのnodejsと関連する操作スキルをサンプルの形で分析します。この記事の例を参照してください

WebSocket通信機能を実装するためのnodejsとsocket.ioの組み合わせ方法について説明します。参考までに皆さんと共有してください。詳細は次のとおりです:

プロジェクトにはバックグラウンド データのリアルタイム取得が必要なシナリオがあるため、以前は http ハートビート リクエスト メソッドが使用されていました。 WebSocket はこのモードと比較してパフォーマンスが大幅に向上し、リアルタイム パフォーマンスを向上させることができるため、WebSocket についていくつかの研究が行われています。これは、nodejs+socket.io を使用して実装されます。

目標を達成する

元のハートビートリクエストのバックグラウンドデータメソッドを、バックグラウンドへのソケット接続を介した統合プッシュメソッドに変更します。バックグラウンド データは、他のプロセスによってファイルまたは Redis に書き込まれます。ここで実装されるのは、ファイルを読み取る方法です。

事前準備

nodejsをインストール(省略)

サーバー側

新しいプロジェクトディレクトリを作成、ここにsockettest
sockettestディレクトリに入り、expressモジュールとsocketioモジュールをインストールする

npm install --save express@4.10.2
npm install --save socket.io
ログイン後にコピー

新しいパッケージ。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(&#39;./data/trends.json&#39;,&#39;utf-8&#39;);#trends数据
  var coins = fs.readFileSync(&#39;./data/coins.json&#39;,&#39;utf-8&#39;);#coins数据
  #向所有socket连接发送数据
  for (i in iolist) {
    # 向客户端发送trends数据
    iolist[i].emit(&#39;trends&#39;, trends);
    # 向客户端发送coins数据
    iolist[i].emit(&#39;coins&#39;, coins);
  }
}, 1000);
# 服务器侦听在sockettest.com的3000端口上
http.listen(3000, function(){
  # 输出到标准输出
  console.log(&#39;listening on sockettest.com:3000&#39;);
});
ログイン後にコピー

新しいデータ ディレクトリを作成し、ソケット サーバーによって読み取られるデータを保存するために、以下の 2 つの新しいファイル Trend と Coins を作成します。
新しいパブリックディレクトリを作成し、その中に新しいファイル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(&#39;http://sockettest.com:3000&#39;);
    socketdata(socket);
    function socketdata() {
      #定义接收到coins类型数据时的行为
      socket.on(&#39;coins&#39;, function(msg){
        console.log(msg);
      }
      #定义接收到trends类型数据时的行为
      socket.on(&#39;trends&#39;, function(msg){
        console.log(msg);
      }
    }
</script>
ログイン後にコピー

コードデプロイメント

2つのindex.htmlファイルを作成した理由は次のとおりです。既存のソケットに簡単に追加できるようにします。nodejs によって提供されるソケット サービスは、Web プロジェクトで使用されます。このようにして、nginx や tomcat などの他のサーバーに public/index.html をデプロイし、ルート ディレクトリでソケット サーバーを起動してソケット サービスを提供できます。
まず、先ほどのプロジェクトのルート ディレクトリで

node ./trends.js
ログイン後にコピー

を実行し、ターミナルを実行したままにして、プロジェクトを nginx にデプロイし、Chrome 経由で nginx が提供する Web サービスにアクセスします:

http://hostname/public/開発者モードをオンにすると、ノード サーバーからソケット プッシュ メッセージを毎秒受信することがコンソールで確認できます。データ ディレクトリ内の 2 つのファイルを変更すると、ファイルに書き込まれたデータもリアルタイムでクライアントにプッシュされることがわかります。

上記は私があなたのためにまとめたものです。

関連記事:

vueでcliを使用して複数ページのスキャフォールディングの再構築を実装する方法

JSでドロップダウンメニューのコンテンツ同期入力ボックスのクリック・トゥ・クリックを実現

入力ボックスとドロップダウンボックス連携

Parcel.jsを使用したパッケージングエラーの問題

vue再構成技術の詳細な解釈

以上がWebSocket通信機能をnodejsに実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!