[hotfix] Manual build of docs

This is temporary until the CI server is back up again. Please remove all added 
files then.

https://blogs.apache.org/infra/entry/buildbot_master_currently_off_line


Project: http://git-wip-us.apache.org/repos/asf/flink-web/repo
Commit: http://git-wip-us.apache.org/repos/asf/flink-web/commit/396616d4
Tree: http://git-wip-us.apache.org/repos/asf/flink-web/tree/396616d4
Diff: http://git-wip-us.apache.org/repos/asf/flink-web/diff/396616d4

Branch: refs/heads/asf-site
Commit: 396616d4462e220644f55a4eac1d95d75d4de272
Parents: 6186435
Author: Ufuk Celebi <[email protected]>
Authored: Tue Jun 30 12:14:14 2015 +0200
Committer: Ufuk Celebi <[email protected]>
Committed: Tue Jun 30 12:14:15 2015 +0200

----------------------------------------------------------------------
 _config.yml                                     |    7 +-
 _includes/navbar.html                           |   10 +-
 content/blog/feed.xml                           |   74 +-
 content/blog/index.html                         |   22 +-
 content/blog/page2/index.html                   |   22 +-
 content/blog/page3/index.html                   |   24 +-
 content/blog/page4/index.html                   |   22 +-
 content/coding-guidelines.html                  |   22 +-
 content/community.html                          |   40 +-
 content/docs/0.9/README.md                      |   60 +
 content/docs/0.9/apis/best_practices.html       |  411 +++
 content/docs/0.9/apis/cli.html                  |  394 ++
 content/docs/0.9/apis/cluster_execution.html    |  345 ++
 .../docs/0.9/apis/dataset_transformations.html  | 1720 +++++++++
 content/docs/0.9/apis/example_connectors.html   |  404 +++
 content/docs/0.9/apis/examples.html             |  681 ++++
 content/docs/0.9/apis/fig/LICENSE.txt           |   17 +
 .../fig/iterations_delta_iterate_operator.png   |  Bin 0 -> 113607 bytes
 ...terations_delta_iterate_operator_example.png |  Bin 0 -> 335057 bytes
 .../apis/fig/iterations_iterate_operator.png    |  Bin 0 -> 63465 bytes
 .../fig/iterations_iterate_operator_example.png |  Bin 0 -> 102925 bytes
 .../docs/0.9/apis/fig/iterations_supersteps.png |  Bin 0 -> 54098 bytes
 content/docs/0.9/apis/fig/plan_visualizer.png   |  Bin 0 -> 145778 bytes
 content/docs/0.9/apis/hadoop_compatibility.html |  423 +++
 content/docs/0.9/apis/index.html                |  205 ++
 content/docs/0.9/apis/iterations.html           |  399 ++
 content/docs/0.9/apis/java8.html                |  360 ++
 content/docs/0.9/apis/local_execution.html      |  302 ++
 content/docs/0.9/apis/programming_guide.html    | 3433 ++++++++++++++++++
 content/docs/0.9/apis/python.html               |  764 ++++
 content/docs/0.9/apis/streaming_guide.html      | 1944 ++++++++++
 content/docs/0.9/apis/web_client.html           |  272 ++
 content/docs/0.9/build_docs.sh                  |   64 +
 content/docs/0.9/faq.html                       |  606 ++++
 content/docs/0.9/fig/LICENSE.txt                |   17 +
 content/docs/0.9/fig/overview-stack-0.9.png     |  Bin 0 -> 260807 bytes
 content/docs/0.9/index.html                     |  248 ++
 content/docs/0.9/internals/add_operator.html    |  431 +++
 .../docs/0.9/internals/coding_guidelines.html   |  207 ++
 content/docs/0.9/internals/fig/ClientJmTm.svg   |  348 ++
 content/docs/0.9/internals/fig/LICENSE.txt      |   17 +
 .../internals/fig/job_and_execution_graph.svg   |  851 +++++
 .../0.9/internals/fig/projects_dependencies.svg |  586 +++
 content/docs/0.9/internals/fig/slots.svg        |  505 +++
 content/docs/0.9/internals/fig/stack.svg        |  606 ++++
 .../docs/0.9/internals/fig/state_machine.svg    |  318 ++
 content/docs/0.9/internals/general_arch.html    |  285 ++
 .../docs/0.9/internals/how_to_contribute.html   |  207 ++
 content/docs/0.9/internals/ide_setup.html       |  328 ++
 content/docs/0.9/internals/index.html           |  205 ++
 content/docs/0.9/internals/job_scheduling.html  |  265 ++
 content/docs/0.9/internals/logging.html         |  273 ++
 .../docs/0.9/internals/types_serialization.html |  438 +++
 content/docs/0.9/libs/fig/LICENSE.txt           |   17 +
 .../docs/0.9/libs/fig/gelly-example-graph.png   |  Bin 0 -> 18813 bytes
 content/docs/0.9/libs/fig/gelly-filter.png      |  Bin 0 -> 57192 bytes
 .../docs/0.9/libs/fig/gelly-gsa-sssp-result.png |  Bin 0 -> 14472 bytes
 content/docs/0.9/libs/fig/gelly-gsa-sssp1.png   |  Bin 0 -> 33476 bytes
 content/docs/0.9/libs/fig/gelly-gsa-sssp2.png   |  Bin 0 -> 24962 bytes
 .../docs/0.9/libs/fig/gelly-reduceOnEdges.png   |  Bin 0 -> 23843 bytes
 .../0.9/libs/fig/gelly-reduceOnNeighbors.png    |  Bin 0 -> 34903 bytes
 content/docs/0.9/libs/fig/gelly-union.png       |  Bin 0 -> 50498 bytes
 content/docs/0.9/libs/fig/gelly-vc-sssp1.png    |  Bin 0 -> 30470 bytes
 content/docs/0.9/libs/fig/gelly-vc-sssp2.png    |  Bin 0 -> 24644 bytes
 content/docs/0.9/libs/fig/spargel_example.png   |  Bin 0 -> 199032 bytes
 .../docs/0.9/libs/fig/spargel_example_input.png |  Bin 0 -> 113478 bytes
 content/docs/0.9/libs/gelly_guide.html          | 1045 ++++++
 content/docs/0.9/libs/index.html                |  205 ++
 content/docs/0.9/libs/ml/als.html               |  401 ++
 .../docs/0.9/libs/ml/contribution_guide.html    |  325 ++
 content/docs/0.9/libs/ml/distance_metrics.html  |  325 ++
 content/docs/0.9/libs/ml/index.html             |  322 ++
 content/docs/0.9/libs/ml/min_max_scaler.html    |  339 ++
 .../0.9/libs/ml/multiple_linear_regression.html |  380 ++
 content/docs/0.9/libs/ml/optimization.html      |  513 +++
 content/docs/0.9/libs/ml/pipelines.html         |  638 ++++
 .../docs/0.9/libs/ml/polynomial_features.html   |  333 ++
 content/docs/0.9/libs/ml/quickstart.html        |  438 +++
 content/docs/0.9/libs/ml/standard_scaler.html   |  340 ++
 content/docs/0.9/libs/ml/svm.html               |  419 +++
 content/docs/0.9/libs/ml/vision_roadmap.html    |  313 ++
 content/docs/0.9/libs/spargel_guide.html        |  313 ++
 content/docs/0.9/libs/table.html                |  302 ++
 content/docs/0.9/page/css/codetabs.css          |   62 +
 content/docs/0.9/page/css/flink.css             |  123 +
 content/docs/0.9/page/css/syntax.css            |   79 +
 content/docs/0.9/page/favicon.ico               |  Bin 0 -> 1150 bytes
 content/docs/0.9/page/img/LICENSE.txt           |   17 +
 content/docs/0.9/page/img/navbar-brand-logo.jpg |  Bin 0 -> 18470 bytes
 .../compiler-webclient-new.png                  |  Bin 0 -> 134963 bytes
 .../jobmanager-running-new.png                  |  Bin 0 -> 132859 bytes
 .../page/img/quickstart-example/kmeans003.png   |  Bin 0 -> 27962 bytes
 .../page/img/quickstart-example/kmeans008.png   |  Bin 0 -> 39305 bytes
 .../page/img/quickstart-example/kmeans015.png   |  Bin 0 -> 41958 bytes
 .../page/img/quickstart-example/result003.png   |  Bin 0 -> 60228 bytes
 .../page/img/quickstart-example/result008.png   |  Bin 0 -> 92732 bytes
 .../page/img/quickstart-example/result015.png   |  Bin 0 -> 89724 bytes
 .../img/quickstart-example/run-webclient.png    |  Bin 0 -> 89469 bytes
 .../docs/0.9/page/img/quickstart_cluster.png    |  Bin 0 -> 83790 bytes
 content/docs/0.9/page/js/codetabs.js            |  121 +
 .../0.9/quickstart/java_api_quickstart.html     |  330 ++
 content/docs/0.9/quickstart/plotPoints.py       |  100 +
 .../0.9/quickstart/run_example_quickstart.html  |  359 ++
 .../0.9/quickstart/scala_api_quickstart.html    |  334 ++
 .../docs/0.9/quickstart/setup_quickstart.html   |  350 ++
 content/docs/0.9/scala_shell.html               |  244 ++
 content/docs/0.9/search-results.html            |  219 ++
 content/docs/0.9/setup/building.html            |  273 ++
 content/docs/0.9/setup/cluster_setup.html       |  528 +++
 content/docs/0.9/setup/config.html              |  639 ++++
 content/docs/0.9/setup/fig/FlinkOnYarn.svg      |  151 +
 content/docs/0.9/setup/fig/LICENSE.txt          |   17 +
 .../0.9/setup/fig/flink_on_tez_translation.png  |  Bin 0 -> 350867 bytes
 content/docs/0.9/setup/fig/flink_tez_vertex.png |  Bin 0 -> 105544 bytes
 .../docs/0.9/setup/fig/slots_parallelism.svg    |  695 ++++
 content/docs/0.9/setup/flink_on_tez.html        |  486 +++
 content/docs/0.9/setup/gce_setup.html           |  289 ++
 content/docs/0.9/setup/index.html               |  205 ++
 content/docs/0.9/setup/local_setup.html         |  324 ++
 content/docs/0.9/setup/yarn_setup.html          |  443 +++
 content/docs/master/README.md                   |   60 +
 content/docs/master/apis/best_practices.html    |  411 +++
 content/docs/master/apis/cli.html               |  394 ++
 content/docs/master/apis/cluster_execution.html |  345 ++
 .../master/apis/dataset_transformations.html    | 1722 +++++++++
 .../docs/master/apis/example_connectors.html    |  404 +++
 content/docs/master/apis/examples.html          |  681 ++++
 content/docs/master/apis/fig/LICENSE.txt        |   17 +
 .../fig/iterations_delta_iterate_operator.png   |  Bin 0 -> 113607 bytes
 ...terations_delta_iterate_operator_example.png |  Bin 0 -> 335057 bytes
 .../apis/fig/iterations_iterate_operator.png    |  Bin 0 -> 63465 bytes
 .../fig/iterations_iterate_operator_example.png |  Bin 0 -> 102925 bytes
 .../master/apis/fig/iterations_supersteps.png   |  Bin 0 -> 54098 bytes
 .../docs/master/apis/fig/plan_visualizer.png    |  Bin 0 -> 145778 bytes
 .../docs/master/apis/hadoop_compatibility.html  |  423 +++
 content/docs/master/apis/index.html             |  205 ++
 content/docs/master/apis/iterations.html        |  399 ++
 content/docs/master/apis/java8.html             |  360 ++
 content/docs/master/apis/local_execution.html   |  302 ++
 content/docs/master/apis/programming_guide.html | 3433 ++++++++++++++++++
 content/docs/master/apis/python.html            |  764 ++++
 content/docs/master/apis/streaming_guide.html   | 2007 ++++++++++
 content/docs/master/apis/web_client.html        |  272 ++
 .../docs/master/apis/zip_elements_guide.html    |  251 ++
 content/docs/master/build_docs.sh               |   64 +
 content/docs/master/faq.html                    |  606 ++++
 content/docs/master/fig/LICENSE.txt             |   17 +
 content/docs/master/fig/overview-stack-0.9.png  |  Bin 0 -> 260807 bytes
 content/docs/master/index.html                  |  248 ++
 content/docs/master/internals/add_operator.html |  431 +++
 .../master/internals/coding_guidelines.html     |  207 ++
 .../docs/master/internals/fig/ClientJmTm.svg    |  348 ++
 content/docs/master/internals/fig/LICENSE.txt   |   17 +
 .../internals/fig/job_and_execution_graph.svg   |  851 +++++
 .../internals/fig/projects_dependencies.svg     |  586 +++
 content/docs/master/internals/fig/slots.svg     |  505 +++
 content/docs/master/internals/fig/stack.svg     |  606 ++++
 .../docs/master/internals/fig/state_machine.svg |  318 ++
 content/docs/master/internals/general_arch.html |  285 ++
 .../master/internals/how_to_contribute.html     |  207 ++
 content/docs/master/internals/ide_setup.html    |  328 ++
 content/docs/master/internals/index.html        |  205 ++
 .../docs/master/internals/job_scheduling.html   |  265 ++
 content/docs/master/internals/logging.html      |  273 ++
 .../master/internals/types_serialization.html   |  438 +++
 content/docs/master/libs/fig/LICENSE.txt        |   17 +
 .../master/libs/fig/gelly-example-graph.png     |  Bin 0 -> 18813 bytes
 content/docs/master/libs/fig/gelly-filter.png   |  Bin 0 -> 57192 bytes
 .../master/libs/fig/gelly-gsa-sssp-result.png   |  Bin 0 -> 14472 bytes
 .../docs/master/libs/fig/gelly-gsa-sssp1.png    |  Bin 0 -> 33476 bytes
 .../docs/master/libs/fig/gelly-gsa-sssp2.png    |  Bin 0 -> 24962 bytes
 .../master/libs/fig/gelly-reduceOnEdges.png     |  Bin 0 -> 23843 bytes
 .../master/libs/fig/gelly-reduceOnNeighbors.png |  Bin 0 -> 34903 bytes
 content/docs/master/libs/fig/gelly-union.png    |  Bin 0 -> 50498 bytes
 content/docs/master/libs/fig/gelly-vc-sssp1.png |  Bin 0 -> 30470 bytes
 content/docs/master/libs/fig/gelly-vc-sssp2.png |  Bin 0 -> 24644 bytes
 .../docs/master/libs/fig/spargel_example.png    |  Bin 0 -> 199032 bytes
 .../master/libs/fig/spargel_example_input.png   |  Bin 0 -> 113478 bytes
 content/docs/master/libs/gelly_guide.html       | 1090 ++++++
 content/docs/master/libs/index.html             |  205 ++
 content/docs/master/libs/ml/als.html            |  401 ++
 .../docs/master/libs/ml/contribution_guide.html |  325 ++
 .../docs/master/libs/ml/distance_metrics.html   |  325 ++
 content/docs/master/libs/ml/index.html          |  322 ++
 content/docs/master/libs/ml/min_max_scaler.html |  339 ++
 .../libs/ml/multiple_linear_regression.html     |  380 ++
 content/docs/master/libs/ml/optimization.html   |  513 +++
 content/docs/master/libs/ml/pipelines.html      |  638 ++++
 .../master/libs/ml/polynomial_features.html     |  333 ++
 content/docs/master/libs/ml/quickstart.html     |  438 +++
 .../docs/master/libs/ml/standard_scaler.html    |  340 ++
 content/docs/master/libs/ml/svm.html            |  419 +++
 content/docs/master/libs/ml/vision_roadmap.html |  313 ++
 content/docs/master/libs/spargel_guide.html     |  313 ++
 content/docs/master/libs/table.html             |  302 ++
 content/docs/master/page/css/codetabs.css       |   62 +
 content/docs/master/page/css/flink.css          |  123 +
 content/docs/master/page/css/syntax.css         |   79 +
 content/docs/master/page/favicon.ico            |  Bin 0 -> 1150 bytes
 content/docs/master/page/img/LICENSE.txt        |   17 +
 .../docs/master/page/img/navbar-brand-logo.jpg  |  Bin 0 -> 18470 bytes
 .../compiler-webclient-new.png                  |  Bin 0 -> 134963 bytes
 .../jobmanager-running-new.png                  |  Bin 0 -> 132859 bytes
 .../page/img/quickstart-example/kmeans003.png   |  Bin 0 -> 27962 bytes
 .../page/img/quickstart-example/kmeans008.png   |  Bin 0 -> 39305 bytes
 .../page/img/quickstart-example/kmeans015.png   |  Bin 0 -> 41958 bytes
 .../page/img/quickstart-example/result003.png   |  Bin 0 -> 60228 bytes
 .../page/img/quickstart-example/result008.png   |  Bin 0 -> 92732 bytes
 .../page/img/quickstart-example/result015.png   |  Bin 0 -> 89724 bytes
 .../img/quickstart-example/run-webclient.png    |  Bin 0 -> 89469 bytes
 .../docs/master/page/img/quickstart_cluster.png |  Bin 0 -> 83790 bytes
 content/docs/master/page/js/codetabs.js         |  121 +
 .../master/quickstart/java_api_quickstart.html  |  330 ++
 content/docs/master/quickstart/plotPoints.py    |  100 +
 .../quickstart/run_example_quickstart.html      |  359 ++
 .../master/quickstart/scala_api_quickstart.html |  334 ++
 .../master/quickstart/setup_quickstart.html     |  350 ++
 content/docs/master/scala_shell.html            |  244 ++
 content/docs/master/search-results.html         |  219 ++
 content/docs/master/setup/building.html         |  273 ++
 content/docs/master/setup/cluster_setup.html    |  528 +++
 content/docs/master/setup/config.html           |  639 ++++
 content/docs/master/setup/fig/FlinkOnYarn.svg   |  151 +
 content/docs/master/setup/fig/LICENSE.txt       |   17 +
 .../setup/fig/flink_on_tez_translation.png      |  Bin 0 -> 350867 bytes
 .../docs/master/setup/fig/flink_tez_vertex.png  |  Bin 0 -> 105544 bytes
 .../docs/master/setup/fig/slots_parallelism.svg |  695 ++++
 content/docs/master/setup/flink_on_tez.html     |  486 +++
 content/docs/master/setup/gce_setup.html        |  289 ++
 content/docs/master/setup/index.html            |  205 ++
 content/docs/master/setup/local_setup.html      |  324 ++
 content/docs/master/setup/yarn_setup.html       |  445 +++
 content/downloads.html                          |   28 +-
 content/faq.html                                |   74 +-
 content/features.html                           |   22 +-
 content/how-to-contribute.html                  |   42 +-
 content/index.html                              |   28 +-
 content/material.html                           |   32 +-
 content/news/2012/08/21/release02.html          |   22 +-
 content/news/2012/10/15/icde2013.html           |   22 +-
 content/news/2012/11/12/btw2013demo.html        |   22 +-
 content/news/2012/11/21/previewICDE2013.html    |   22 +-
 content/news/2013/03/27/www-demo-paper.html     |   22 +-
 content/news/2013/10/21/cikm2013-paper.html     |   22 +-
 .../2013/12/13/humboldt-innovation-award.html   |   22 +-
 .../2014/01/10/stratosphere-hadoop-summit.html  |   22 +-
 .../news/2014/01/12/0.4-migration-guide.html    |   22 +-
 .../2014/01/13/stratosphere-release-0.4.html    |   28 +-
 .../26/optimizer_plan_visualization_tool.html   |   22 +-
 content/news/2014/01/28/querying_mongodb.html   |   22 +-
 .../18/amazon-elastic-mapreduce-cloud-yarn.html |   28 +-
 ...stratosphere-google-summer-of-code-2014.html |   22 +-
 .../16/stratosphere-goes-apache-incubator.html  |   22 +-
 content/news/2014/05/31/release-0.5.html        |   22 +-
 content/news/2014/08/26/release-0.6.html        |   22 +-
 content/news/2014/09/26/release-0.6.1.html      |   22 +-
 content/news/2014/10/03/upcoming_events.html    |   22 +-
 content/news/2014/11/04/release-0.7.0.html      |   24 +-
 .../news/2014/11/18/hadoop-compatibility.html   |   26 +-
 content/news/2015/01/06/december-in-flink.html  |   22 +-
 content/news/2015/01/21/release-0.8.html        |   24 +-
 content/news/2015/02/04/january-in-flink.html   |   24 +-
 content/news/2015/02/09/streaming-example.html  |   26 +-
 .../news/2015/03/02/february-2015-in-flink.html |   22 +-
 .../peeking-into-Apache-Flinks-Engine-Room.html |   40 +-
 content/news/2015/04/07/march-in-flink.html     |   22 +-
 .../2015/04/13/release-0.9.0-milestone1.html    |   22 +-
 .../05/11/Juggling-with-Bits-and-Bytes.html     |   48 +-
 .../news/2015/05/14/Community-update-April.html |   26 +-
 .../announcing-apache-flink-0.9.0-release.html  |   22 +-
 content/privacy-policy.html                     |   22 +-
 content/project.html                            |   22 +-
 docs/0.9/README.md                              |   60 +
 docs/0.9/apis/best_practices.html               |  411 +++
 docs/0.9/apis/cli.html                          |  394 ++
 docs/0.9/apis/cluster_execution.html            |  345 ++
 docs/0.9/apis/dataset_transformations.html      | 1720 +++++++++
 docs/0.9/apis/example_connectors.html           |  404 +++
 docs/0.9/apis/examples.html                     |  681 ++++
 docs/0.9/apis/fig/LICENSE.txt                   |   17 +
 .../fig/iterations_delta_iterate_operator.png   |  Bin 0 -> 113607 bytes
 ...terations_delta_iterate_operator_example.png |  Bin 0 -> 335057 bytes
 .../apis/fig/iterations_iterate_operator.png    |  Bin 0 -> 63465 bytes
 .../fig/iterations_iterate_operator_example.png |  Bin 0 -> 102925 bytes
 docs/0.9/apis/fig/iterations_supersteps.png     |  Bin 0 -> 54098 bytes
 docs/0.9/apis/fig/plan_visualizer.png           |  Bin 0 -> 145778 bytes
 docs/0.9/apis/hadoop_compatibility.html         |  423 +++
 docs/0.9/apis/index.html                        |  205 ++
 docs/0.9/apis/iterations.html                   |  399 ++
 docs/0.9/apis/java8.html                        |  360 ++
 docs/0.9/apis/local_execution.html              |  302 ++
 docs/0.9/apis/programming_guide.html            | 3433 ++++++++++++++++++
 docs/0.9/apis/python.html                       |  764 ++++
 docs/0.9/apis/streaming_guide.html              | 1944 ++++++++++
 docs/0.9/apis/web_client.html                   |  272 ++
 docs/0.9/build_docs.sh                          |   64 +
 docs/0.9/faq.html                               |  606 ++++
 docs/0.9/fig/LICENSE.txt                        |   17 +
 docs/0.9/fig/overview-stack-0.9.png             |  Bin 0 -> 260807 bytes
 docs/0.9/index.html                             |  248 ++
 docs/0.9/internals/add_operator.html            |  431 +++
 docs/0.9/internals/coding_guidelines.html       |  207 ++
 docs/0.9/internals/fig/ClientJmTm.svg           |  348 ++
 docs/0.9/internals/fig/LICENSE.txt              |   17 +
 .../internals/fig/job_and_execution_graph.svg   |  851 +++++
 .../0.9/internals/fig/projects_dependencies.svg |  586 +++
 docs/0.9/internals/fig/slots.svg                |  505 +++
 docs/0.9/internals/fig/stack.svg                |  606 ++++
 docs/0.9/internals/fig/state_machine.svg        |  318 ++
 docs/0.9/internals/general_arch.html            |  285 ++
 docs/0.9/internals/how_to_contribute.html       |  207 ++
 docs/0.9/internals/ide_setup.html               |  328 ++
 docs/0.9/internals/index.html                   |  205 ++
 docs/0.9/internals/job_scheduling.html          |  265 ++
 docs/0.9/internals/logging.html                 |  273 ++
 docs/0.9/internals/types_serialization.html     |  438 +++
 docs/0.9/libs/fig/LICENSE.txt                   |   17 +
 docs/0.9/libs/fig/gelly-example-graph.png       |  Bin 0 -> 18813 bytes
 docs/0.9/libs/fig/gelly-filter.png              |  Bin 0 -> 57192 bytes
 docs/0.9/libs/fig/gelly-gsa-sssp-result.png     |  Bin 0 -> 14472 bytes
 docs/0.9/libs/fig/gelly-gsa-sssp1.png           |  Bin 0 -> 33476 bytes
 docs/0.9/libs/fig/gelly-gsa-sssp2.png           |  Bin 0 -> 24962 bytes
 docs/0.9/libs/fig/gelly-reduceOnEdges.png       |  Bin 0 -> 23843 bytes
 docs/0.9/libs/fig/gelly-reduceOnNeighbors.png   |  Bin 0 -> 34903 bytes
 docs/0.9/libs/fig/gelly-union.png               |  Bin 0 -> 50498 bytes
 docs/0.9/libs/fig/gelly-vc-sssp1.png            |  Bin 0 -> 30470 bytes
 docs/0.9/libs/fig/gelly-vc-sssp2.png            |  Bin 0 -> 24644 bytes
 docs/0.9/libs/fig/spargel_example.png           |  Bin 0 -> 199032 bytes
 docs/0.9/libs/fig/spargel_example_input.png     |  Bin 0 -> 113478 bytes
 docs/0.9/libs/gelly_guide.html                  | 1045 ++++++
 docs/0.9/libs/index.html                        |  205 ++
 docs/0.9/libs/ml/als.html                       |  401 ++
 docs/0.9/libs/ml/contribution_guide.html        |  325 ++
 docs/0.9/libs/ml/distance_metrics.html          |  325 ++
 docs/0.9/libs/ml/index.html                     |  322 ++
 docs/0.9/libs/ml/min_max_scaler.html            |  339 ++
 .../0.9/libs/ml/multiple_linear_regression.html |  380 ++
 docs/0.9/libs/ml/optimization.html              |  513 +++
 docs/0.9/libs/ml/pipelines.html                 |  638 ++++
 docs/0.9/libs/ml/polynomial_features.html       |  333 ++
 docs/0.9/libs/ml/quickstart.html                |  438 +++
 docs/0.9/libs/ml/standard_scaler.html           |  340 ++
 docs/0.9/libs/ml/svm.html                       |  419 +++
 docs/0.9/libs/ml/vision_roadmap.html            |  313 ++
 docs/0.9/libs/spargel_guide.html                |  313 ++
 docs/0.9/libs/table.html                        |  302 ++
 docs/0.9/page/css/codetabs.css                  |   62 +
 docs/0.9/page/css/flink.css                     |  123 +
 docs/0.9/page/css/syntax.css                    |   79 +
 docs/0.9/page/favicon.ico                       |  Bin 0 -> 1150 bytes
 docs/0.9/page/img/LICENSE.txt                   |   17 +
 docs/0.9/page/img/navbar-brand-logo.jpg         |  Bin 0 -> 18470 bytes
 .../compiler-webclient-new.png                  |  Bin 0 -> 134963 bytes
 .../jobmanager-running-new.png                  |  Bin 0 -> 132859 bytes
 .../page/img/quickstart-example/kmeans003.png   |  Bin 0 -> 27962 bytes
 .../page/img/quickstart-example/kmeans008.png   |  Bin 0 -> 39305 bytes
 .../page/img/quickstart-example/kmeans015.png   |  Bin 0 -> 41958 bytes
 .../page/img/quickstart-example/result003.png   |  Bin 0 -> 60228 bytes
 .../page/img/quickstart-example/result008.png   |  Bin 0 -> 92732 bytes
 .../page/img/quickstart-example/result015.png   |  Bin 0 -> 89724 bytes
 .../img/quickstart-example/run-webclient.png    |  Bin 0 -> 89469 bytes
 docs/0.9/page/img/quickstart_cluster.png        |  Bin 0 -> 83790 bytes
 docs/0.9/page/js/codetabs.js                    |  121 +
 docs/0.9/quickstart/java_api_quickstart.html    |  330 ++
 docs/0.9/quickstart/plotPoints.py               |  100 +
 docs/0.9/quickstart/run_example_quickstart.html |  359 ++
 docs/0.9/quickstart/scala_api_quickstart.html   |  334 ++
 docs/0.9/quickstart/setup_quickstart.html       |  350 ++
 docs/0.9/scala_shell.html                       |  244 ++
 docs/0.9/search-results.html                    |  219 ++
 docs/0.9/setup/building.html                    |  273 ++
 docs/0.9/setup/cluster_setup.html               |  528 +++
 docs/0.9/setup/config.html                      |  639 ++++
 docs/0.9/setup/fig/FlinkOnYarn.svg              |  151 +
 docs/0.9/setup/fig/LICENSE.txt                  |   17 +
 docs/0.9/setup/fig/flink_on_tez_translation.png |  Bin 0 -> 350867 bytes
 docs/0.9/setup/fig/flink_tez_vertex.png         |  Bin 0 -> 105544 bytes
 docs/0.9/setup/fig/slots_parallelism.svg        |  695 ++++
 docs/0.9/setup/flink_on_tez.html                |  486 +++
 docs/0.9/setup/gce_setup.html                   |  289 ++
 docs/0.9/setup/index.html                       |  205 ++
 docs/0.9/setup/local_setup.html                 |  324 ++
 docs/0.9/setup/yarn_setup.html                  |  443 +++
 docs/master/README.md                           |   60 +
 docs/master/apis/best_practices.html            |  411 +++
 docs/master/apis/cli.html                       |  394 ++
 docs/master/apis/cluster_execution.html         |  345 ++
 docs/master/apis/dataset_transformations.html   | 1722 +++++++++
 docs/master/apis/example_connectors.html        |  404 +++
 docs/master/apis/examples.html                  |  681 ++++
 docs/master/apis/fig/LICENSE.txt                |   17 +
 .../fig/iterations_delta_iterate_operator.png   |  Bin 0 -> 113607 bytes
 ...terations_delta_iterate_operator_example.png |  Bin 0 -> 335057 bytes
 .../apis/fig/iterations_iterate_operator.png    |  Bin 0 -> 63465 bytes
 .../fig/iterations_iterate_operator_example.png |  Bin 0 -> 102925 bytes
 docs/master/apis/fig/iterations_supersteps.png  |  Bin 0 -> 54098 bytes
 docs/master/apis/fig/plan_visualizer.png        |  Bin 0 -> 145778 bytes
 docs/master/apis/hadoop_compatibility.html      |  423 +++
 docs/master/apis/index.html                     |  205 ++
 docs/master/apis/iterations.html                |  399 ++
 docs/master/apis/java8.html                     |  360 ++
 docs/master/apis/local_execution.html           |  302 ++
 docs/master/apis/programming_guide.html         | 3433 ++++++++++++++++++
 docs/master/apis/python.html                    |  764 ++++
 docs/master/apis/streaming_guide.html           | 2007 ++++++++++
 docs/master/apis/web_client.html                |  272 ++
 docs/master/apis/zip_elements_guide.html        |  251 ++
 docs/master/build_docs.sh                       |   64 +
 docs/master/faq.html                            |  606 ++++
 docs/master/fig/LICENSE.txt                     |   17 +
 docs/master/fig/overview-stack-0.9.png          |  Bin 0 -> 260807 bytes
 docs/master/index.html                          |  248 ++
 docs/master/internals/add_operator.html         |  431 +++
 docs/master/internals/coding_guidelines.html    |  207 ++
 docs/master/internals/fig/ClientJmTm.svg        |  348 ++
 docs/master/internals/fig/LICENSE.txt           |   17 +
 .../internals/fig/job_and_execution_graph.svg   |  851 +++++
 .../internals/fig/projects_dependencies.svg     |  586 +++
 docs/master/internals/fig/slots.svg             |  505 +++
 docs/master/internals/fig/stack.svg             |  606 ++++
 docs/master/internals/fig/state_machine.svg     |  318 ++
 docs/master/internals/general_arch.html         |  285 ++
 docs/master/internals/how_to_contribute.html    |  207 ++
 docs/master/internals/ide_setup.html            |  328 ++
 docs/master/internals/index.html                |  205 ++
 docs/master/internals/job_scheduling.html       |  265 ++
 docs/master/internals/logging.html              |  273 ++
 docs/master/internals/types_serialization.html  |  438 +++
 docs/master/libs/fig/LICENSE.txt                |   17 +
 docs/master/libs/fig/gelly-example-graph.png    |  Bin 0 -> 18813 bytes
 docs/master/libs/fig/gelly-filter.png           |  Bin 0 -> 57192 bytes
 docs/master/libs/fig/gelly-gsa-sssp-result.png  |  Bin 0 -> 14472 bytes
 docs/master/libs/fig/gelly-gsa-sssp1.png        |  Bin 0 -> 33476 bytes
 docs/master/libs/fig/gelly-gsa-sssp2.png        |  Bin 0 -> 24962 bytes
 docs/master/libs/fig/gelly-reduceOnEdges.png    |  Bin 0 -> 23843 bytes
 .../master/libs/fig/gelly-reduceOnNeighbors.png |  Bin 0 -> 34903 bytes
 docs/master/libs/fig/gelly-union.png            |  Bin 0 -> 50498 bytes
 docs/master/libs/fig/gelly-vc-sssp1.png         |  Bin 0 -> 30470 bytes
 docs/master/libs/fig/gelly-vc-sssp2.png         |  Bin 0 -> 24644 bytes
 docs/master/libs/fig/spargel_example.png        |  Bin 0 -> 199032 bytes
 docs/master/libs/fig/spargel_example_input.png  |  Bin 0 -> 113478 bytes
 docs/master/libs/gelly_guide.html               | 1090 ++++++
 docs/master/libs/index.html                     |  205 ++
 docs/master/libs/ml/als.html                    |  401 ++
 docs/master/libs/ml/contribution_guide.html     |  325 ++
 docs/master/libs/ml/distance_metrics.html       |  325 ++
 docs/master/libs/ml/index.html                  |  322 ++
 docs/master/libs/ml/min_max_scaler.html         |  339 ++
 .../libs/ml/multiple_linear_regression.html     |  380 ++
 docs/master/libs/ml/optimization.html           |  513 +++
 docs/master/libs/ml/pipelines.html              |  638 ++++
 docs/master/libs/ml/polynomial_features.html    |  333 ++
 docs/master/libs/ml/quickstart.html             |  438 +++
 docs/master/libs/ml/standard_scaler.html        |  340 ++
 docs/master/libs/ml/svm.html                    |  419 +++
 docs/master/libs/ml/vision_roadmap.html         |  313 ++
 docs/master/libs/spargel_guide.html             |  313 ++
 docs/master/libs/table.html                     |  302 ++
 docs/master/page/css/codetabs.css               |   62 +
 docs/master/page/css/flink.css                  |  123 +
 docs/master/page/css/syntax.css                 |   79 +
 docs/master/page/favicon.ico                    |  Bin 0 -> 1150 bytes
 docs/master/page/img/LICENSE.txt                |   17 +
 docs/master/page/img/navbar-brand-logo.jpg      |  Bin 0 -> 18470 bytes
 .../compiler-webclient-new.png                  |  Bin 0 -> 134963 bytes
 .../jobmanager-running-new.png                  |  Bin 0 -> 132859 bytes
 .../page/img/quickstart-example/kmeans003.png   |  Bin 0 -> 27962 bytes
 .../page/img/quickstart-example/kmeans008.png   |  Bin 0 -> 39305 bytes
 .../page/img/quickstart-example/kmeans015.png   |  Bin 0 -> 41958 bytes
 .../page/img/quickstart-example/result003.png   |  Bin 0 -> 60228 bytes
 .../page/img/quickstart-example/result008.png   |  Bin 0 -> 92732 bytes
 .../page/img/quickstart-example/result015.png   |  Bin 0 -> 89724 bytes
 .../img/quickstart-example/run-webclient.png    |  Bin 0 -> 89469 bytes
 docs/master/page/img/quickstart_cluster.png     |  Bin 0 -> 83790 bytes
 docs/master/page/js/codetabs.js                 |  121 +
 docs/master/quickstart/java_api_quickstart.html |  330 ++
 docs/master/quickstart/plotPoints.py            |  100 +
 .../quickstart/run_example_quickstart.html      |  359 ++
 .../master/quickstart/scala_api_quickstart.html |  334 ++
 docs/master/quickstart/setup_quickstart.html    |  350 ++
 docs/master/scala_shell.html                    |  244 ++
 docs/master/search-results.html                 |  219 ++
 docs/master/setup/building.html                 |  273 ++
 docs/master/setup/cluster_setup.html            |  528 +++
 docs/master/setup/config.html                   |  639 ++++
 docs/master/setup/fig/FlinkOnYarn.svg           |  151 +
 docs/master/setup/fig/LICENSE.txt               |   17 +
 .../setup/fig/flink_on_tez_translation.png      |  Bin 0 -> 350867 bytes
 docs/master/setup/fig/flink_tez_vertex.png      |  Bin 0 -> 105544 bytes
 docs/master/setup/fig/slots_parallelism.svg     |  695 ++++
 docs/master/setup/flink_on_tez.html             |  486 +++
 docs/master/setup/gce_setup.html                |  289 ++
 docs/master/setup/index.html                    |  205 ++
 docs/master/setup/local_setup.html              |  324 ++
 docs/master/setup/yarn_setup.html               |  445 +++
 495 files changed, 130600 insertions(+), 597 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/flink-web/blob/396616d4/_config.yml
----------------------------------------------------------------------
diff --git a/_config.yml b/_config.yml
index f2606fa..2de61c6 100644
--- a/_config.yml
+++ b/_config.yml
@@ -37,8 +37,11 @@ FLINK_DOWNLOAD_URL_HADOOP_2_LATEST: 
http://stratosphere-bin.s3-website-us-east-1
 stable: "0.9.0"
 snapshot: "0.10"
 
-docs-stable: "http://ci.apache.org/projects/flink/flink-docs-release-0.9";
-docs-snapshot: "http://ci.apache.org/projects/flink/flink-docs-master";
+docs-stable: http://flink.apache.org/docs/0.9
+docs-snapshot: http://flink.apache.org/docs/master
+
+# docs-stable: "http://ci.apache.org/projects/flink/flink-docs-release-0.9";
+# docs-snapshot: "http://ci.apache.org/projects/flink/flink-docs-master";
 
 # Used by the gh_link plugin
 jira: "https://issues.apache.org/jira/browse/FLINK";

http://git-wip-us.apache.org/repos/asf/flink-web/blob/396616d4/_includes/navbar.html
----------------------------------------------------------------------
diff --git a/_includes/navbar.html b/_includes/navbar.html
index 4aa7f75..c59a439 100644
--- a/_includes/navbar.html
+++ b/_includes/navbar.html
@@ -42,16 +42,18 @@
               <ul class="dropdown-menu" role="menu">
                 <!-- Latest stable release -->
                 <li role="presentation" class="dropdown-header"><strong>Latest 
Release</strong> (Stable)</li>
-                <li><a href="{{ site.docs-stable }}">{{ site.stable }} 
Documentation</a></li>
+                <li><a href="{{ site.baseurl }}/docs/0.9">{{ site.stable }} 
Documentation</a></li>
+                <!-- <li><a href="{{ site.docs-stable }}">{{ site.stable }} 
Documentation</a></li>
                 <li><a href="{{ site.docs-stable }}/api/java" 
class="active">{{ site.stable }} Javadocs</a></li>
-                <li><a href="{{ site.docs-stable }}/api/scala/index.html" 
class="active">{{ site.stable }} ScalaDocs</a></li>
+                <li><a href="{{ site.docs-stable }}/api/scala/index.html" 
class="active">{{ site.stable }} ScalaDocs</a></li> -->
 
                 <!-- Snapshot docs -->
                 <li class="divider"></li>
                 <li role="presentation" 
class="dropdown-header"><strong>Snapshot</strong> (Development)</li>
-                <li><a href="{{ site.docs-snapshot }}">{{ site.snapshot }} 
Documentation</a></li>
+                <li><a href="{{ site.baseurl }}/docs/master">{{ site.stable }} 
Documentation</a></li>
+                <!-- <li><a href="{{ site.docs-snapshot }}">{{ site.snapshot 
}} Documentation</a></li>
                 <li><a href="{{ site.docs-snapshot }}/api/java" 
class="active">{{ site.snapshot }} Javadocs</a></li>
-                <li><a href="{{ site.docs-snapshot }}/api/scala/index.html" 
class="active">{{ site.snapshot }} ScalaDocs</a></li>
+                <li><a href="{{ site.docs-snapshot }}/api/scala/index.html" 
class="active">{{ site.snapshot }} ScalaDocs</a></li> -->
 
                 <!-- Wiki -->
                 <li class="divider"></li>

http://git-wip-us.apache.org/repos/asf/flink-web/blob/396616d4/content/blog/feed.xml
----------------------------------------------------------------------
diff --git a/content/blog/feed.xml b/content/blog/feed.xml
index 46caacd..06cc7ea 100644
--- a/content/blog/feed.xml
+++ b/content/blog/feed.xml
@@ -247,7 +247,7 @@
 
 <item>
 <title>April 2015 in the Flink community</title>
-<description>&lt;p&gt;April was an packed month for Apache Flink. &lt;/p&gt;
+<description>&lt;p&gt;April was an packed month for Apache Flink.&lt;/p&gt;
 
 &lt;h2 id=&quot;flink-090-milestone1-release&quot;&gt;Flink 0.9.0-milestone1 
release&lt;/h2&gt;
 
@@ -263,7 +263,7 @@
 
 &lt;h2 id=&quot;flink-on-the-web&quot;&gt;Flink on the web&lt;/h2&gt;
 
-&lt;p&gt;Fabian Hueske gave an &lt;a 
href=&quot;http://www.infoq.com/news/2015/04/hueske-apache-flink?utm_campaign=infoq_content&amp;amp;utm_source=infoq&amp;amp;utm_medium=feed&amp;amp;utm_term=global&quot;&gt;interview
 at InfoQ&lt;/a&gt; on Apache Flink. &lt;/p&gt;
+&lt;p&gt;Fabian Hueske gave an &lt;a 
href=&quot;http://www.infoq.com/news/2015/04/hueske-apache-flink?utm_campaign=infoq_content&amp;amp;utm_source=infoq&amp;amp;utm_medium=feed&amp;amp;utm_term=global&quot;&gt;interview
 at InfoQ&lt;/a&gt; on Apache Flink.&lt;/p&gt;
 
 &lt;h2 id=&quot;upcoming-events&quot;&gt;Upcoming events&lt;/h2&gt;
 
@@ -295,7 +295,7 @@ However, this approach has a few notable drawbacks. First 
of all it is not trivi
 &lt;img src=&quot;/img/blog/memory-mgmt.png&quot; 
style=&quot;width:90%;margin:15px&quot; /&gt;
 &lt;/center&gt;
 
-&lt;p&gt;Flink’s style of active memory management and operating on binary 
data has several benefits: &lt;/p&gt;
+&lt;p&gt;Flink’s style of active memory management and operating on binary 
data has several benefits:&lt;/p&gt;
 
 &lt;ol&gt;
   &lt;li&gt;&lt;strong&gt;Memory-safe execution &amp;amp; efficient 
out-of-core algorithms.&lt;/strong&gt; Due to the fixed amount of allocated 
memory segments, it is trivial to monitor remaining memory resources. In case 
of memory shortage, processing operators can efficiently write larger batches 
of memory segments to disk and later them read back. Consequently, 
&lt;code&gt;OutOfMemoryErrors&lt;/code&gt; are effectively prevented.&lt;/li&gt;
@@ -304,13 +304,13 @@ However, this approach has a few notable drawbacks. First 
of all it is not trivi
   &lt;li&gt;&lt;strong&gt;Efficient binary operations &amp;amp; cache 
sensitivity.&lt;/strong&gt; Binary data can be efficiently compared and 
operated on given a suitable binary representation. Furthermore, the binary 
representations can put related values, as well as hash codes, keys, and 
pointers, adjacently into memory. This gives data structures with usually more 
cache efficient access patterns.&lt;/li&gt;
 &lt;/ol&gt;
 
-&lt;p&gt;These properties of active memory management are very desirable in a 
data processing systems for large-scale data analytics but have a significant 
price tag attached. Active memory management and operating on binary data is 
not trivial to implement, i.e., using 
&lt;code&gt;java.util.HashMap&lt;/code&gt; is much easier than implementing a 
spillable hash-table backed by byte arrays and a custom serialization stack. Of 
course Apache Flink is not the only JVM-based data processing system that 
operates on serialized binary data. Projects such as &lt;a 
href=&quot;http://drill.apache.org/&quot;&gt;Apache Drill&lt;/a&gt;, &lt;a 
href=&quot;http://ignite.incubator.apache.org/&quot;&gt;Apache Ignite 
(incubating)&lt;/a&gt; or &lt;a 
href=&quot;http://projectgeode.org/&quot;&gt;Apache Geode 
(incubating)&lt;/a&gt; apply similar techniques and it was recently announced 
that also &lt;a href=&quot;http://spark.apache.org/&quot;&gt;Apache 
Spark&lt;/a&gt; will evolve into this direction with &
 lt;a 
href=&quot;https://databricks.com/blog/2015/04/28/project-tungsten-bringing-spark-closer-to-bare-metal.html&quot;&gt;Project
 Tungsten&lt;/a&gt;. &lt;/p&gt;
+&lt;p&gt;These properties of active memory management are very desirable in a 
data processing systems for large-scale data analytics but have a significant 
price tag attached. Active memory management and operating on binary data is 
not trivial to implement, i.e., using 
&lt;code&gt;java.util.HashMap&lt;/code&gt; is much easier than implementing a 
spillable hash-table backed by byte arrays and a custom serialization stack. Of 
course Apache Flink is not the only JVM-based data processing system that 
operates on serialized binary data. Projects such as &lt;a 
href=&quot;http://drill.apache.org/&quot;&gt;Apache Drill&lt;/a&gt;, &lt;a 
href=&quot;http://ignite.incubator.apache.org/&quot;&gt;Apache Ignite 
(incubating)&lt;/a&gt; or &lt;a 
href=&quot;http://projectgeode.org/&quot;&gt;Apache Geode 
(incubating)&lt;/a&gt; apply similar techniques and it was recently announced 
that also &lt;a href=&quot;http://spark.apache.org/&quot;&gt;Apache 
Spark&lt;/a&gt; will evolve into this direction with &
 lt;a 
href=&quot;https://databricks.com/blog/2015/04/28/project-tungsten-bringing-spark-closer-to-bare-metal.html&quot;&gt;Project
 Tungsten&lt;/a&gt;.&lt;/p&gt;
 
 &lt;p&gt;In the following we discuss in detail how Flink allocates memory, 
de/serializes objects, and operates on binary data. We will also show some 
performance numbers comparing processing objects on the heap and operating on 
binary data.&lt;/p&gt;
 
 &lt;h2 id=&quot;how-does-flink-allocate-memory&quot;&gt;How does Flink 
allocate memory?&lt;/h2&gt;
 
-&lt;p&gt;A Flink worker, called TaskManager, is composed of several internal 
components such as an actor system for coordination with the Flink master, an 
IOManager that takes care of spilling data to disk and reading it back, and a 
MemoryManager that coordinates memory usage. In the context of this blog post, 
the MemoryManager is of most interest. &lt;/p&gt;
+&lt;p&gt;A Flink worker, called TaskManager, is composed of several internal 
components such as an actor system for coordination with the Flink master, an 
IOManager that takes care of spilling data to disk and reading it back, and a 
MemoryManager that coordinates memory usage. In the context of this blog post, 
the MemoryManager is of most interest.&lt;/p&gt;
 
 &lt;p&gt;The MemoryManager takes care of allocating, accounting, and 
distributing MemorySegments to data processing operators such as sort and join 
operators. A &lt;a 
href=&quot;https://github.com/apache/flink/blob/release-0.9.0-milestone-1/flink-core/src/main/java/org/apache/flink/core/memory/MemorySegment.java&quot;&gt;MemorySegment&lt;/a&gt;
 is Flink’s distribution unit of memory and is backed by a regular Java byte 
array (size is 32 KB by default). A MemorySegment provides very efficient write 
and read access to its backed byte array using Java’s unsafe methods. You can 
think of a MemorySegment as a custom-tailored version of Java’s NIO 
ByteBuffer. In order to operate on multiple MemorySegments like on a larger 
chunk of consecutive memory, Flink uses logical views that implement Java’s 
&lt;code&gt;java.io.DataOutput&lt;/code&gt; and 
&lt;code&gt;java.io.DataInput&lt;/code&gt; interfaces.&lt;/p&gt;
 
@@ -322,7 +322,7 @@ However, this approach has a few notable drawbacks. First 
of all it is not trivi
 
 &lt;h2 id=&quot;how-does-flink-serialize-objects&quot;&gt;How does Flink 
serialize objects?&lt;/h2&gt;
 
-&lt;p&gt;The Java ecosystem offers several libraries to convert objects into a 
binary representation and back. Common alternatives are standard Java 
serialization, &lt;a 
href=&quot;https://github.com/EsotericSoftware/kryo&quot;&gt;Kryo&lt;/a&gt;, 
&lt;a href=&quot;http://avro.apache.org/&quot;&gt;Apache Avro&lt;/a&gt;, &lt;a 
href=&quot;http://thrift.apache.org/&quot;&gt;Apache Thrift&lt;/a&gt;, or 
Google’s &lt;a 
href=&quot;https://github.com/google/protobuf&quot;&gt;Protobuf&lt;/a&gt;. 
Flink includes its own custom serialization framework in order to control the 
binary representation of data. This is important because operating on binary 
data such as comparing or even manipulating binary data requires exact 
knowledge of the serialization layout. Further, configuring the serialization 
layout with respect to operations that are performed on binary data can yield a 
significant performance boost. Flink’s serialization stack also leverages the 
fact, that the type of the objects which 
 are going through de/serialization are exactly known before a program is 
executed. &lt;/p&gt;
+&lt;p&gt;The Java ecosystem offers several libraries to convert objects into a 
binary representation and back. Common alternatives are standard Java 
serialization, &lt;a 
href=&quot;https://github.com/EsotericSoftware/kryo&quot;&gt;Kryo&lt;/a&gt;, 
&lt;a href=&quot;http://avro.apache.org/&quot;&gt;Apache Avro&lt;/a&gt;, &lt;a 
href=&quot;http://thrift.apache.org/&quot;&gt;Apache Thrift&lt;/a&gt;, or 
Google’s &lt;a 
href=&quot;https://github.com/google/protobuf&quot;&gt;Protobuf&lt;/a&gt;. 
Flink includes its own custom serialization framework in order to control the 
binary representation of data. This is important because operating on binary 
data such as comparing or even manipulating binary data requires exact 
knowledge of the serialization layout. Further, configuring the serialization 
layout with respect to operations that are performed on binary data can yield a 
significant performance boost. Flink’s serialization stack also leverages the 
fact, that the type of the objects which 
 are going through de/serialization are exactly known before a program is 
executed.&lt;/p&gt;
 
 &lt;p&gt;Flink programs can process data represented as arbitrary Java or 
Scala objects. Before a program is optimized, the data types at each processing 
step of the program’s data flow need to be identified. For Java programs, 
Flink features a reflection-based type extraction component to analyze the 
return types of user-defined functions. Scala programs are analyzed with help 
of the Scala compiler. Flink represents each data type with a &lt;a 
href=&quot;https://github.com/apache/flink/blob/release-0.9.0-milestone-1/flink-core/src/main/java/org/apache/flink/api/common/typeinfo/TypeInformation.java&quot;&gt;TypeInformation&lt;/a&gt;.
 Flink has TypeInformations for several kinds of data types, 
including:&lt;/p&gt;
 
@@ -332,11 +332,11 @@ However, this approach has a few notable drawbacks. First 
of all it is not trivi
   &lt;li&gt;WritableTypeInfo: Any implementation of Hadoop’s Writable 
interface.&lt;/li&gt;
   &lt;li&gt;TupleTypeInfo: Any Flink tuple (Tuple1 to Tuple25). Flink tuples 
are Java representations for fixed-length tuples with typed fields.&lt;/li&gt;
   &lt;li&gt;CaseClassTypeInfo: Any Scala CaseClass (including Scala 
tuples).&lt;/li&gt;
-  &lt;li&gt;PojoTypeInfo: Any POJO (Java or Scala), i.e., an object with all 
fields either being public or accessible through getters and setter that follow 
the common naming conventions. &lt;/li&gt;
+  &lt;li&gt;PojoTypeInfo: Any POJO (Java or Scala), i.e., an object with all 
fields either being public or accessible through getters and setter that follow 
the common naming conventions.&lt;/li&gt;
   &lt;li&gt;GenericTypeInfo: Any data type that cannot be identified as 
another type.&lt;/li&gt;
 &lt;/ul&gt;
 
-&lt;p&gt;Each TypeInformation provides a serializer for the data type it 
represents. For example, a BasicTypeInfo returns a serializer that writes the 
respective primitive type, the serializer of a WritableTypeInfo delegates 
de/serialization to the write() and readFields() methods of the object 
implementing Hadoop’s Writable interface, and a GenericTypeInfo returns a 
serializer that delegates serialization to Kryo. Object serialization to a 
DataOutput which is backed by Flink MemorySegments goes automatically through 
Java’s efficient unsafe operations. For data types that can be used as keys, 
i.e., compared and hashed, the TypeInformation provides TypeComparators. 
TypeComparators compare and hash objects and can - depending on the concrete 
data type - also efficiently compare binary representations and extract 
fixed-length binary key prefixes. &lt;/p&gt;
+&lt;p&gt;Each TypeInformation provides a serializer for the data type it 
represents. For example, a BasicTypeInfo returns a serializer that writes the 
respective primitive type, the serializer of a WritableTypeInfo delegates 
de/serialization to the write() and readFields() methods of the object 
implementing Hadoop’s Writable interface, and a GenericTypeInfo returns a 
serializer that delegates serialization to Kryo. Object serialization to a 
DataOutput which is backed by Flink MemorySegments goes automatically through 
Java’s efficient unsafe operations. For data types that can be used as keys, 
i.e., compared and hashed, the TypeInformation provides TypeComparators. 
TypeComparators compare and hash objects and can - depending on the concrete 
data type - also efficiently compare binary representations and extract 
fixed-length binary key prefixes.&lt;/p&gt;
 
 &lt;p&gt;Tuple, Pojo, and CaseClass types are composite types, i.e., 
containers for one or more possibly nested data types. As such, their 
serializers and comparators are also composite and delegate the serialization 
and comparison of their member data types to the respective serializers and 
comparators. The following figure illustrates the serialization of a (nested) 
&lt;code&gt;Tuple3&amp;lt;Integer, Double, Person&amp;gt;&lt;/code&gt; object 
where &lt;code&gt;Person&lt;/code&gt; is a POJO and defined as 
follows:&lt;/p&gt;
 
@@ -349,13 +349,13 @@ However, this approach has a few notable drawbacks. First 
of all it is not trivi
 &lt;img src=&quot;/img/blog/data-serialization.png&quot; 
style=&quot;width:80%;margin:15px&quot; /&gt;
 &lt;/center&gt;
 
-&lt;p&gt;Flink’s type system can be easily extended by providing custom 
TypeInformations, Serializers, and Comparators to improve the performance of 
serializing and comparing custom data types. &lt;/p&gt;
+&lt;p&gt;Flink’s type system can be easily extended by providing custom 
TypeInformations, Serializers, and Comparators to improve the performance of 
serializing and comparing custom data types.&lt;/p&gt;
 
 &lt;h2 id=&quot;how-does-flink-operate-on-binary-data&quot;&gt;How does Flink 
operate on binary data?&lt;/h2&gt;
 
 &lt;p&gt;Similar to many other data processing APIs (including SQL), Flink’s 
APIs provide transformations to group, sort, and join data sets. These 
transformations operate on potentially very large data sets. Relational 
database systems feature very efficient algorithms for these purposes since 
several decades including external merge-sort, merge-join, and hybrid 
hash-join. Flink builds on this technology, but generalizes it to handle 
arbitrary objects using its custom serialization and comparison stack. In the 
following, we show how Flink operates with binary data by the example of 
Flink’s in-memory sort algorithm.&lt;/p&gt;
 
-&lt;p&gt;Flink assigns a memory budget to its data processing operators. Upon 
initialization, a sort algorithm requests its memory budget from the 
MemoryManager and receives a corresponding set of MemorySegments. The set of 
MemorySegments becomes the memory pool of a so-called sort buffer which 
collects the data that is be sorted. The following figure illustrates how data 
objects are serialized into the sort buffer. &lt;/p&gt;
+&lt;p&gt;Flink assigns a memory budget to its data processing operators. Upon 
initialization, a sort algorithm requests its memory budget from the 
MemoryManager and receives a corresponding set of MemorySegments. The set of 
MemorySegments becomes the memory pool of a so-called sort buffer which 
collects the data that is be sorted. The following figure illustrates how data 
objects are serialized into the sort buffer.&lt;/p&gt;
 
 &lt;center&gt;
 &lt;img src=&quot;/img/blog/sorting-binary-data-1.png&quot; 
style=&quot;width:90%;margin:15px&quot; /&gt;
@@ -368,7 +368,7 @@ The following figure shows how two objects are 
compared.&lt;/p&gt;
 &lt;img src=&quot;/img/blog/sorting-binary-data-2.png&quot; 
style=&quot;width:80%;margin:15px&quot; /&gt;
 &lt;/center&gt;
 
-&lt;p&gt;The sort buffer compares two elements by comparing their binary 
fix-length sort keys. The comparison is successful if either done on a full key 
(not a prefix key) or if the binary prefix keys are not equal. If the prefix 
keys are equal (or the sort key data type does not provide a binary prefix 
key), the sort buffer follows the pointers to the actual object data, 
deserializes both objects and compares the objects. Depending on the result of 
the comparison, the sort algorithm decides whether to swap the compared 
elements or not. The sort buffer swaps two elements by moving their fix-length 
keys and pointers. The actual data is not moved. Once the sort algorithm 
finishes, the pointers in the sort buffer are correctly ordered. The following 
figure shows how the sorted data is returned from the sort buffer. &lt;/p&gt;
+&lt;p&gt;The sort buffer compares two elements by comparing their binary 
fix-length sort keys. The comparison is successful if either done on a full key 
(not a prefix key) or if the binary prefix keys are not equal. If the prefix 
keys are equal (or the sort key data type does not provide a binary prefix 
key), the sort buffer follows the pointers to the actual object data, 
deserializes both objects and compares the objects. Depending on the result of 
the comparison, the sort algorithm decides whether to swap the compared 
elements or not. The sort buffer swaps two elements by moving their fix-length 
keys and pointers. The actual data is not moved. Once the sort algorithm 
finishes, the pointers in the sort buffer are correctly ordered. The following 
figure shows how the sorted data is returned from the sort buffer.&lt;/p&gt;
 
 &lt;center&gt;
 &lt;img src=&quot;/img/blog/sorting-binary-data-3.png&quot; 
style=&quot;width:80%;margin:15px&quot; /&gt;
@@ -386,7 +386,7 @@ The following figure shows how two objects are 
compared.&lt;/p&gt;
   &lt;li&gt;&lt;strong&gt;Kryo-serialized.&lt;/strong&gt; The tuple fields are 
serialized into a sort buffer of 600 MB size using Kryo serialization and 
sorted without binary sort keys. This means that each pair-wise comparison 
requires two object to be deserialized.&lt;/li&gt;
 &lt;/ol&gt;
 
-&lt;p&gt;All sort methods are implemented using a single thread. The reported 
times are averaged over ten runs. After each run, we call 
&lt;code&gt;System.gc()&lt;/code&gt; to request a garbage collection run which 
does not go into measured execution time. The following figure shows the time 
to store the input data in memory, sort it, and read it back as objects. 
&lt;/p&gt;
+&lt;p&gt;All sort methods are implemented using a single thread. The reported 
times are averaged over ten runs. After each run, we call 
&lt;code&gt;System.gc()&lt;/code&gt; to request a garbage collection run which 
does not go into measured execution time. The following figure shows the time 
to store the input data in memory, sort it, and read it back as 
objects.&lt;/p&gt;
 
 &lt;center&gt;
 &lt;img src=&quot;/img/blog/sort-benchmark.png&quot; 
style=&quot;width:90%;margin:15px&quot; /&gt;
@@ -444,13 +444,13 @@ The following figure shows how two objects are 
compared.&lt;/p&gt;
 
 &lt;p&gt;&lt;br /&gt;&lt;/p&gt;
 
-&lt;p&gt;To summarize, the experiments verify the previously stated benefits 
of operating on binary data. &lt;/p&gt;
+&lt;p&gt;To summarize, the experiments verify the previously stated benefits 
of operating on binary data.&lt;/p&gt;
 
 &lt;h2 id=&quot;were-not-done-yet&quot;&gt;We’re not done yet!&lt;/h2&gt;
 
-&lt;p&gt;Apache Flink features quite a bit of advanced techniques to safely 
and efficiently process huge amounts of data with limited memory resources. 
However, there are a few points that could make Flink even more efficient. The 
Flink community is working on moving the managed memory to off-heap memory. 
This will allow for smaller JVMs, lower garbage collection overhead, and also 
easier system configuration. With Flink’s Table API, the semantics of all 
operations such as aggregations and projections are known (in contrast to 
black-box user-defined functions). Hence we can generate code for Table API 
operations that directly operates on binary data. Further improvements include 
serialization layouts which are tailored towards the operations that are 
applied on the binary data and code generation for serializers and comparators. 
&lt;/p&gt;
+&lt;p&gt;Apache Flink features quite a bit of advanced techniques to safely 
and efficiently process huge amounts of data with limited memory resources. 
However, there are a few points that could make Flink even more efficient. The 
Flink community is working on moving the managed memory to off-heap memory. 
This will allow for smaller JVMs, lower garbage collection overhead, and also 
easier system configuration. With Flink’s Table API, the semantics of all 
operations such as aggregations and projections are known (in contrast to 
black-box user-defined functions). Hence we can generate code for Table API 
operations that directly operates on binary data. Further improvements include 
serialization layouts which are tailored towards the operations that are 
applied on the binary data and code generation for serializers and 
comparators.&lt;/p&gt;
 
-&lt;p&gt;The groundwork (and a lot more) for operating on binary data is done 
but there is still some room for making Flink even better and faster. If you 
are crazy about performance and like to juggle with lot of bits and bytes, join 
the Flink community! &lt;/p&gt;
+&lt;p&gt;The groundwork (and a lot more) for operating on binary data is done 
but there is still some room for making Flink even better and faster. If you 
are crazy about performance and like to juggle with lot of bits and bytes, join 
the Flink community!&lt;/p&gt;
 
 &lt;h2 id=&quot;tldr-give-me-three-things-to-remember&quot;&gt;TL;DR; Give me 
three things to remember!&lt;/h2&gt;
 
@@ -804,7 +804,7 @@ Tez as an execution backend instead of Flink’s own 
network stack. Learn more
 &lt;p&gt;In this blog post, we cut through Apache Flink’s layered 
architecture and take a look at its internals with a focus on how it handles 
joins. Specifically, I will&lt;/p&gt;
 
 &lt;ul&gt;
-  &lt;li&gt;show how easy it is to join data sets using Flink’s fluent APIs, 
&lt;/li&gt;
+  &lt;li&gt;show how easy it is to join data sets using Flink’s fluent 
APIs,&lt;/li&gt;
   &lt;li&gt;discuss basic distributed join strategies, Flink’s join 
implementations, and its memory management,&lt;/li&gt;
   &lt;li&gt;talk about Flink’s optimizer that automatically chooses join 
strategies,&lt;/li&gt;
   &lt;li&gt;show some performance numbers for joining data sets of different 
sizes, and finally&lt;/li&gt;
@@ -815,7 +815,7 @@ Tez as an execution backend instead of Flink’s own 
network stack. Learn more
 
 &lt;h3 id=&quot;how-do-i-join-with-flink&quot;&gt;How do I join with 
Flink?&lt;/h3&gt;
 
-&lt;p&gt;Flink provides fluent APIs in Java and Scala to write data flow 
programs. Flink’s APIs are centered around parallel data collections which 
are called data sets. data sets are processed by applying Transformations that 
compute new data sets. Flink’s transformations include Map and Reduce as 
known from MapReduce &lt;a 
href=&quot;http://research.google.com/archive/mapreduce.html&quot;&gt;[1]&lt;/a&gt;
 but also operators for joining, co-grouping, and iterative processing. The 
documentation gives an overview of all available transformations &lt;a 
href=&quot;http://ci.apache.org/projects/flink/flink-docs-release-0.8/dataset_transformations.html&quot;&gt;[2]&lt;/a&gt;.
 &lt;/p&gt;
+&lt;p&gt;Flink provides fluent APIs in Java and Scala to write data flow 
programs. Flink’s APIs are centered around parallel data collections which 
are called data sets. data sets are processed by applying Transformations that 
compute new data sets. Flink’s transformations include Map and Reduce as 
known from MapReduce &lt;a 
href=&quot;http://research.google.com/archive/mapreduce.html&quot;&gt;[1]&lt;/a&gt;
 but also operators for joining, co-grouping, and iterative processing. The 
documentation gives an overview of all available transformations &lt;a 
href=&quot;http://ci.apache.org/projects/flink/flink-docs-release-0.8/dataset_transformations.html&quot;&gt;[2]&lt;/a&gt;.&lt;/p&gt;
 
 &lt;p&gt;Joining two Scala case class data sets is very easy as the following 
example shows:&lt;/p&gt;
 
@@ -852,7 +852,7 @@ Tez as an execution backend instead of Flink’s own 
network stack. Learn more
 
 &lt;ol&gt;
   &lt;li&gt;The data of both inputs is distributed across all parallel 
instances that participate in the join and&lt;/li&gt;
-  &lt;li&gt;each parallel instance performs a standard stand-alone join 
algorithm on its local partition of the overall data. &lt;/li&gt;
+  &lt;li&gt;each parallel instance performs a standard stand-alone join 
algorithm on its local partition of the overall data.&lt;/li&gt;
 &lt;/ol&gt;
 
 &lt;p&gt;The distribution of data across parallel instances must ensure that 
each valid join pair can be locally built by exactly one instance. For both 
steps, there are multiple valid strategies that can be independently picked and 
which are favorable in different situations. In Flink terminology, the first 
phase is called Ship Strategy and the second phase Local Strategy. In the 
following I will describe Flink’s ship and local strategies to join two data 
sets &lt;em&gt;R&lt;/em&gt; and &lt;em&gt;S&lt;/em&gt;.&lt;/p&gt;
@@ -871,7 +871,7 @@ Tez as an execution backend instead of Flink’s own 
network stack. Learn more
 &lt;img src=&quot;/img/blog/joins-repartition.png&quot; 
style=&quot;width:90%;margin:15px&quot; /&gt;
 &lt;/center&gt;
 
-&lt;p&gt;The Broadcast-Forward strategy sends one complete data set (R) to 
each parallel instance that holds a partition of the other data set (S), i.e., 
each parallel instance receives the full data set R. Data set S remains local 
and is not shipped at all. The cost of the BF strategy depends on the size of R 
and the number of parallel instances it is shipped to. The size of S does not 
matter because S is not moved. The figure below illustrates how both ship 
strategies work. &lt;/p&gt;
+&lt;p&gt;The Broadcast-Forward strategy sends one complete data set (R) to 
each parallel instance that holds a partition of the other data set (S), i.e., 
each parallel instance receives the full data set R. Data set S remains local 
and is not shipped at all. The cost of the BF strategy depends on the size of R 
and the number of parallel instances it is shipped to. The size of S does not 
matter because S is not moved. The figure below illustrates how both ship 
strategies work.&lt;/p&gt;
 
 &lt;center&gt;
 &lt;img src=&quot;/img/blog/joins-broadcast.png&quot; 
style=&quot;width:90%;margin:15px&quot; /&gt;
@@ -880,7 +880,7 @@ Tez as an execution backend instead of Flink’s own 
network stack. Learn more
 &lt;p&gt;The Repartition-Repartition and Broadcast-Forward ship strategies 
establish suitable data distributions to execute a distributed join. Depending 
on the operations that are applied before the join, one or even both inputs of 
a join are already distributed in a suitable way across parallel instances. In 
this case, Flink will reuse such distributions and only ship one or no input at 
all.&lt;/p&gt;
 
 &lt;h4 id=&quot;flinks-memory-management&quot;&gt;Flink’s Memory 
Management&lt;/h4&gt;
-&lt;p&gt;Before delving into the details of Flink’s local join algorithms, I 
will briefly discuss Flink’s internal memory management. Data processing 
algorithms such as joining, grouping, and sorting need to hold portions of 
their input data in memory. While such algorithms perform best if there is 
enough memory available to hold all data, it is crucial to gracefully handle 
situations where the data size exceeds memory. Such situations are especially 
tricky in JVM-based systems such as Flink because the system needs to reliably 
recognize that it is short on memory. Failure to detect such situations can 
result in an &lt;code&gt;OutOfMemoryException&lt;/code&gt; and kill the JVM. 
&lt;/p&gt;
+&lt;p&gt;Before delving into the details of Flink’s local join algorithms, I 
will briefly discuss Flink’s internal memory management. Data processing 
algorithms such as joining, grouping, and sorting need to hold portions of 
their input data in memory. While such algorithms perform best if there is 
enough memory available to hold all data, it is crucial to gracefully handle 
situations where the data size exceeds memory. Such situations are especially 
tricky in JVM-based systems such as Flink because the system needs to reliably 
recognize that it is short on memory. Failure to detect such situations can 
result in an &lt;code&gt;OutOfMemoryException&lt;/code&gt; and kill the 
JVM.&lt;/p&gt;
 
 &lt;p&gt;Flink handles this challenge by actively managing its memory. When a 
worker node (TaskManager) is started, it allocates a fixed portion (70% by 
default) of the JVM’s heap memory that is available after initialization as 
32KB byte arrays. These byte arrays are distributed as working memory to all 
algorithms that need to hold significant portions of data in memory. The 
algorithms receive their input data as Java data objects and serialize them 
into their working memory.&lt;/p&gt;
 
@@ -897,7 +897,7 @@ Tez as an execution backend instead of Flink’s own 
network stack. Learn more
 &lt;p&gt;After the data has been distributed across all parallel join 
instances using either a Repartition-Repartition or Broadcast-Forward ship 
strategy, each instance runs a local join algorithm to join the elements of its 
local partition. Flink’s runtime features two common join strategies to 
perform these local joins:&lt;/p&gt;
 
 &lt;ul&gt;
-  &lt;li&gt;the &lt;em&gt;Sort-Merge-Join&lt;/em&gt; strategy (SM) and 
&lt;/li&gt;
+  &lt;li&gt;the &lt;em&gt;Sort-Merge-Join&lt;/em&gt; strategy (SM) 
and&lt;/li&gt;
   &lt;li&gt;the &lt;em&gt;Hybrid-Hash-Join&lt;/em&gt; strategy (HH).&lt;/li&gt;
 &lt;/ul&gt;
 
@@ -942,13 +942,13 @@ Tez as an execution backend instead of Flink’s own 
network stack. Learn more
 &lt;ul&gt;
   &lt;li&gt;1GB     : 1000GB&lt;/li&gt;
   &lt;li&gt;10GB    : 1000GB&lt;/li&gt;
-  &lt;li&gt;100GB   : 1000GB &lt;/li&gt;
+  &lt;li&gt;100GB   : 1000GB&lt;/li&gt;
   &lt;li&gt;1000GB  : 1000GB&lt;/li&gt;
 &lt;/ul&gt;
 
 &lt;p&gt;The Broadcast-Forward strategy is only executed for up to 10GB. 
Building a hash table from 100GB broadcasted data in 5GB working memory would 
result in spilling proximately 95GB (build input) + 950GB (probe input) in each 
parallel thread and require more than 8TB local disk storage on each 
machine.&lt;/p&gt;
 
-&lt;p&gt;As in the single-core benchmark, we run 1:N joins, generate the data 
on-the-fly, and immediately discard the result after the join. We run the 
benchmark on 10 n1-highmem-8 Google Compute Engine instances. Each instance is 
equipped with 8 cores, 52GB RAM, 40GB of which are configured as working memory 
(5GB per core), and one local SSD for spilling to disk. All benchmarks are 
performed using the same configuration, i.e., no fine tuning for the respective 
data sizes is done. The programs are executed with a parallelism of 80. 
&lt;/p&gt;
+&lt;p&gt;As in the single-core benchmark, we run 1:N joins, generate the data 
on-the-fly, and immediately discard the result after the join. We run the 
benchmark on 10 n1-highmem-8 Google Compute Engine instances. Each instance is 
equipped with 8 cores, 52GB RAM, 40GB of which are configured as working memory 
(5GB per core), and one local SSD for spilling to disk. All benchmarks are 
performed using the same configuration, i.e., no fine tuning for the respective 
data sizes is done. The programs are executed with a parallelism of 
80.&lt;/p&gt;
 
 &lt;center&gt;
 &lt;img src=&quot;/img/blog/joins-dist-perf.png&quot; 
style=&quot;width:70%;margin:15px&quot; /&gt;
@@ -965,7 +965,7 @@ Tez as an execution backend instead of Flink’s own 
network stack. Learn more
 &lt;ul&gt;
   &lt;li&gt;Flink’s fluent Scala and Java APIs make joins and other data 
transformations easy as cake.&lt;/li&gt;
   &lt;li&gt;The optimizer does the hard choices for you, but gives you control 
in case you know better.&lt;/li&gt;
-  &lt;li&gt;Flink’s join implementations perform very good in-memory and 
gracefully degrade when going to disk. &lt;/li&gt;
+  &lt;li&gt;Flink’s join implementations perform very good in-memory and 
gracefully degrade when going to disk.&lt;/li&gt;
   &lt;li&gt;Due to Flink’s robust memory management, there is no need for 
job- or data-specific memory tuning to avoid a nasty 
&lt;code&gt;OutOfMemoryException&lt;/code&gt;. It just runs 
out-of-the-box.&lt;/li&gt;
 &lt;/ul&gt;
 
@@ -1136,7 +1136,7 @@ found &lt;a 
href=&quot;https://github.com/mbalassi/flink/blob/stockprices/flink-
   &lt;li&gt;Read a socket stream of stock prices&lt;/li&gt;
   &lt;li&gt;Parse the text in the stream to create a stream of 
&lt;code&gt;StockPrice&lt;/code&gt; objects&lt;/li&gt;
   &lt;li&gt;Add four other sources tagged with the stock symbol.&lt;/li&gt;
-  &lt;li&gt;Finally, merge the streams to create a unified stream. &lt;/li&gt;
+  &lt;li&gt;Finally, merge the streams to create a unified stream.&lt;/li&gt;
 &lt;/ol&gt;
 
 &lt;p&gt;&lt;img alt=&quot;Reading from multiple inputs&quot; 
src=&quot;/img/blog/blog_multi_input.png&quot; width=&quot;70%&quot; 
class=&quot;img-responsive center-block&quot; /&gt;&lt;/p&gt;
@@ -1608,7 +1608,7 @@ number of mentions of a given stock in the Twitter 
stream. As both of
 these data streams are potentially infinite, we apply the join on a
 30-second window.&lt;/p&gt;
 
-&lt;p&gt;&lt;img alt=&quot;Streaming joins&quot; 
src=&quot;/img/blog/blog_stream_join.png&quot; width=&quot;60%&quot; 
class=&quot;img-responsive center-block&quot; /&gt; &lt;/p&gt;
+&lt;p&gt;&lt;img alt=&quot;Streaming joins&quot; 
src=&quot;/img/blog/blog_stream_join.png&quot; width=&quot;60%&quot; 
class=&quot;img-responsive center-block&quot; /&gt;&lt;/p&gt;
 
 &lt;div class=&quot;codetabs&quot;&gt;
 
@@ -1777,7 +1777,7 @@ internally, fault tolerance, and performance 
measurements!&lt;/p&gt;
 
 &lt;h3 
id=&quot;using-off-heap-memoryhttpsgithubcomapacheflinkpull290&quot;&gt;&lt;a 
href=&quot;https://github.com/apache/flink/pull/290&quot;&gt;Using off-heap 
memory&lt;/a&gt;&lt;/h3&gt;
 
-&lt;p&gt;This pull request enables Flink to use off-heap memory for its 
internal memory uses (sort, hash, caching of intermediate data sets). &lt;/p&gt;
+&lt;p&gt;This pull request enables Flink to use off-heap memory for its 
internal memory uses (sort, hash, caching of intermediate data sets).&lt;/p&gt;
 
 &lt;h3 
id=&quot;gelly-flinks-graph-apihttpsgithubcomapacheflinkpull335&quot;&gt;&lt;a 
href=&quot;https://github.com/apache/flink/pull/335&quot;&gt;Gelly, Flink’s 
Graph API&lt;/a&gt;&lt;/h3&gt;
 
@@ -1849,7 +1849,7 @@ internally, fault tolerance, and performance 
measurements!&lt;/p&gt;
   &lt;li&gt;Stefan Bunk&lt;/li&gt;
   &lt;li&gt;Paris Carbone&lt;/li&gt;
   &lt;li&gt;Ufuk Celebi&lt;/li&gt;
-  &lt;li&gt;Nils Engelbach &lt;/li&gt;
+  &lt;li&gt;Nils Engelbach&lt;/li&gt;
   &lt;li&gt;Stephan Ewen&lt;/li&gt;
   &lt;li&gt;Gyula Fora&lt;/li&gt;
   &lt;li&gt;Gabor Hermann&lt;/li&gt;
@@ -1954,7 +1954,7 @@ Flink serialization system improved a lot over time and 
by now surpasses the cap
 &lt;img src=&quot;/img/blog/hcompat-logos.png&quot; 
style=&quot;width:30%;margin:15px&quot; /&gt;
 &lt;/center&gt;
 
-&lt;p&gt;To close this gap, Flink provides a Hadoop Compatibility package to 
wrap functions implemented against Hadoop’s MapReduce interfaces and embed 
them in Flink programs. This package was developed as part of a &lt;a 
href=&quot;https://developers.google.com/open-source/soc/&quot;&gt;Google 
Summer of Code&lt;/a&gt; 2014 project. &lt;/p&gt;
+&lt;p&gt;To close this gap, Flink provides a Hadoop Compatibility package to 
wrap functions implemented against Hadoop’s MapReduce interfaces and embed 
them in Flink programs. This package was developed as part of a &lt;a 
href=&quot;https://developers.google.com/open-source/soc/&quot;&gt;Google 
Summer of Code&lt;/a&gt; 2014 project.&lt;/p&gt;
 
 &lt;p&gt;With the Hadoop Compatibility package, you can reuse all your 
Hadoop&lt;/p&gt;
 
@@ -1967,7 +1967,7 @@ Flink serialization system improved a lot over time and 
by now surpasses the cap
 
 &lt;p&gt;in Flink programs without changing a line of code. Moreover, Flink 
also natively supports all Hadoop data types 
(&lt;code&gt;Writables&lt;/code&gt; and 
&lt;code&gt;WritableComparable&lt;/code&gt;).&lt;/p&gt;
 
-&lt;p&gt;The following code snippet shows a simple Flink WordCount program 
that solely uses Hadoop data types, InputFormat, OutputFormat, Mapper, and 
Reducer functions. &lt;/p&gt;
+&lt;p&gt;The following code snippet shows a simple Flink WordCount program 
that solely uses Hadoop data types, InputFormat, OutputFormat, Mapper, and 
Reducer functions.&lt;/p&gt;
 
 &lt;div class=&quot;highlight&quot;&gt;&lt;pre&gt;&lt;code 
class=&quot;language-java&quot;&gt;&lt;span class=&quot;c1&quot;&gt;// 
Definition of Hadoop Mapper function&lt;/span&gt;
 &lt;span class=&quot;kd&quot;&gt;public&lt;/span&gt; &lt;span 
class=&quot;kd&quot;&gt;class&lt;/span&gt; &lt;span 
class=&quot;nc&quot;&gt;Tokenizer&lt;/span&gt; &lt;span 
class=&quot;kd&quot;&gt;implements&lt;/span&gt; &lt;span 
class=&quot;n&quot;&gt;Mapper&lt;/span&gt;&lt;span 
class=&quot;o&quot;&gt;&amp;lt;&lt;/span&gt;&lt;span 
class=&quot;n&quot;&gt;LongWritable&lt;/span&gt;&lt;span 
class=&quot;o&quot;&gt;,&lt;/span&gt; &lt;span 
class=&quot;n&quot;&gt;Text&lt;/span&gt;&lt;span 
class=&quot;o&quot;&gt;,&lt;/span&gt; &lt;span 
class=&quot;n&quot;&gt;Text&lt;/span&gt;&lt;span 
class=&quot;o&quot;&gt;,&lt;/span&gt; &lt;span 
class=&quot;n&quot;&gt;LongWritable&lt;/span&gt;&lt;span 
class=&quot;o&quot;&gt;&amp;gt;&lt;/span&gt; &lt;span 
class=&quot;o&quot;&gt;{&lt;/span&gt; &lt;span 
class=&quot;o&quot;&gt;...&lt;/span&gt; &lt;span 
class=&quot;o&quot;&gt;}&lt;/span&gt;
@@ -2053,7 +2053,7 @@ Flink serialization system improved a lot over time and 
by now surpasses the cap
 
 &lt;p&gt;&lt;strong&gt;Record API deprecated:&lt;/strong&gt; The (old) 
Stratosphere Record API has been marked as deprecated and is planned for 
removal in the 0.9.0 release.&lt;/p&gt;
 
-&lt;p&gt;&lt;strong&gt;BLOB service:&lt;/strong&gt; This release contains a 
new service to distribute jar files and other binary data among the JobManager, 
TaskManagers and the client. &lt;/p&gt;
+&lt;p&gt;&lt;strong&gt;BLOB service:&lt;/strong&gt; This release contains a 
new service to distribute jar files and other binary data among the JobManager, 
TaskManagers and the client.&lt;/p&gt;
 
 &lt;p&gt;&lt;strong&gt;Intermediate data sets:&lt;/strong&gt; A major rewrite 
of the system internals introduces intermediate data sets as first class 
citizens. The internal state machine that tracks the distributed tasks has also 
been completely rewritten for scalability. While this is not visible as a 
user-facing feature yet, it is the foundation for several upcoming exciting 
features.&lt;/p&gt;
 
@@ -2489,7 +2489,7 @@ Applying students can use our wiki (create a new page) to 
create a project propo
 ssh [email protected] -i 
~/Downloads/work-laptop.pem&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
 
 &lt;p&gt;(Windows users have to follow &lt;a 
href=&quot;http://docs.aws.amazon.com/ElasticMapReduce/latest/DeveloperGuide/emr-connect-master-node-ssh.html&quot;&gt;these
 instructions&lt;/a&gt; to SSH into the machine running the master.) 
&amp;lt;/br&amp;gt;&amp;lt;/br&amp;gt;
-Once connected to the master, download and start Stratosphere for YARN: 
&lt;/p&gt;
+Once connected to the master, download and start Stratosphere for 
YARN:&lt;/p&gt;
 &lt;ul&gt;
        &lt;li&gt;Download and extract Stratosphere-YARN&lt;/li&gt;
 
@@ -2512,11 +2512,11 @@ The arguments have the following meaning
        &lt;/ul&gt;
 &lt;/ul&gt;
 
-&lt;p&gt;Once the output has changed from &lt;/p&gt;
+&lt;p&gt;Once the output has changed from&lt;/p&gt;
 
 &lt;div class=&quot;highlight&quot;&gt;&lt;pre&gt;&lt;code 
class=&quot;language-bash&quot; data-lang=&quot;bash&quot;&gt;JobManager is now 
running on N/A:6123&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
 
-&lt;p&gt;to &lt;/p&gt;
+&lt;p&gt;to&lt;/p&gt;
 
 &lt;div class=&quot;highlight&quot;&gt;&lt;pre&gt;&lt;code 
class=&quot;language-bash&quot; data-lang=&quot;bash&quot;&gt;JobManager is now 
running on 
ip-172-31-13-68.us-west-2.compute.internal:6123&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;
 
@@ -2738,7 +2738,7 @@ You can now press the “Run” button and see how 
Stratosphere executes the lit
 
 <item>
 <title>Stratosphere 0.4 Released</title>
-<description>&lt;p&gt;We are pleased to announce that version 0.4 of the 
Stratosphere system has been released. &lt;/p&gt;
+<description>&lt;p&gt;We are pleased to announce that version 0.4 of the 
Stratosphere system has been released.&lt;/p&gt;
 
 &lt;p&gt;Our team has been working hard during the last few months to create 
an improved and stable Stratosphere version. The new version comes with many 
new features, usability and performance improvements in all levels, including a 
new Scala API for the concise specification of programs, a Pregel-like API, 
support for Yarn clusters, and major performance improvements. The system 
features now first-class support for iterative programs and thus covers 
traditional analytical use cases as well as data mining and graph processing 
use cases with great performance.&lt;/p&gt;
 
@@ -2766,7 +2766,7 @@ Follow &lt;a 
href=&quot;/docs/0.4/setup/yarn.html&quot;&gt;our guide&lt;/a&gt; o
 &lt;p&gt;The high-level language Meteor now natively serializes JSON trees for 
greater performance and offers additional operators and file formats. We 
greatly empowered the user to write crispier scripts by adding second-order 
functions, multi-output operators, and other syntactical sugar. For developers 
of Meteor packages, the API is much more comprehensive and allows to define 
custom data types that can be easily embedded in JSON trees through ad-hoc byte 
code generation.&lt;/p&gt;
 
 &lt;h3 id=&quot;spargel-pregel-inspired-graph-processing&quot;&gt;Spargel: 
Pregel Inspired Graph Processing&lt;/h3&gt;
-&lt;p&gt;Spargel is a vertex-centric API similar to the interface proposed in 
Google’s Pregel paper and implemented in Apache Giraph. Spargel is 
implemented in 500 lines of code (including comments) on top of 
Stratosphere’s delta iterations feature. This confirms the flexibility of 
Stratosphere’s architecture. &lt;/p&gt;
+&lt;p&gt;Spargel is a vertex-centric API similar to the interface proposed in 
Google’s Pregel paper and implemented in Apache Giraph. Spargel is 
implemented in 500 lines of code (including comments) on top of 
Stratosphere’s delta iterations feature. This confirms the flexibility of 
Stratosphere’s architecture.&lt;/p&gt;
 
 &lt;h3 id=&quot;web-frontend&quot;&gt;Web Frontend&lt;/h3&gt;
 &lt;p&gt;Using the new web frontend, you can monitor the progress of 
Stratosphere jobs. For finished jobs, the frontend shows a breakdown of the 
execution times for each operator. The webclient also visualizes the execution 
strategies chosen by the optimizer.&lt;/p&gt;
@@ -2794,7 +2794,7 @@ Follow &lt;a 
href=&quot;/docs/0.4/setup/yarn.html&quot;&gt;our guide&lt;/a&gt; o
 &lt;/ul&gt;
 
 &lt;h3 
id=&quot;download-and-get-started-with-stratosphere-v04&quot;&gt;Download and 
get started with Stratosphere v0.4&lt;/h3&gt;
-&lt;p&gt;There are several options for getting started with Stratosphere. 
&lt;/p&gt;
+&lt;p&gt;There are several options for getting started with 
Stratosphere.&lt;/p&gt;
 
 &lt;ul&gt;
   &lt;li&gt;Download it on the &lt;a href=&quot;/downloads&quot;&gt;download 
page&lt;/a&gt;&lt;/li&gt;

http://git-wip-us.apache.org/repos/asf/flink-web/blob/396616d4/content/blog/index.html
----------------------------------------------------------------------
diff --git a/content/blog/index.html b/content/blog/index.html
index f377375..e801faf 100644
--- a/content/blog/index.html
+++ b/content/blog/index.html
@@ -52,10 +52,10 @@
             <li class="dropdown">
               <a href="#" class="dropdown-toggle" data-toggle="dropdown" 
role="button" aria-expanded="false">Quickstart <span class="caret"></span></a>
               <ul class="dropdown-menu" role="menu">
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/quickstart/setup_quickstart.html";>Setup</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/quickstart/java_api_quickstart.html";>Java
 API</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/quickstart/scala_api_quickstart.html";>Scala
 API</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/quickstart/run_example_quickstart.html";>Run
 Step-by-Step Example</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/quickstart/setup_quickstart.html";>Setup</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/quickstart/java_api_quickstart.html";>Java
 API</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/quickstart/scala_api_quickstart.html";>Scala
 API</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/quickstart/run_example_quickstart.html";>Run
 Step-by-Step Example</a></li>
               </ul>
             </li>
 
@@ -71,16 +71,18 @@
               <ul class="dropdown-menu" role="menu">
                 <!-- Latest stable release -->
                 <li role="presentation" class="dropdown-header"><strong>Latest 
Release</strong> (Stable)</li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9";>0.9.0 
Documentation</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/api/java"; 
class="active">0.9.0 Javadocs</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/api/scala/index.html";
 class="active">0.9.0 ScalaDocs</a></li>
+                <li><a href="/docs/0.9">0.9.0 Documentation</a></li>
+                <!-- <li><a href="http://flink.apache.org/docs/0.9";>0.9.0 
Documentation</a></li>
+                <li><a href="http://flink.apache.org/docs/0.9/api/java"; 
class="active">0.9.0 Javadocs</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/api/scala/index.html"; 
class="active">0.9.0 ScalaDocs</a></li> -->
 
                 <!-- Snapshot docs -->
                 <li class="divider"></li>
                 <li role="presentation" 
class="dropdown-header"><strong>Snapshot</strong> (Development)</li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-master";>0.10 
Documentation</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-master/api/java"; 
class="active">0.10 Javadocs</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-master/api/scala/index.html";
 class="active">0.10 ScalaDocs</a></li>
+                <li><a href="/docs/master">0.9.0 Documentation</a></li>
+                <!-- <li><a href="http://flink.apache.org/docs/master";>0.10 
Documentation</a></li>
+                <li><a href="http://flink.apache.org/docs/master/api/java"; 
class="active">0.10 Javadocs</a></li>
+                <li><a 
href="http://flink.apache.org/docs/master/api/scala/index.html"; 
class="active">0.10 ScalaDocs</a></li> -->
 
                 <!-- Wiki -->
                 <li class="divider"></li>

http://git-wip-us.apache.org/repos/asf/flink-web/blob/396616d4/content/blog/page2/index.html
----------------------------------------------------------------------
diff --git a/content/blog/page2/index.html b/content/blog/page2/index.html
index 609a749..eebc5df 100644
--- a/content/blog/page2/index.html
+++ b/content/blog/page2/index.html
@@ -52,10 +52,10 @@
             <li class="dropdown">
               <a href="#" class="dropdown-toggle" data-toggle="dropdown" 
role="button" aria-expanded="false">Quickstart <span class="caret"></span></a>
               <ul class="dropdown-menu" role="menu">
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/quickstart/setup_quickstart.html";>Setup</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/quickstart/java_api_quickstart.html";>Java
 API</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/quickstart/scala_api_quickstart.html";>Scala
 API</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/quickstart/run_example_quickstart.html";>Run
 Step-by-Step Example</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/quickstart/setup_quickstart.html";>Setup</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/quickstart/java_api_quickstart.html";>Java
 API</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/quickstart/scala_api_quickstart.html";>Scala
 API</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/quickstart/run_example_quickstart.html";>Run
 Step-by-Step Example</a></li>
               </ul>
             </li>
 
@@ -71,16 +71,18 @@
               <ul class="dropdown-menu" role="menu">
                 <!-- Latest stable release -->
                 <li role="presentation" class="dropdown-header"><strong>Latest 
Release</strong> (Stable)</li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9";>0.9.0 
Documentation</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/api/java"; 
class="active">0.9.0 Javadocs</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-release-0.9/api/scala/index.html";
 class="active">0.9.0 ScalaDocs</a></li>
+                <li><a href="/docs/0.9">0.9.0 Documentation</a></li>
+                <!-- <li><a href="http://flink.apache.org/docs/0.9";>0.9.0 
Documentation</a></li>
+                <li><a href="http://flink.apache.org/docs/0.9/api/java"; 
class="active">0.9.0 Javadocs</a></li>
+                <li><a 
href="http://flink.apache.org/docs/0.9/api/scala/index.html"; 
class="active">0.9.0 ScalaDocs</a></li> -->
 
                 <!-- Snapshot docs -->
                 <li class="divider"></li>
                 <li role="presentation" 
class="dropdown-header"><strong>Snapshot</strong> (Development)</li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-master";>0.10 
Documentation</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-master/api/java"; 
class="active">0.10 Javadocs</a></li>
-                <li><a 
href="http://ci.apache.org/projects/flink/flink-docs-master/api/scala/index.html";
 class="active">0.10 ScalaDocs</a></li>
+                <li><a href="/docs/master">0.9.0 Documentation</a></li>
+                <!-- <li><a href="http://flink.apache.org/docs/master";>0.10 
Documentation</a></li>
+                <li><a href="http://flink.apache.org/docs/master/api/java"; 
class="active">0.10 Javadocs</a></li>
+                <li><a 
href="http://flink.apache.org/docs/master/api/scala/index.html"; 
class="active">0.10 ScalaDocs</a></li> -->
 
                 <!-- Wiki -->
                 <li class="divider"></li>

Reply via email to