Laravel 開発: Laravel Echo Server を使用して WebSocket サーバーを実装するにはどうすればよいですか?

WBOY
リリース: 2023-06-13 15:08:44
オリジナル
1612 人が閲覧しました

リアルタイム通信テクノロジーの急速な発展に伴い、WebSocket は多くの Web 開発者に選ばれるようになり、Laravel フレームワークも例外ではありません。 Laravel Echo Server を使用すると、Web 開発者は WebSocket サーバーを簡単に実装し、リアルタイム通信アプリケーションを迅速に構築できます。この記事では、Laravel Echo Server を使用して Laravel アプリケーションにリアルタイム通信を実装する方法を理解するのに役立つ、Laravel Echo Server の詳細な入門ガイドを提供します。

Laravel Echo サーバーとは何ですか?

Laravel Echo Server はオープンソース プロジェクトであり、Laravel Echo 用のリアルタイム通信サーバーであり、Laravel Echo と併用して WebSocket 通信を実装できます。 Laravel Echo は、開発者が簡単な構文を使用してアプリケーションを WebSocket サーバーに接続できるようにする JavaScript ライブラリです。 Laravel Echo Server はサーバーとして機能します。

Laravel Echo Server では、開発者は Node.js と Socket.io を使用してリアルタイム通信サーバーを作成できます。 Laravel Echo Server は Socket.io に基づいており、ユーザーが WebSocket サーバーを構築しやすくするためのシンプルな API とコンソールを提供します。

Laravel Echo Server のインストール

まず、Node.js と npm をインストールする必要があります。すでにインストールしている場合は、この手順をスキップしてください。

Node.js と npm をインストールする

sudo apt-get update
sudo apt-get install nodejs
sudo apt-get install npm
ログイン後にコピー

インストールが完了したら、Node.js と npm が正常にインストールされたかどうかを確認してください。

node -v
npm -v
ログイン後にコピー

次に、npm を使用して Laravel Echo Server をインストールできます。ターミナルに次のコマンドを入力してインストールします:

sudo npm install -g laravel-echo-server
ログイン後にコピー

インストールが完了したら、次のコマンドを使用して Laravel Echo Server のバージョンを確認できます:

laravel-echo-server -v
ログイン後にコピー

Laravel アプリケーションの構成

Laravel Echo Server を使用する前に、WebSocket サーバーと通信するように Laravel アプリケーションを設定する必要があります。 Laravel 5.6 バージョン以降、Laravel フレームワークには組み込みの Pusher サービス プロバイダーが組み込まれています。 config/broadcasting.php には、プッシャー サービス プロバイダーの設定が含まれています。

デフォルトでは、Laravel フレームワークはプッシャー サービス プロバイダーを使用してブロードキャスト イベントを処理します。ただし、Laravel Echo サーバーを使用する場合は、Laravel Echo が WebSocket サーバー上のブロードキャスト イベントをリッスンできるようにこのファイルを変更する必要があります。

config/broadcasting.php ファイルを変更する前に、まずコンポーザーの依存関係をインストールする必要があります。

composer require predis/predis
ログイン後にコピー

次に、config/broadcasting.php ファイルを開き、ブロードキャスト ドライバーを Redis に変更します。

'connections' => [
     'redis' => [
         'driver' => 'redis',
         'connection' => 'default',
     ],
],
ログイン後にコピー

次に、Redis サービスをインストールして開始する必要があります。 Redis は次のコマンドを使用してインストールできます:

sudo apt-get install -y redis-server
ログイン後にコピー

redis サービスを開始します:

sudo systemctl start redis
ログイン後にコピー

これで、Laravel アプリケーションは Laravel Echo Server と通信する準備ができました。

Laravel Echo Server の構成

このセクションでは、Laravel Echo Server を構成して起動します。 Laravel Echo Server は、ファイルの設定を変更することで WebSocket サーバーを構成できる簡単な構成ファイルを提供します。デフォルトでは、Laravel Echo Server はファイルストレージを使用してクライアントデータを保存しますが、Redis を使用してクライアントデータを保存することを選択できます。

Laravel Echo Server ファイルの構成

Laravel Echo Server を使用する前に、構成ファイルを作成する必要があります。次のコマンドを使用して、アプリケーションのルート ディレクトリに構成ファイルを作成できます。

laravel-echo-server init
ログイン後にコピー

init コマンドを実行すると、Laravel Echo Server は新しい laravel-echo-server.json 設定ファイルを作成します。次のコマンドを使用して構成ファイルを編集できます。

nano laravel-echo-server.json
ログイン後にコピー

エディタでは、構成ファイルのデフォルト設定が表示されます。必要に応じて変更できる一般的な設定をいくつか示します。

{
    "authHost": "http://localhost",
    "authEndpoint": "/broadcasting/auth",
    "clients": [],
    "database": "redis",
    "databaseConfig": {
        "redis": {},
        "sqlite": {
            "databasePath": "/database/laravel-echo-server.sqlite"
        }
    },
    "devMode": false,
    "host": null,
    "port": "6001",
    "protocol": "http",
    "socketio": {},
    "sslCertPath": "",
    "sslKeyPath": "",
    "sslCertChainPath": "",
    "sslPassphrase": "",
    "subscribers": {
        "http": true,
        "redis": true
    },
    "apiOriginAllow": {
        "allowCors": false,
        "allowOrigin": "",
        "allowMethods": "",
        "allowHeaders": ""
    }
}
ログイン後にコピー
  • authHost: Laravel で設定されたアプリケーションのホスト名/アドレス。
  • authEndpoint: Laravel アプリケーションのブロードキャスト認証エンドポイント。
  • clients: クライアント名とキー。
  • データベース: クライアント データ ストレージ タイプ。
  • devMode: Laravel Echo Server が開発モードで実行されているかどうか。
  • host: WebSocket サーバーにバインドされているホスト名。
  • port: WebSocket サーバーにバインドされているポート。
  • protocol: WebSocket サーバーのプロトコル。
  • subscribers: メッセージ購読者。
  • apiOriginAllow: API リクエストをサポートするホスト。

実際の環境に応じて設定ファイルを変更して保存します。

Laravel Echo Server の起動

設定が完了したら、次のコマンドを使用して Laravel Echo Server を起動します。

laravel-echo-server start
ログイン後にコピー

Laravel Echo Server が正常に起動し、WebSocket サーバーの実装に使用できるようになりました。

Laravel Echo Server を使用すると、リアルタイム通信を実装するのは非常に簡単です。 Laravel では、次のコマンドを使用してイベントをブロードキャストするだけです:

broadcast(new WebsocketDemoEvent($user, $message));
ログイン後にコピー

これにより、Laravel Echo サーバー上で新しい WebsocketDemoEvent イベントがブロードキャストされます。コンソールで上記のコマンドを使用してLaravel Echo Serverを起動していることを確認してください。

Laravel Echo Server は、ブラウザを通じてアクセスして WebSocket サーバーのステータス情報を表示できる使いやすい管理インターフェイスを提供します。デフォルトでは、管理インターフェイスは http://localhost:6001 にあります。

ここでは、Laravel Echo Server を使用して WebSocket サーバーを実装する方法を紹介します。 Laravel Echo Server は、リアルタイム通信を処理する簡単な方法を提供するため、WebSocket は幅広い Web 開発者にとって非常に役立ちます。リアルタイム通信を実装する簡単な方法を探している場合は、Laravel Echo Server を試してみてください。

以上がLaravel 開発: Laravel Echo Server を使用して WebSocket サーバーを実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート