SlideShare une entreprise Scribd logo
1  sur  17
Télécharger pour lire hors ligne
Hipster batch
making batch processing cool again
HTTP Microservices
One solution does not fit all problems
Batch processing
+
batch processing
+
REST with
hypermedia
+
metadata
=
hipster batch
REST
● Representational State Transfer
● Modelled on HTTP resource verbs (GET,
POST, PUT etc)
● No reason for resources to be dynamic
Hipster batch
Step 1:
Scheduled scale from 0 to 1
(using “autoscaling” feature)
Step 2:
Process data (CSV files, SQL query)
Hipster batch
Step 3:
Write output to S3 with hypermedia links to
allow files to be navigated by a consumer
Hipster batch
HTTP:
open(“http://some-service”) { | file | file.read }
S3:
open(“s3://some-bucket/index.json”) { | file | file.read }
{
"_links": {
"self": {
"href": "s3://rea-reporting/revenue/customer/index.json"
},
"all": [
{
"href": "s3://rea-reporting/revenue/customer/ancestry-latest-by-
month/2015-02.json"
},
{
"href": "s3://rea-reporting/revenue/customer/ancestry-latest-by-
month/2015-03.json"
}
],
"latest": {
"href": "s3://rea-
reporting/revenue/customer/ancestry/20150312_052251_2015-03.json"
}
}
}
Index
Ancestry
● JSON
● Metadata about job (time, duration, name,
status)
● Links to data files
● Links to logs
● Links to (or copy of) source data
● Includes ancestry of source data
{
"id": "20150312_050856",
"status": "success",
"name": "customer-collector",
"month": "2015-02",
"startTime": "2015-03-12T16:08:56+11:00",
"duration": 16,
"_links": {
"self": {
"href": "s3://rea-reporting/revenue/customer/ancestry/20150312_050856_2015-02.json"
},
"git": {
"href": "https://git.realestate.com.au/mad-dart/customer-collector/commit/git-hash-not-set"
},
"splunk": {
"href": "https://splunk:8000/en-US/app/search/flashtimeline?q=search%20index=mad-reporting%
20service=customer-collector%2092c056cc5996d8dad547d077cebb5c25"
},
"data": [
{
"href": "s3://rea-reporting/revenue/customer/data/20150312_050856/Customer-25-2-2015.csv.json.gz"
}
]
},
"ancestry": {
"name": "customer",
"uploader": "beth.skurrie@rea-group.com",
"_links": {
"data": {
"href": "s3://rea-reporting/revenue/customer/source/20150312_050856/Customer-25-2-2015.csv.gz"
},
"box": {
"href": "reference/customer/Customer-25-2-2015.csv"
}
}
}
}
File structure
index.json
ancestry/timestamp_1_2015-02.json
data/timestamp_1/Customers-2015-02.csv.json.gz
source/timestamp_1/Customers-2015-02.csv.gz
ancestry-latest-by-month/2015-02.json
File structure
index.json
ancestry/timestamp_1_2015-02.json
ancestry/timestamp_2_2015-02.json
data/timestamp_1/Customers-2015-02.csv.json.gz
data/timestamp_2/Customers-2015-02.csv.json.gz
source/timestamp_1/Customers-2015-02.csv.gz
source/timestamp_2/Customers-2015-02.csv.gz
ancestry-latest-by-month/2015-02.json
Why is it cool?
● Security
● Flexibility
● Auditability
You didn’t think I could do a
presentation without mentioning
Pact did you?
Contracts with non-HTTP Pact
Contract
(example data
structures)
Consumer
Correctly handles
expected data
Provider
Can produce
expected data
Questions?
@bethesque
bskurrie@dius.com.au
github.com/bethesque

Contenu connexe

En vedette (11)

77234018 vivienda-multifamiliar
77234018 vivienda-multifamiliar77234018 vivienda-multifamiliar
77234018 vivienda-multifamiliar
 
Memoria descriptiva de vivienda multifamiliar
Memoria descriptiva de vivienda multifamiliarMemoria descriptiva de vivienda multifamiliar
Memoria descriptiva de vivienda multifamiliar
 
Tipos De Vivienda
Tipos De ViviendaTipos De Vivienda
Tipos De Vivienda
 
Edificio multifamiliar sustentable
Edificio multifamiliar sustentableEdificio multifamiliar sustentable
Edificio multifamiliar sustentable
 
Memoria descrptiva
Memoria descrptivaMemoria descrptiva
Memoria descrptiva
 
MEMORIA DESCRIPTIVA INSTALACIONES ELECTRICAS
MEMORIA DESCRIPTIVA INSTALACIONES ELECTRICASMEMORIA DESCRIPTIVA INSTALACIONES ELECTRICAS
MEMORIA DESCRIPTIVA INSTALACIONES ELECTRICAS
 
PRESENTACION PROYECTO FINAL VIVIENDA MULTIFAMILIAR
PRESENTACION PROYECTO FINAL VIVIENDA MULTIFAMILIARPRESENTACION PROYECTO FINAL VIVIENDA MULTIFAMILIAR
PRESENTACION PROYECTO FINAL VIVIENDA MULTIFAMILIAR
 
Memoria descriptiva INDECI - EDIFICIO MULTIFAMILIAR 6 PISOS
Memoria descriptiva INDECI - EDIFICIO MULTIFAMILIAR 6 PISOS Memoria descriptiva INDECI - EDIFICIO MULTIFAMILIAR 6 PISOS
Memoria descriptiva INDECI - EDIFICIO MULTIFAMILIAR 6 PISOS
 
Memoria descriptiva de estructuras
Memoria descriptiva de estructurasMemoria descriptiva de estructuras
Memoria descriptiva de estructuras
 
MEMORIA DESCIRPTIVA. VIVIENDA UNIFAMILIAR
MEMORIA DESCIRPTIVA. VIVIENDA UNIFAMILIARMEMORIA DESCIRPTIVA. VIVIENDA UNIFAMILIAR
MEMORIA DESCIRPTIVA. VIVIENDA UNIFAMILIAR
 
Ejemplo memoria de calculo estructural
Ejemplo memoria de calculo estructuralEjemplo memoria de calculo estructural
Ejemplo memoria de calculo estructural
 

Dernier

Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
vu2urc
 

Dernier (20)

Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot TakeoffStrategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
Strategize a Smooth Tenant-to-tenant Migration and Copilot Takeoff
 
Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organization
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf
 
HTML Injection Attacks: Impact and Mitigation Strategies
HTML Injection Attacks: Impact and Mitigation StrategiesHTML Injection Attacks: Impact and Mitigation Strategies
HTML Injection Attacks: Impact and Mitigation Strategies
 
Developing An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of BrazilDeveloping An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of Brazil
 
GenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdfGenAI Risks & Security Meetup 01052024.pdf
GenAI Risks & Security Meetup 01052024.pdf
 
Real Time Object Detection Using Open CV
Real Time Object Detection Using Open CVReal Time Object Detection Using Open CV
Real Time Object Detection Using Open CV
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data DiscoveryTrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
TrustArc Webinar - Unlock the Power of AI-Driven Data Discovery
 
Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024Partners Life - Insurer Innovation Award 2024
Partners Life - Insurer Innovation Award 2024
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
Boost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivityBoost PC performance: How more available memory can improve productivity
Boost PC performance: How more available memory can improve productivity
 
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...Workshop - Best of Both Worlds_ Combine  KG and Vector search for  enhanced R...
Workshop - Best of Both Worlds_ Combine KG and Vector search for enhanced R...
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?What Are The Drone Anti-jamming Systems Technology?
What Are The Drone Anti-jamming Systems Technology?
 
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time AutomationFrom Event to Action: Accelerate Your Decision Making with Real-Time Automation
From Event to Action: Accelerate Your Decision Making with Real-Time Automation
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Script
 
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
Connector Corner: Accelerate revenue generation using UiPath API-centric busi...
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
 

Hipster batch - making batch processing cool again