API serverless

Dati in streaming con AWS Kinesis e Lambda

Maksim Pecherskiy

Data Engineer

Lezione precedente

RGv3B.png

Dati in streaming con AWS Kinesis e Lambda

Dare accesso ai dati

htdz9.png

Dati in streaming con AWS Kinesis e Lambda

API semplice

XTKzt.png

Dati in streaming con AWS Kinesis e Lambda

API semplice

RFhY5.png

Dati in streaming con AWS Kinesis e Lambda

API semplice

SuISK.png

Dati in streaming con AWS Kinesis e Lambda

Aggiungi un trigger

jSRoQ.png

Dati in streaming con AWS Kinesis e Lambda

Testa la nuova API

JtGop.png

Dati in streaming con AWS Kinesis e Lambda

La nostra prima API

r2u54G.png

Dati in streaming con AWS Kinesis e Lambda

Parametri dell'API

Richiesta di esempio
https://.../speederReporterApi?date=20200620
Evento di esempio
{
  "queryStringParameters": {
    "date": "20200620"
  },
  "isBase64Encoded": false
}
Dati in streaming con AWS Kinesis e Lambda

Handler Lambda

import json, boto3
import awswrangler as wr
import pandas as pd

session = boto3.Session(aws_access_key_id = AWS_KEY, aws_secret_access_key = AWS_SECRET, region_name="us-east-1")
Dati in streaming con AWS Kinesis e Lambda

Handler Lambda

def lambda_handler(event, context):
    filter_date = event['queryStringParameters']['date']

df = wr.s3.read_csv( f"s3://sd-vehicle-data/speeders_daily/{filter_date}.csv", boto3_session=session, delimiter=" ")
Dati in streaming con AWS Kinesis e Lambda

Rispondi con i dati

def lambda_handler(event, context):
    ...
    return {
        'statusCode': 200,
        'headers': {
            "content-type" : "application/json"
        },
        'body': df.to_json()
    }
Dati in streaming con AWS Kinesis e Lambda

Risposta live

https://.../default/speederReporterApi?date=20200621
[
  {
      "record_id":"939ed1d1-1740-420c-8906-445278573c7f",
      "timestamp":"4:25:06.000",
      "vin":"4FTEX4944AK844294",
      "lon":106.9447146,
      "lat":-6.3385652,
      "speed":25
  },
  {
      "record_id":"f29a5b3d-d0fa-43c0-9e1a-e2a5cdb8be7a",
      ...
  },

  ...
]
Dati in streaming con AWS Kinesis e Lambda

Attiva un'altra Lambda

oJAqB.png

Dati in streaming con AWS Kinesis e Lambda

Attiva un'altra Lambda

def trigger_recalc():
  lambda_client = boto3.client("s3", 
                            aws_access_key_id = AWS_KEY, 
                            aws_secret_access_key = AWS_SECRET, 
                            region_name = 'us-east-1')

def lambda_handler(event, context):
  ...

Dati in streaming con AWS Kinesis e Lambda

ARN di speederAggregator

oB7uh.png

Dati in streaming con AWS Kinesis e Lambda

Invocazione

def trigger_recalc():
  ...
  lambda_client.invoke(
    FunctionName='arn:aws:lambda:us-east-1:458913182630:function:speederAggregator',
    InvocationType='Event', # (or RequestResponse)
  )
Dati in streaming con AWS Kinesis e Lambda

Riepilogo

f44P0.png

Dati in streaming con AWS Kinesis e Lambda

Riepilogo

Oi7du.png

Dati in streaming con AWS Kinesis e Lambda

Riepilogo

8yfg4.png

Dati in streaming con AWS Kinesis e Lambda

Riepilogo

BTM2Q.png

Dati in streaming con AWS Kinesis e Lambda

Passons à la pratique !

Dati in streaming con AWS Kinesis e Lambda

Preparing Video For Download...