閒來無事,編個Flink 1.9 玩玩java
一、下載flink、flink-shaded 源碼、解壓python
[venn@venn release]$ ll total 19880 drwxrwxr-x. 44 venn venn 4096 Sep 12 14:00 flink-release-1.9.0 drwxrwxr-x. 13 venn venn 4096 Sep 11 11:05 flink-shaded-release-7.0 -rw-rw-r--. 1 venn venn 20318507 Sep 12 09:24 release-1.9.0.tar.gz -rw-rw-r--. 1 venn venn 28196 Sep 11 11:05 release-7.0.tar.gz
最開始直接拿flink 的 releast-1.9分支,發現都帶了SNAPSHOT,遂放棄git
flink-shaded 包含flink 的不少依賴,好比 flink-shaded-hadoop-2,中央倉庫只提供了幾個hadoop 版本的包,可能沒有與本身hadoop 對應的 flink-shaded-hadoop-2 的包。flink1.9 對應的flink-shaded 版本是 7.0github
<dependency> <groupId>org.apache.flink</groupId> <artifactId>flink-shaded-hadoop-2</artifactId> <version>${hadoop.version}-${flink.shaded.version}</version> <optional>true</optional> </dependency>
我用的hadoop 版本是2.7.7,然而並無(2.7.5應該能夠用)。web
二、編譯flink-shadedsql
指定hadoop版本2.7.7, 把編譯好的包打到本地maven倉庫,後面編譯flink 用shell
[venn@venn flink-shaded-release-7.0]$ mvn clean install -DskipTest -Dhadoop.version=2.7.7 [INFO] Reactor Summary: [INFO] [INFO] flink-shaded 7.0 ................................... SUCCESS [ 3.483 s] [INFO] flink-shaded-force-shading 7.0 ..................... SUCCESS [ 0.597 s] [INFO] flink-shaded-asm-6 6.2.1-7.0 ....................... SUCCESS [ 0.627 s] [INFO] flink-shaded-guava-18 18.0-7.0 ..................... SUCCESS [ 0.994 s] [INFO] flink-shaded-netty-4 4.1.32.Final-7.0 .............. SUCCESS [ 3.469 s] [INFO] flink-shaded-netty-tcnative-dynamic 2.0.25.Final-7.0 SUCCESS [ 0.572 s] [INFO] flink-shaded-jackson-parent 2.9.8-7.0 .............. SUCCESS [ 0.035 s] [INFO] flink-shaded-jackson-2 2.9.8-7.0 ................... SUCCESS [ 1.479 s] [INFO] flink-shaded-jackson-module-jsonSchema-2 2.9.8-7.0 . SUCCESS [ 0.857 s] [INFO] flink-shaded-hadoop-2 2.7.7-7.0 .................... SUCCESS [ 9.132 s] [INFO] flink-shaded-hadoop-2-uber 2.7.7-7.0 ............... SUCCESS [ 17.173 s] [INFO] ------------------------------------------------------------------------ [INFO] BUILD SUCCESS [INFO] ------------------------------------------------------------------------ [INFO] Total time: 38.612 s [INFO] Finished at: 2019-09-12T15:14:42+08:00 [INFO] ------------------------------------------------------------------------
三、編譯 flinkapache
指定hadoop 版本 2.7.7json
[venn@venn flink-release-1.9.0]$ mvn clean package -DskipTests -Dhadoop.version=2.7.7 [INFO] Reactor Summary for flink 1.9.0: [INFO] [INFO] force-shading ...................................... SUCCESS [ 1.281 s] [INFO] flink .............................................. SUCCESS [ 1.829 s] [INFO] flink-annotations .................................. SUCCESS [ 1.280 s] [INFO] flink-shaded-curator ............................... SUCCESS [ 1.501 s] [INFO] flink-metrics ...................................... SUCCESS [ 0.188 s] [INFO] flink-metrics-core ................................. SUCCESS [ 0.736 s] [INFO] flink-test-utils-parent ............................ SUCCESS [ 0.157 s] [INFO] flink-test-utils-junit ............................. SUCCESS [ 0.928 s] [INFO] flink-core ......................................... SUCCESS [ 33.771 s] [INFO] flink-java ......................................... SUCCESS [ 4.827 s] [INFO] flink-queryable-state .............................. SUCCESS [ 0.100 s] [INFO] flink-queryable-state-client-java .................. SUCCESS [ 0.643 s] [INFO] flink-filesystems .................................. SUCCESS [ 0.082 s] [INFO] flink-hadoop-fs .................................... SUCCESS [ 1.168 s] [INFO] flink-runtime ...................................... SUCCESS [01:58 min] [INFO] flink-scala ........................................ SUCCESS [ 29.960 s] [INFO] flink-mapr-fs ...................................... SUCCESS [ 0.394 s] [INFO] flink-filesystems :: flink-fs-hadoop-shaded ........ SUCCESS [ 2.916 s] [INFO] flink-s3-fs-base ................................... SUCCESS [ 5.740 s] [INFO] flink-s3-fs-hadoop ................................. SUCCESS [ 8.235 s] [INFO] flink-s3-fs-presto ................................. SUCCESS [ 12.510 s] [INFO] flink-swift-fs-hadoop .............................. SUCCESS [ 13.618 s] [INFO] flink-oss-fs-hadoop ................................ SUCCESS [ 4.483 s] [INFO] flink-azure-fs-hadoop .............................. SUCCESS [ 5.729 s] [INFO] flink-optimizer .................................... SUCCESS [ 11.589 s] [INFO] flink-clients ...................................... SUCCESS [ 1.179 s] [INFO] flink-streaming-java ............................... SUCCESS [ 8.882 s] [INFO] flink-test-utils ................................... SUCCESS [ 1.453 s] [INFO] flink-runtime-web .................................. SUCCESS [02:06 min] [INFO] flink-examples ..................................... SUCCESS [ 0.112 s] [INFO] flink-examples-batch ............................... SUCCESS [ 10.577 s] [INFO] flink-connectors ................................... SUCCESS [ 0.096 s] [INFO] flink-hadoop-compatibility ......................... SUCCESS [ 4.225 s] [INFO] flink-state-backends ............................... SUCCESS [ 0.070 s] [INFO] flink-statebackend-rocksdb ......................... SUCCESS [ 1.102 s] [INFO] flink-tests ........................................ SUCCESS [ 28.820 s] [INFO] flink-streaming-scala .............................. SUCCESS [ 26.143 s] [INFO] flink-table ........................................ SUCCESS [ 0.054 s] [INFO] flink-table-common ................................. SUCCESS [ 1.771 s] [INFO] flink-table-api-java ............................... SUCCESS [ 1.416 s] [INFO] flink-table-api-java-bridge ........................ SUCCESS [ 0.570 s] [INFO] flink-table-api-scala .............................. SUCCESS [ 5.054 s] [INFO] flink-table-api-scala-bridge ....................... SUCCESS [ 7.626 s] [INFO] flink-sql-parser ................................... SUCCESS [ 3.073 s] [INFO] flink-libraries .................................... SUCCESS [ 0.056 s] [INFO] flink-cep .......................................... SUCCESS [ 2.437 s] [INFO] flink-table-planner ................................ SUCCESS [01:37 min] [INFO] flink-orc .......................................... SUCCESS [ 0.579 s] [INFO] flink-jdbc ......................................... SUCCESS [ 0.546 s] [INFO] flink-table-runtime-blink .......................... SUCCESS [ 3.868 s] [INFO] flink-table-planner-blink .......................... SUCCESS [02:02 min] [INFO] flink-hbase ........................................ SUCCESS [ 1.725 s] [INFO] flink-hcatalog ..................................... SUCCESS [ 4.158 s] [INFO] flink-metrics-jmx .................................. SUCCESS [ 0.272 s] [INFO] flink-connector-kafka-base ......................... SUCCESS [ 1.671 s] [INFO] flink-connector-kafka-0.9 .......................... SUCCESS [ 0.768 s] [INFO] flink-connector-kafka-0.10 ......................... SUCCESS [ 0.547 s] [INFO] flink-connector-kafka-0.11 ......................... SUCCESS [ 0.692 s] [INFO] flink-formats ...................................... SUCCESS [ 0.054 s] [INFO] flink-json ......................................... SUCCESS [ 0.332 s] [INFO] flink-connector-elasticsearch-base ................. SUCCESS [ 0.810 s] [INFO] flink-connector-elasticsearch2 ..................... SUCCESS [ 8.239 s] [INFO] flink-connector-elasticsearch5 ..................... SUCCESS [ 9.715 s] [INFO] flink-connector-elasticsearch6 ..................... SUCCESS [ 0.747 s] [INFO] flink-csv .......................................... SUCCESS [ 0.251 s] [INFO] flink-connector-hive ............................... SUCCESS [ 1.942 s] [INFO] flink-connector-rabbitmq ........................... SUCCESS [ 0.332 s] [INFO] flink-connector-twitter ............................ SUCCESS [ 1.304 s] [INFO] flink-connector-nifi ............................... SUCCESS [ 0.349 s] [INFO] flink-connector-cassandra .......................... SUCCESS [ 2.205 s] [INFO] flink-avro ......................................... SUCCESS [ 1.565 s] [INFO] flink-connector-filesystem ......................... SUCCESS [ 0.861 s] [INFO] flink-connector-kafka .............................. SUCCESS [ 0.973 s] [INFO] flink-connector-gcp-pubsub ......................... SUCCESS [ 0.582 s] [INFO] flink-sql-connector-elasticsearch6 ................. SUCCESS [ 4.583 s] [INFO] flink-sql-connector-kafka-0.9 ...................... SUCCESS [ 0.256 s] [INFO] flink-sql-connector-kafka-0.10 ..................... SUCCESS [ 0.312 s] [INFO] flink-sql-connector-kafka-0.11 ..................... SUCCESS [ 0.413 s] [INFO] flink-sql-connector-kafka .......................... SUCCESS [ 0.641 s] [INFO] flink-connector-kafka-0.8 .......................... SUCCESS [ 0.700 s] [INFO] flink-avro-confluent-registry ...................... SUCCESS [ 0.843 s] [INFO] flink-parquet ...................................... SUCCESS [ 0.726 s] [INFO] flink-sequence-file ................................ SUCCESS [ 0.247 s] [INFO] flink-examples-streaming ........................... SUCCESS [ 10.970 s] [INFO] flink-examples-table ............................... SUCCESS [ 5.554 s] [INFO] flink-examples-build-helper ........................ SUCCESS [ 0.069 s] [INFO] flink-examples-streaming-twitter ................... SUCCESS [ 0.464 s] [INFO] flink-examples-streaming-state-machine ............. SUCCESS [ 0.298 s] [INFO] flink-examples-streaming-gcp-pubsub ................ SUCCESS [ 3.640 s] [INFO] flink-container .................................... SUCCESS [ 0.304 s] [INFO] flink-queryable-state-runtime ...................... SUCCESS [ 0.555 s] [INFO] flink-end-to-end-tests ............................. SUCCESS [ 0.056 s] [INFO] flink-cli-test ..................................... SUCCESS [ 0.151 s] [INFO] flink-parent-child-classloading-test-program ....... SUCCESS [ 0.154 s] [INFO] flink-parent-child-classloading-test-lib-package ... SUCCESS [ 0.098 s] [INFO] flink-dataset-allround-test ........................ SUCCESS [ 0.153 s] [INFO] flink-dataset-fine-grained-recovery-test ........... SUCCESS [ 0.141 s] [INFO] flink-datastream-allround-test ..................... SUCCESS [ 1.119 s] [INFO] flink-batch-sql-test ............................... SUCCESS [ 0.136 s] [INFO] flink-stream-sql-test .............................. SUCCESS [ 0.183 s] [INFO] flink-bucketing-sink-test .......................... SUCCESS [ 0.233 s] [INFO] flink-distributed-cache-via-blob ................... SUCCESS [ 0.138 s] [INFO] flink-high-parallelism-iterations-test ............. SUCCESS [ 5.724 s] [INFO] flink-stream-stateful-job-upgrade-test ............. SUCCESS [ 0.636 s] [INFO] flink-queryable-state-test ......................... SUCCESS [ 1.688 s] [INFO] flink-local-recovery-and-allocation-test ........... SUCCESS [ 0.221 s] [INFO] flink-elasticsearch2-test .......................... SUCCESS [ 3.299 s] [INFO] flink-elasticsearch5-test .......................... SUCCESS [ 3.969 s] [INFO] flink-elasticsearch6-test .......................... SUCCESS [ 2.275 s] [INFO] flink-quickstart ................................... SUCCESS [ 0.781 s] [INFO] flink-quickstart-java .............................. SUCCESS [ 0.350 s] [INFO] flink-quickstart-scala ............................. SUCCESS [ 0.145 s] [INFO] flink-quickstart-test .............................. SUCCESS [ 0.323 s] [INFO] flink-confluent-schema-registry .................... SUCCESS [ 1.202 s] [INFO] flink-stream-state-ttl-test ........................ SUCCESS [ 3.172 s] [INFO] flink-sql-client-test .............................. SUCCESS [ 0.671 s] [INFO] flink-streaming-file-sink-test ..................... SUCCESS [ 0.221 s] [INFO] flink-state-evolution-test ......................... SUCCESS [ 0.822 s] [INFO] flink-e2e-test-utils ............................... SUCCESS [ 6.170 s] [INFO] flink-mesos ........................................ SUCCESS [ 17.591 s] [INFO] flink-yarn ......................................... SUCCESS [ 0.915 s] [INFO] flink-gelly ........................................ SUCCESS [ 2.601 s] [INFO] flink-gelly-scala .................................. SUCCESS [ 13.500 s] [INFO] flink-gelly-examples ............................... SUCCESS [ 7.711 s] [INFO] flink-metrics-dropwizard ........................... SUCCESS [ 0.193 s] [INFO] flink-metrics-graphite ............................. SUCCESS [ 0.123 s] [INFO] flink-metrics-influxdb ............................. SUCCESS [ 0.594 s] [INFO] flink-metrics-prometheus ........................... SUCCESS [ 0.371 s] [INFO] flink-metrics-statsd ............................... SUCCESS [ 0.179 s] [INFO] flink-metrics-datadog .............................. SUCCESS [ 0.237 s] [INFO] flink-metrics-slf4j ................................ SUCCESS [ 0.157 s] [INFO] flink-cep-scala .................................... SUCCESS [ 9.399 s] [INFO] flink-table-uber ................................... SUCCESS [ 1.794 s] [INFO] flink-table-uber-blink ............................. SUCCESS [ 2.050 s] [INFO] flink-sql-client ................................... SUCCESS [ 1.090 s] [INFO] flink-state-processor-api .......................... SUCCESS [ 0.598 s] [INFO] flink-python ....................................... SUCCESS [ 0.621 s] [INFO] flink-scala-shell .................................. SUCCESS [ 8.821 s] [INFO] flink-dist ......................................... SUCCESS [ 10.765 s] [INFO] flink-end-to-end-tests-common ...................... SUCCESS [ 0.285 s] [INFO] flink-metrics-availability-test .................... SUCCESS [ 0.153 s] [INFO] flink-metrics-reporter-prometheus-test ............. SUCCESS [ 0.132 s] [INFO] flink-heavy-deployment-stress-test ................. SUCCESS [ 6.045 s] [INFO] flink-connector-gcp-pubsub-emulator-tests .......... SUCCESS [ 0.516 s] [INFO] flink-streaming-kafka-test-base .................... SUCCESS [ 0.192 s] [INFO] flink-streaming-kafka-test ......................... SUCCESS [ 5.923 s] [INFO] flink-streaming-kafka011-test ...................... SUCCESS [ 5.786 s] [INFO] flink-streaming-kafka010-test ...................... SUCCESS [ 5.000 s] [INFO] flink-plugins-test ................................. SUCCESS [ 0.095 s] [INFO] flink-tpch-test .................................... SUCCESS [ 1.210 s] [INFO] flink-contrib ...................................... SUCCESS [ 0.052 s] [INFO] flink-connector-wikiedits .......................... SUCCESS [ 0.258 s] [INFO] flink-yarn-tests ................................... SUCCESS [ 2.919 s] [INFO] flink-fs-tests ..................................... SUCCESS [ 0.330 s] [INFO] flink-docs ......................................... SUCCESS [ 0.531 s] [INFO] flink-ml-parent .................................... SUCCESS [ 0.052 s] [INFO] flink-ml-api ....................................... SUCCESS [ 0.284 s] [INFO] flink-ml-lib ....................................... SUCCESS [ 0.164 s] [INFO] ------------------------------------------------------------------------ [INFO] BUILD SUCCESS [INFO] ------------------------------------------------------------------------ [INFO] Total time: 15:33 min [INFO] Finished at: 2019-09-12T17:41:19+08:00 [INFO] ------------------------------------------------------------------------
正常狀況耗時15分鐘,異常是可能會卡在 flink-runtime和 flink-runtime-web 上面
四、遇到的問題
1)、 flink 1.9 中移除了 map-r 的包,全部不用在這上面耗時間,可是我在編譯的時候,仍是遇到不少包沒法下載(阿里雲的鏡像都有),只好在本地下載,上傳上去(centos 的虛擬機裏編譯的,虛擬機下不下的包,本地均可以正常下載,就把本地的倉庫覆蓋上去了)
2)、 flink-runtime/flink-runtime-web 有時候會編譯好久
3)、編譯flink-table-api-java 的時候編譯不過
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.0:compile (default-compile) on project flink-table-api-java: Compilation failure [ERROR] /home/venn/git/release/flink-release-1.9.0/flink-table/flink-table-api-java/src/main/java/org/apache/flink/table/operations/ut
ils/factories/AggregateOperationFactory.java:[550,53] unreported exception X; must be caught or declared to be thrown [ERROR] [ERROR] -> [Help 1] [ERROR] [ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch. [ERROR] Re-run Maven using the -X switch to enable full debug logging. [ERROR] [ERROR] For more information about the errors and possible solutions, please read the following articles: [ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException [ERROR] [ERROR] After correcting the problems, you can resume the build with the command [ERROR] mvn <args> -rf :flink-table-api-java
是低版本jdk的bug,下面這種用法有點問題
List<String> aliases = children.subList(1, children.size()) .stream() .map(alias -> ExpressionUtils.extractValue(alias, String.class) .orElseThrow(() -> new ValidationException("Unexpected alias: " + alias))) .collect(toList());
解決方法: 升級jdk 1.8 的小版本, 從jdk1.8.0_91 升到 jdk1.8.0_111 解決了
4)、能夠預裝個 gcc、gcc-c++,中間會有報錯,不過應該不影響