After Width: | Height: | Size: 57 KiB |
After Width: | Height: | Size: 162 KiB |
After Width: | Height: | Size: 73 KiB |
After Width: | Height: | Size: 70 KiB |
After Width: | Height: | Size: 54 KiB |
After Width: | Height: | Size: 136 KiB |
After Width: | Height: | Size: 204 KiB |
After Width: | Height: | Size: 77 KiB |
After Width: | Height: | Size: 235 KiB |
After Width: | Height: | Size: 130 KiB |
After Width: | Height: | Size: 77 KiB |
After Width: | Height: | Size: 67 KiB |
After Width: | Height: | Size: 46 KiB |
After Width: | Height: | Size: 59 KiB |
After Width: | Height: | Size: 164 KiB |
After Width: | Height: | Size: 90 KiB |
After Width: | Height: | Size: 128 KiB |
After Width: | Height: | Size: 116 KiB |
After Width: | Height: | Size: 154 KiB |
After Width: | Height: | Size: 157 KiB |
After Width: | Height: | Size: 124 KiB |
After Width: | Height: | Size: 40 KiB |
After Width: | Height: | Size: 57 KiB |
After Width: | Height: | Size: 43 KiB |
After Width: | Height: | Size: 371 KiB |
After Width: | Height: | Size: 101 KiB |
After Width: | Height: | Size: 82 KiB |
After Width: | Height: | Size: 128 KiB |
After Width: | Height: | Size: 172 KiB |
After Width: | Height: | Size: 80 KiB |
After Width: | Height: | Size: 128 KiB |
After Width: | Height: | Size: 122 KiB |
After Width: | Height: | Size: 66 KiB |
After Width: | Height: | Size: 61 KiB |
After Width: | Height: | Size: 100 KiB |
After Width: | Height: | Size: 75 KiB |
After Width: | Height: | Size: 78 KiB |
After Width: | Height: | Size: 86 KiB |
After Width: | Height: | Size: 70 KiB |
After Width: | Height: | Size: 253 KiB |
After Width: | Height: | Size: 105 KiB |
After Width: | Height: | Size: 134 KiB |
After Width: | Height: | Size: 80 KiB |
After Width: | Height: | Size: 106 KiB |
After Width: | Height: | Size: 120 KiB |
After Width: | Height: | Size: 126 KiB |
After Width: | Height: | Size: 91 KiB |
After Width: | Height: | Size: 107 KiB |
After Width: | Height: | Size: 82 KiB |
After Width: | Height: | Size: 64 KiB |
After Width: | Height: | Size: 79 KiB |
After Width: | Height: | Size: 65 KiB |
After Width: | Height: | Size: 90 KiB |
After Width: | Height: | Size: 69 KiB |
After Width: | Height: | Size: 50 KiB |
@ -0,0 +1,503 @@
|
||||
<!doctype html> |
||||
<html lang="en"> |
||||
<head> |
||||
<meta charset="utf-8"> |
||||
|
||||
<title>Flink Forward 2018</title> |
||||
|
||||
<meta name="description" content="Colocando uma aplicação Flask em produção em 40 minutos (ou menos)"> |
||||
<meta name="author" content="Julio Biason"> |
||||
|
||||
<meta name="apple-mobile-web-app-capable" content="yes"> |
||||
<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent"> |
||||
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no, minimal-ui"> |
||||
|
||||
<link rel="stylesheet" href="reveal.js/css/reveal.css"> |
||||
<link rel="stylesheet" href="theme/azion.css" id="theme"> |
||||
|
||||
<!-- Code syntax highlighting --> |
||||
<link rel="stylesheet" href="reveal.js/lib/css/zenburn.css"> |
||||
|
||||
<!-- Printing and PDF exports --> |
||||
<script> |
||||
var link = document.createElement( 'link' ); |
||||
link.rel = 'stylesheet'; |
||||
link.type = 'text/css'; |
||||
link.href = window.location.search.match( /print-pdf/gi ) ? 'css/print/pdf.css' : 'css/print/paper.css'; |
||||
document.getElementsByTagName( 'head' )[0].appendChild( link ); |
||||
</script> |
||||
|
||||
<!--[if lt IE 9]> |
||||
<script src="lib/js/html5shiv.js"></script> |
||||
<![endif]--> |
||||
|
||||
<style type="text/css" media="screen"> |
||||
.happy { |
||||
color: yellow; |
||||
} |
||||
|
||||
.reveal section img { |
||||
border: none; |
||||
} |
||||
|
||||
.reveal ul.empty { |
||||
list-style: none outside; |
||||
} |
||||
|
||||
li { |
||||
display: block; |
||||
} |
||||
|
||||
.cursor { |
||||
background-color: #666; |
||||
color: white; |
||||
} |
||||
|
||||
img { |
||||
max-height: 90%; |
||||
} |
||||
|
||||
td.seen { |
||||
font-style: italic; |
||||
font-weight: bold; |
||||
} |
||||
</style> |
||||
</head> |
||||
|
||||
<body> |
||||
<div class="reveal"> |
||||
<div class="slides"> |
||||
<section> |
||||
<section data-background="_images/ff_logo.png" data-tile> |
||||
<h1 class="semi-opaque"> |
||||
Flink Forward 2018 |
||||
</h1> |
||||
</section> |
||||
</section> |
||||
|
||||
<section> |
||||
<section data-background="_images/ff_dayone.jpg"> |
||||
</section> |
||||
|
||||
<section data-background="_images/ff_watermarks0.png"> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_watermark1.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_watermark2.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_watermark3.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_watermark4.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_watermark5.png" alt=""/> |
||||
</section> |
||||
|
||||
<section data-background="_images/ff_broadcast0.png"></section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_broadcast1.png" alt=""/> |
||||
</section> |
||||
|
||||
<section data-background="_images/ff_state0.png"></section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_state1.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_state2.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_state3.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_state4.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_state5.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_state6.png" alt=""/> |
||||
</section> |
||||
|
||||
<!-- Testing Harnesses for Operators --> |
||||
<section data-background="_images/ff_harness0.png"></section> |
||||
<section> |
||||
<img src="_images/ff_harness1.png" alt=""/> |
||||
</section> |
||||
|
||||
<!-- State and Schema Migration --> |
||||
<section data-background="_images/ff_migration0.png"></section> |
||||
<section> |
||||
<img src="_images/ff_migration1.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_migration2.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_migration3.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_migration4.png" alt=""/> |
||||
</section> |
||||
|
||||
<!-- Exactly-Once Processing --> |
||||
<section data-background="_images/ff_exactlyonce0.png"></section> |
||||
<section> |
||||
<img src="_images/ff_exactlyonce1.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_exactlyonce2.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_exactlyonce3.png" alt=""/> |
||||
</section> |
||||
|
||||
<!-- Deployment and FLIP-6 --> |
||||
<section data-background="_images/ff_flip60.png"></section> |
||||
<section> |
||||
<img src="_images/ff_flip61.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_flip62.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_flip63.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_flip64.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_flip65.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_flip66.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_flip67.png" alt=""/> |
||||
</section> |
||||
|
||||
<!-- Running Flink 24-7 --> |
||||
<section data-background="_images/ff_capacity0.png"></section> |
||||
<section> |
||||
<img src="_images/ff_capacity1.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_capacity2.png" alt=""/> |
||||
</section> |
||||
|
||||
<!-- Metrics, Monitoring and Troubleshooting --> |
||||
<section data-background="_images/ff_monitoring0.png"></section> |
||||
<section> |
||||
<img src="_images/ff_monitoring1.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_monitoring2.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_monitoring3.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_monitoring4.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_monitoring5.png" alt=""/> |
||||
</section> |
||||
<section> |
||||
<img src="_images/ff_monitoring6.png" alt=""/> |
||||
</section> |
||||
</section> |
||||
|
||||
<section> |
||||
<section data-background="_images/ff_daytwo.jpg"> |
||||
</section> |
||||
|
||||
<section> |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>Keynotes</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
<tr> |
||||
<td> |
||||
What turns stream processing from a tool into a platform?<br/> |
||||
<small>Stephan Ewen, data Artisans</small> |
||||
</td> |
||||
</tr> |
||||
|
||||
<tr> |
||||
<td> |
||||
Stream Processing Revolutionizing Big Data<br/> |
||||
<small> |
||||
Srikanth Satya, Dell EMC |
||||
</small> |
||||
</td> |
||||
</tr> |
||||
|
||||
<tr> |
||||
<td> |
||||
Apache Flink + Apache Beam: Expanding the horizons of Big Data<br/> |
||||
<small> |
||||
Anand Iyer, Google Cloud |
||||
</small> |
||||
</td> |
||||
</tr> |
||||
</tbody> |
||||
</table> |
||||
</section> |
||||
|
||||
<section> |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>11:00</th> |
||||
</tr> |
||||
</thead> |
||||
<tbody> |
||||
<tr> |
||||
<td> |
||||
Powering Yelp’s Data Pipeline Infrastructure with Apache Flink</br><small>Enrico Canzonieri, Yelp Inc.</small> |
||||
</td> |
||||
</tr> |
||||
|
||||
<tr> |
||||
<td class="seen"> |
||||
Scaling stream data pipelines <br/><small>Flavio Junqueira, Pravega by DellEMC</small> |
||||
</td> |
||||
|
||||
<aside class="notes"> |
||||
- Pravega |
||||
- Kinda like Kafka |
||||
- Auto-partition |
||||
- When a partition is created or destroyed a Flink TaskManager is created/destroyed |
||||
- Pravega requires a key already |
||||
</aside> |
||||
</tr> |
||||
|
||||
<tr> |
||||
<td> |
||||
Building a scalable focused web crawler with Flink <br/><small>Ken Krugler, Scale Unlimited</small> |
||||
</td> |
||||
</tr> |
||||
</tbody> |
||||
</table> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_pravega.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<table> |
||||
<thead> |
||||
<tr> |
||||
<th>11:50</th> |
||||
</tr> |
||||
</thead> |
||||
|
||||
<tbody> |
||||
<tr> |
||||
<td>Building Flink As a Service platform at Uber</br><small>Shuyi Chen, Uber</small></td> |
||||
</tr> |
||||
|
||||
<tr> |
||||
<td class="seen">eBay monitoring platform preprocessing and alerting on Flink</br><small>Garret Li, ebay</small></td> |
||||
<aside class="notes"> |
||||
- Sherlock.IO |
||||
- "The Frink", nervous |
||||
- Policy changes go through the pipeline |
||||
- https://vimeo.com/265025956/c7d5576622 |
||||
</aside> |
||||
</tr> |
||||
|
||||
<tr> |
||||
<td>Using Flink for balances and controls across platform boundaries<br/><small>Faraz Babar, American Express</small></td> |
||||
</tr> |
||||
</tbody> |
||||
</table> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_sherlock.jpg" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_sherlock_policy.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<table> |
||||
<thead> |
||||
<tr><th>12:20</th></tr> |
||||
</thead> |
||||
|
||||
<tbody> |
||||
<tr><td>Scaling Flink in Cloud<br/><small>Steven Wu, Netflix</small></td></tr> |
||||
<tr><td>Flink real-time analysis in CloudStream Service of Huawei Cloud<br/><small>Jinkui Shi, Huawei</small></td></tr> |
||||
<tr> |
||||
<td class="seen">Why and how to leverage the simplicity and power of SQL on Flink<br/><small>Fabian Hueske, data Artisans</small></td> |
||||
<aside class="notes"> |
||||
- Built-in in Flink 1.5 |
||||
- Can create pipelines on the fly |
||||
- Launches TaskManagers |
||||
</aside> |
||||
</tr> |
||||
</tbody> |
||||
</table> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_sql.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<table> |
||||
<thead><tr><th>2:00</th></tr></thead> |
||||
<tbody> |
||||
<tr><td>Optimizations in Blink Runtime for Global Shopping Festival at Alibaba<br><small>Feng Wang, Alibaba </small></td></tr> |
||||
<tr> |
||||
<td class="seen">Bootstrapping State In Apache Flink<br/><small>Gregory Fee, Lyft </small></td> |
||||
<aside class="notes"> |
||||
- Lyft |
||||
- Grouping all information, including old ones |
||||
- Required for information of all rides of all users over all the time |
||||
- Old data on S3, new data on Kafka |
||||
- Multiple inputs |
||||
- Old input will hold new input |
||||
</aside> |
||||
</tr> |
||||
<tr><td>Panta Rhei: designing distributed applications with streams<br/><small> Aris Koliopoulos, Drivetribe </small></td></tr> |
||||
</tbody> |
||||
</table> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_lyft.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<table> |
||||
<thead><tr><th>2:50</th></tr></thead> |
||||
<tbody> |
||||
<tr><td> Powering Tensorflor with Big Data (Apache BEAM & Flink) <br/><small> Holden Karau, Google Cloud </small></td></tr> |
||||
<tr><td class="seen">Alibaba’s common algorithm platform on Flink<br/><small> Xu Yang, Alibaba </small></td></tr> |
||||
<tr><td> Cloud Native Flink <br/><small> Jowanza Joseph, One Click Retail </small></td></tr> |
||||
</tbody> |
||||
</table> |
||||
</section> |
||||
|
||||
<section> |
||||
<table> |
||||
<thead><tr><th>3:20</th></tr></thead> |
||||
<tbody> |
||||
<tr><td> Embedding Flink Throughout an Operationalized Streaming ML Lifecycle <br/><small> Dave Torok, Comcast Corporation </small></td></tr> |
||||
<tr><td>Scaling Uber’s Realtime Optimization with Apache Flink <br/><small> Xingzhong Xu, Uber Technologies Inc. </small></td></tr> |
||||
<tr> |
||||
<td class="seen"> Operating Flink on Mesos at Scale <br/><small> Jörg Schad, Mesosphere </small></td> |
||||
<aside class="notes"> |
||||
- Basically, the same Kubernetes does |
||||
- Use of Kube or Mesos is a personal choice |
||||
</aside> |
||||
</tr> |
||||
</tbody> |
||||
</table> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_mesos.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<table> |
||||
<thead><tr><th>4:30</th></tr></thead> |
||||
<tbody> |
||||
<tr> |
||||
<td class="seen"> Finding Bad Acorns <br/><small> Andrew Gao, Capital One </small></td> |
||||
<aside class="notes"> |
||||
- Teller validation |
||||
- Python integration (because data scientists use Jupyter) |
||||
- Queryable state |
||||
- Broke the monolith |
||||
</aside> |
||||
</tr> |
||||
<tr><td> dA Platform – Production-ready stream processing with Apache Flink <br/><small> Robert Metzger, data Artisans </small></td></tr> |
||||
<tr><td> Real-time monitoring of Mobile Internet Quality of Experience using Flink <br/><small> David Reniz, Everis </small></td></tr> |
||||
</tbody> |
||||
</table> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_acorns_python.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<img src="_images/ff_acorns_state.png" alt=""/> |
||||
</section> |
||||
|
||||
<section> |
||||
<table> |
||||
<thead><tr><th>5:20</th></tr></thead> |
||||
<tbody> |
||||
<tr><td> How to build a modern stream processor: The science behind Apache Flink <br/><small> Stefan Richter, data Artisans </small></td></tr> |
||||
<tr> |
||||
<td class="seen"> Testing Stateful Streaming Applications <br/><small> Seth Wiesman, MediaMath </small></td> |
||||
<aside class="notes"> |
||||
- Math guy |
||||
- Test pipeline, break pipeline to test checkpoint |
||||
- WHYYYYY?!?!?! |
||||
</aside> |
||||
</tr> |
||||
<tr><td> Extending Flink metrics: Real-time BI atop existing Flink streaming pipelines <br/><small> Andrew Torson, Walmart Labs </small></td></tr> |
||||
</tbody> |
||||
</table> |
||||
</section> |
||||
</section> |
||||
</div> |
||||
</div> |
||||
|
||||
<script src="reveal.js/lib/js/head.min.js"></script> |
||||
<script src="reveal.js/js/reveal.js"></script> |
||||
|
||||
<script> |
||||
// Full list of configuration options available at: |
||||
// https://github.com/hakimel/reveal.js#configuration |
||||
Reveal.initialize({ |
||||
controls: true, |
||||
progress: true, |
||||
history: true, |
||||
center: true, |
||||
// showNotes: true, |
||||
|
||||
transition: 'slide', // none/fade/slide/convex/concave/zoom |
||||
|
||||
// Optional reveal.js plugins |
||||
dependencies: [ |
||||
{ src: 'reveal.js/lib/js/classList.js', condition: function() { return !document.body.classList; } }, |
||||
{ src: 'reveal.js/plugin/markdown/marked.js', condition: function() { return !!document.querySelector( '[data-markdown]' ); } }, |
||||
{ src: 'reveal.js/plugin/markdown/markdown.js', condition: function() { return !!document.querySelector( '[data-markdown]' ); } }, |
||||
{ src: 'reveal.js/plugin/highlight/highlight.js', async: true, callback: function() { hljs.initHighlightingOnLoad(); } }, |
||||
{ src: 'reveal.js/plugin/zoom-js/zoom.js', async: true }, |
||||
{ src: 'reveal.js/plugin/notes/notes.js', async: true } |
||||
] |
||||
}); |
||||
</script> |
||||
|
||||
</body> |
||||
</html> |