SP.process()
定義
バージョン7.0の新機能: 現在の ストリーム プロセシング インスタンス にエフェメラル Stream プロセッサ を作成します。
互換性
構文
sp.process()
メソッドの構文は次のとおりです。
sp.process( [ <pipeline> ], { <options> } )
コマンドフィールド
sp.createStreamProcessor()
次のフィールドを取ります。
フィールド | タイプ | 必要性 | 説明 |
---|---|---|---|
| string | 必須 | ストリーム プロセッサの論理名。 これは、ストリーム プロセシング インスタンス内で一意である必要があります。 |
| 配列 | 必須 | データのストリーミング配信に適用するストリーム集約パイプライン。 |
| オブジェクト | 任意 | ストリーム プロセッサのさまざまなオプション設定を定義するオブジェクト。 |
| オブジェクト | 条件付き | ストリーム プロセシング インスタンスにデッド レター キューを割り当てるオブジェクト。 このフィールドは、 |
| string | 条件付き | 接続レジストリ内の接続を識別するラベル。 この接続は Atlas クラスターを参照する必要があります。 このフィールドは、 |
| string | 条件付き |
|
| string | 条件付き |
|
動作
sp.process()
は、現在のストリーム プロセシング インスタンスにエフェメラルの名前のないストリーム プロセッサを作成し、すぐに初期化します。 このストリーム プロセッサは の実行中のみ保持されます。 エフェメラル ストリーム プロセッサを終了した場合、使用するには再度作成する必要があります。
アクセス制御
sp.process()
を実行しているユーザーにはatlasAdmin
ロールが必要です。
例
次の例では、 sample_stream_solar
接続からデータを取り込む一時的なストリーム プロセッサを作成しています。 プロセッサは、 device_id
フィールドの値がdevice_8
であるすべてのドキュメントを除外し、残りを10秒の期間のローリングウィンドウに渡します。 各ウィンドウは受け取ったドキュメントをグループ化し、各グループのさまざまな有用な統計を返します。 次に、ストリーム プロセッサはこれらのレコードをmongodb1
接続を介してsolar_db.solar_coll
にマージします。
sp.process( [ { $source: { connectionName: 'sample_stream_solar', timeField: { $dateFromString: { dateString: '$timestamp' } } } }, { $match: { $expr: { $ne: [ "$device_id", "device_8" ] } } }, { $tumblingWindow: { interval: { size: NumberInt(10), unit: "second" }, "pipeline": [ { $group: { "_id": { "device_id": "$device_id" }, "max_temp": { $max: "$obs.temp" }, "max_watts": { $max: "$obs.watts" }, "min_watts": { $min: "$obs.watts" }, "avg_watts": { $avg: "$obs.watts" }, "median_watts": { $median: { input: "$obs.watts", method: "approximate" } } } } ] } }, { $merge: { into: { connectionName: "mongodb1", db: "solar_db", coll: "solar_coll" }, on: ["_id"] } } ] )