TsgcWebSocketLoadBalancerServer › メソッド › Broadcast
WebSocket メッセージをクラスター内のすべてのバックアップ サーバーにファンアウトします。チャンネル、プロトコル、または接続 GUID リストでオプションのフィルタリングができます。
procedure Broadcast(const aMessage: string; const aChannel: string = ''; const aProtocol: string = ''; const Exclude: String = ''; const Include: String = '');
| 名前 | タイプ | 説明 |
|---|---|---|
aMessage | const string | 一致する各クライアントにWebSocketテキストフレームとして配信されるテキストペイロード。 |
aChannel | const string | 空でない場合、メッセージは指定されたチャンネルをサブスクライブしているクライアントのみに送信されます。 |
aProtocol | const string | 空でない場合、メッセージは指定されたWebSocketサブプロトコルを使用するクライアントにのみ送信されます。 |
Exclude | const String | このブロードキャストでスキップする必要がある接続 GUID のカンマ区切りリスト。 |
Include | const String | ブロードキャストをそのサブセットに制限する接続 GUID のカンマ区切りリスト。空の場合は無視されます。 |
このオーバーロードはロードバランサーを通じてテキストフレームを送信し、登録されたすべてのバックアップサーバーが自身のローカル接続されたWebSocketクライアントに再配信します。フィルターはANDセマンティクスで結合されます。接続はすべての非空フィルターを満たす場合にのみメッセージを受信し、そのGUIDがExcludeに含まれている場合は到達しません。純粋なHTTP/HTTP2リクエストはBroadcastがWebSocketハンドシェイクを完了したクライアントのみを対象とするため無視されます。ロードバランサーはペイロードを各バックアップノードに順に転送します。接続ごとの書き込みエラーはブロードキャストを中断せずにOnExceptionを通じて報告されます。この呼び出しは呼び出し元のスレッドで実行され、各バックアップサーバーへのリンクにフレームが渡されると返ります。
oServer.Broadcast('Hello From Server');
procedure Broadcast(aStream: TStream; const aChannel: string = ''; const aProtocol: string = ''; const Exclude: String = ''; const Include: String = ''; const aSize: Integer = 0; const aStreaming: TwsStreaming = stmNone);
| 名前 | タイプ | 説明 |
|---|---|---|
aStream | TStream | 各一致するクライアントに WebSocket バイナリフレームとして配信されるコンテンツのソースストリーム。呼び出し元がストリームの所有者のままです。 |
aChannel | const string | 空でない場合、メッセージは指定されたチャンネルをサブスクライブしているクライアントのみに送信されます。 |
aProtocol | const string | 空でない場合、メッセージは指定されたWebSocketサブプロトコルを使用するクライアントにのみ送信されます。 |
Exclude | const String | このブロードキャストでスキップする必要がある接続 GUID のカンマ区切りリスト。 |
Include | const String | ブロードキャストをそのサブセットに制限する接続 GUID のカンマ区切りリスト。空の場合は無視されます。 |
aSize | const Integer | オプションのフラグメントサイズ(バイト単位)。ゼロより大きい場合、各クライアントはこのサイズのフラグメントに分割されたストリームを受け取ります。0(デフォルト)を使用するとストリーム全体を単一フレームとして送信します。 |
aStreaming | const TwsStreaming | フラグメント化された送信のストリーミングモード(stmNone、stmStart、stmContinue、stmFinish)。デフォルトは stmNone で、完全なスタンドアロンメッセージを送信します。 |
このオーバーロードはロードバランサーを通じてストリームコンテンツをバイナリフレームとしてブロードキャストします。ロードバランサーはペイロードをすべての登録済みバックアップサーバーに転送し、それらがローカルのWebSocketクライアントに再配信できるようにします。ストリームは現在の位置から読み取られます。ロードバランサーは所有権を取得しないため、呼び出し元はBroadcastが返るまでストリームをアライブに保つ必要があります。チャンネル、プロトコル、Include、Excludeフィルターは各バックアップノードが自身の接続にフレームをディスパッチするときに評価されます。非常に大きなペイロードを1つの過大なフレームではなく複数のWebSocketフラグメントとしてストリーミングするにはaSizeとaStreamingを使用してください。
oStream := TMemoryStream.Create;
try
oStream.LoadFromFile('payload.bin');
oServer.Broadcast(oStream);
finally
oStream.Free;
end;