Definición
sp.createStreamProcessor()Crea un Procesador de flujo en el espacio de trabajo de procesamiento de flujo actual.
Solo puedes invocar este comando mientras estés conectado a un espacio de trabajo de procesamiento de flujo.
Este comando requiere
mongoshversión ≥ 2.0.
Compatibilidad
Este método es compatible con los espacios de trabajo de procesamiento de secuencias de Atlas.
Sintaxis
El método sp.createStreamProcessor() tiene la siguiente sintaxis:
sp.createStreamProcessor( <name>, [ <pipeline> ], { <options> } )
Campos de comandos
sp.createStreamProcessor() toma estos campos:
Campo | Tipo | Necesidad | Descripción |
|---|---|---|---|
| string | Requerido | Nombre lógico del procesador de flujo. Debe ser único dentro del espacio de trabajo de procesamiento de flujo. |
| arreglo | Requerido | Canal de agregación de transmisiones que desea aplicar a sus datos de transmisión. |
| Objeto | Opcional | Objeto que define varias configuraciones opcionales para su procesador de flujo. |
| Objeto | Condicional | Objeto que asigna un
Cola demensajes no entregados para su |
| string | Condicional | Etiqueta que identifica una conexión en su registro de conexiones. Esta conexión debe hacer referencia a un clúster Atlas. Este campo es necesario si define el campo |
| string | Condicional | Nombre de una base de datos Atlas en el clúster especificado en |
| string | Condicional | Nombre de una colección en la base de datos especificada en |
| string | Opcional | El nivel al que Atlas Stream Processing asigna el procesador. Si no declara esta opción, Atlas Stream Processing asigna el procesador al nivel del espacio de trabajo de Stream Processing. Debe ser uno de los siguientes:
Para obtener más información, consulte Niveles. |
Comportamiento
sp.createStreamProcessor() Crea un procesador de flujo persistente con nombre en el espacio de trabajo de procesamiento de flujo actual. Puede inicializar este procesador de flujo sp.processor.start() con. Si intenta crear un procesador de flujo con el mismo nombre que uno existente, mongosh devolverá un error.
Control de acceso
El usuario que ejecuta sp.createStreamProcessor() debe tener el atlasAdmin rol.
Ejemplo
El siguiente ejemplo crea un procesador de flujo llamado solarDemo que ingiere datos de la sample_stream_solar conexión. El procesador excluye todos los documentos cuyo valor del device_id campo sea device_8 y pasa el resto a una ventana de bucle con una 10duración de segundos. Cada ventana agrupa los documentos que recibe y devuelve diversas estadísticas útiles de cada grupo. El procesador de flujo fusiona estos registros en a solar_db.solar_coll través de la mongodb1 conexión.
sp.createStreamProcessor( 'solarDemo', [ { $source: { connectionName: 'sample_stream_solar', timeField: { $dateFromString: { dateString: '$timestamp' } } } }, { $match: { $expr: { $ne: [ "$device_id", "device_8" ] } } }, { $tumblingWindow: { interval: { size: Int32(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"] } } ] )