Creación de un cuaderno de Studio con Kinesis Data Streams - Managed Service para Apache Flink

Amazon Managed Service para Apache Flink Amazon (Amazon MSF) se denominaba anteriormente Amazon Kinesis Data Analytics para Apache Flink.

Creación de un cuaderno de Studio con Kinesis Data Streams

En este tutorial se describe cómo crear un cuaderno de Studio que utilice un flujo de datos de Kinesis como fuente.

Cumplir con los requisitos previos

Antes de crear un cuaderno de Studio, cree un flujo de datos de Kinesis (ExampleInputStream). Su aplicación utiliza estos flujos para el origen de la aplicación.

Se puede crear este flujo mediante la consola de Amazon Kinesis o el siguiente comando de la AWS CLI. Para obtener instrucciones sobre la consola, consulte Creating and Updating Data Streams en la Guía para desarrolladores de Amazon Kinesis Data Streams. Asigne el nombre ExampleInputStream al flujo y establezca el número de particiones abiertas en 1.

Para crear el flujo (ExampleInputStream), utilizando la AWS CLI, utilice el siguiente comando de Amazon Kinesis create-stream AWS CLI.

$ aws kinesis create-stream \ --stream-name ExampleInputStream \ --shard-count 1 \ --region us-east-1 \ --profile adminuser

Creación de una tabla de AWS Glue

Su cuaderno de Studio utiliza una AWS Glue base de datos para los metadatos sobre su origen de datos de Kinesis Data Streams.

nota

Se puede crear primero la base de datos manualmente o dejar que Managed Service para Apache Flink la cree por usted al crear el cuaderno. De forma similar, puede crear la tabla manualmente tal y como se describe en esta sección o puede usar el código conector de creación de tablas para Managed Service para Apache Flink en su cuaderno en Apache Zeppelin para crear la tabla mediante una instrucción DDL. A continuación, puede comprobar AWS Glue para asegurarse de que la tabla se creó correctamente.

Crear una tabla
  1. Inicie sesión en la Consola de administración de AWS y abra la consola de AWS Glue en https://console.aws.amazon.com/glue/.

  2. Si aún no tiene una base de datos AWS Glue, elija Bases de datos en la barra de navegación izquierda. Elija Agregar una base de datos. En la ventana Añadir base de datos, introduzca default en el nombre de la base de datos. Seleccione Crear.

  3. En la barra de navegación izquierda, seleccione Tablas. En la página Tablas, seleccione Añadir tablas y Añadir tabla manualmente.

  4. En la página Configurar las propiedades de la tabla, introduzca stock como Nombre de la tabla. Asegúrese de seleccionar la base de datos que creó anteriormente. Elija Siguiente.

  5. En la página Añadir un almacén de datos, elija Kinesis. Para el Nombre del flujo, introduzcaExampleInputStream. Para la URL de origen de Kinesis, pulse Intro https://kinesis.us-east-1.amazonaws.com. Si copia y pega la URL de origen de Kinesis, asegúrese de eliminar los espacios iniciales o finales. Elija Siguiente.

  6. En la página de Clasificación, seleccione JSON. Elija Siguiente.

  7. En la página Definir un esquema, elija Añadir columna para añadir una. Añada columnas con las siguientes propiedades:

    Nombre de la columna Tipo de datos
    ticker cadena
    precio double

    Elija Siguiente.

  8. En la página siguiente, verifique su configuración y seleccione Finalizar.

  9. Elija la tabla recién creada de la lista de tablas.

  10. Elija Editar tabla y añada una propiedad con la clave managed-flink.proctime y el valor proctime.

  11. Seleccione Aplicar.

Creación de un cuaderno de Studio con Kinesis Data Streams

Ahora que ha creado los recursos que utiliza su aplicación, cree su cuaderno de Studio.

Para crear la aplicación, puede utilizar la Consola de administración de AWS o la AWS CLI.

Creación de un cuaderno de Studio con la Consola de administración de AWS

  1. Abra la consola de Managed Service para Apache Flink en https://console.aws.amazon.com/managed-flink/home?region=us-east-1#/applications/dashboard.

  2. En la página de Aplicaciones de Managed Service para Apache Flink, seleccione la pestaña Studio. Seleccione Crear cuaderno de Studio.

    nota

    También puede crear un cuaderno de Studio desde las consolas de Amazon MSK o Kinesis Data Streams seleccionando el clúster de Amazon MSK o la el flujo de datos de Kinesis de entrada y eligiendo Procesar datos en tiempo real.

  3. En la página Crear cuaderno de Studio, proporcione la siguiente información:

    • Introduzca MyNotebook como nombre del cuaderno.

    • Elija el valor predeterminado para la Base de datos de Glue de AWS.

    Seleccione Crear cuaderno de Studio.

  4. En la página MyNotebook, seleccione Ejecutar. Espere a que el Estado muestre En ejecución. Se aplican cargos cuando el cuaderno se está ejecutando.

Creación de un cuaderno de Studio con la AWS CLI

Para crear su cuaderno de Studio usando la AWS CLI, haga lo siguiente:

  1. Verifique su ID de cuenta. Necesitará este valor para crear su aplicación.

  2. Cree el rol arn:aws:iam::AccountID:role/ZeppelinRole y añada los siguientes permisos al rol creado automáticamente por consola.

    "kinesis:GetShardIterator",

    "kinesis:GetRecords",

    "kinesis:ListShards"

  3. Cree un archivo denominado create.json con el siguiente contenido. Reemplace los valores de marcador de posición con su información.

    { "ApplicationName": "MyNotebook", "RuntimeEnvironment": "ZEPPELIN-FLINK-3_0", "ApplicationMode": "INTERACTIVE", "ServiceExecutionRole": "arn:aws:iam::AccountID:role/ZeppelinRole", "ApplicationConfiguration": { "ApplicationSnapshotConfiguration": { "SnapshotsEnabled": false }, "ZeppelinApplicationConfiguration": { "CatalogConfiguration": { "GlueDataCatalogConfiguration": { "DatabaseARN": "arn:aws:glue:us-east-1:AccountID:database/default" } } } } }
  4. Para crear su aplicación, ejecute el siguiente comando:

    aws kinesisanalyticsv2 create-application --cli-input-json file://create.json
  5. Una vez completado el comando, verá un resultado que muestra los detalles de su nuevo cuaderno de Studio. A continuación se muestra un ejemplo de la salida.

    { "ApplicationDetail": { "ApplicationARN": "arn:aws:kinesisanalyticsus-east-1:012345678901:application/MyNotebook", "ApplicationName": "MyNotebook", "RuntimeEnvironment": "ZEPPELIN-FLINK-3_0", "ApplicationMode": "INTERACTIVE", "ServiceExecutionRole": "arn:aws:iam::012345678901:role/ZeppelinRole", ...
  6. Para iniciar su aplicación, ejecute el siguiente comando. Sustituya los valores de muestra por su ID de la cuenta.

    aws kinesisanalyticsv2 start-application --application-arn arn:aws:kinesisanalyticsus-east-1:012345678901:application/MyNotebook\

Envío de datos a su flujo de datos de Kinesis

Para enviar los datos de prueba al flujo de datos de Kinesis, haga lo siguiente:

  1. Abra el Kinesis Data Generator.

  2. Elija Crear un usuario de Cognito con CloudFormation.

  3. La consola CloudFormation se abre con la plantilla de Kinesis Data Generator. Elija Siguiente.

  4. En la página Especificar detalles de pila, ingrese el nombre y la contraseña de su usuario de Cognito. Elija Siguiente.

  5. En la página Configurar opciones de pila, elija Siguiente.

  6. En la página Revisar Kinesis-Data-Generator-Cognito-User, elija la casilla de verificación Acepto que AWS CloudFormation podría crear recursos de IAM. Elija Crear pila.

  7. Espere a que termine la creación de la pila de CloudFormation. Una vez completada la pila, abra la pila Kinesis-Data-Generator-Cognito-User en la consola CloudFormation y seleccione la pestaña Salidas. Abra la URL que aparece para el valor de salida de KinesisDataGeneratorUrl.

  8. En la página de Amazon Kinesis Data Generator, inicie sesión con las credenciales que creó en el paso 4.

  9. En la siguiente página , especifique los valores siguientes:

    Región us-east-1
    Transmisión de Stream/Firehose ExampleInputStream
    Registros por segundo 1

    En Plantilla de registro, pegue el siguiente código:

    { "ticker": "{{random.arrayElement( ["AMZN","MSFT","GOOG"] )}}", "price": {{random.number( { "min":10, "max":150 } )}} }
  10. Elija Enviar datos.

  11. El generador enviará los datos a su flujo de datos de Kinesis.

    Deje el generador ejecutándose mientras completa la siguiente sección.

Prueba de su cuaderno de Studio

En esta sección, utilizará su cuaderno de Studio para consultar datos de su flujo de datos de Kinesis.

  1. Abra la consola de Managed Service para Apache Flink en https://console.aws.amazon.com/managed-flink/home?region=us-east-1#/applications/dashboard.

  2. En la página de Aplicaciones de Managed Service para Apache Flink, seleccione la pestaña Cuaderno de Studio. Elija MyNotebook.

  3. En la página MyNotebook, seleccione Abrir en Apache Zeppelin.

    La interfaz de Apache Zeppelin se abre en una pestaña nueva.

  4. En la página ¡Bienvenido a Zeppelin!, elija la Zeppelin Note.

  5. En la página Zeppelin Note, introduzca la siguiente consulta en una nota nueva:

    %flink.ssql(type=update) select * from stock

    Seleccione el icono de reproducción.

    Al cabo de poco tiempo, el cuaderno muestra los datos de la flujo de datos de Kinesis.

Para abrir el Panel de control de Apache Flink de su aplicación y ver los aspectos operativos, elija TRABAJO DE FLINK. Para obtener más información sobre el Panel de control de Flink, consulte Apache Flink Dashboard en la Guía para desarrolladores de Managed Service para Apache Flink.

Para ver más ejemplos de consultas SQL de Flink Streaming, consulte Queries en la documentación de Apache Flink.