Hi Flink: Recently we meet a problem that we have to test and run Flink on ARM arch. While after searching Flink community, I didn’t find an official ARM release version.
Since Flink is made by Java and Scala language which can be ran cross-platform usually, I think Flink can be built and ran on ARM directly as well. Then with my local test, Flink was built and deployed success as expected. But some tests were failed due to ARM arch. For example: 1. MemoryArchitectureTest.testArchitectureNotUnknown:34 Values should be different. Actual: UNKNOWN 2. [ERROR] testIterator(org.apache.flink.contrib.streaming.state.RocksDBRocksStateKeysIteratorTest) Time elapsed: 0.234 s <<< ERROR! java.io.IOException: Could not load the native RocksDB library at org.apache.flink.contrib.streaming.state.RocksDBRocksStateKeysIteratorTest.testIteratorHelper(RocksDBRocksStateKeysIteratorTest.java:90) at org.apache.flink.contrib.streaming.state.RocksDBRocksStateKeysIteratorTest.testIterator(RocksDBRocksStateKeysIteratorTest.java:63) Caused by: java.lang.UnsatisfiedLinkError: /tmp/rocksdb-lib-81ca7930b92af2cca143a050c0338d34/librocksdbjni-linux64.so: /tmp/rocksdb-lib-81ca7930b92af2cca143a050c0338d34/librocksdbjni-linux64.so: cannot open shared object file: No such file or directory (Possible cause: can't load AMD 64-bit .so on a AARCH64-bit platform) … Since the test isn’t passed totally, we are not sure if Flink 100% support ARM or not. Is it possible for Flink to support ARM release officially? I guess it may be not a very huge work basing on Java. I notice that Flink now uses trivis-ci which is X86 only for build & test check. Is it possible to add an ARM arch CI as well? It can be non-voting first. Then we can keep monitoring and fixing ARM related error. One day it’s stable enough, we can remove the non-voting tag and create Flink ARM release. There is an open source CI community called OpenLab[1] which can provide CI function and ARM resource to Flink by free. I’m one of the OpenLab members. If Flink commun think ARM support is fine, I can keep helping Flink to build and maintain the ARM CI job. There is an POC for Flink ARM build job made by me on OpenLab system[2] and a live demo which built and run on an ARM VM[3]. You can take a look first. Eager to get everybody’s feedback. Any question is welcome. Thanks. [1]: https://openlabtesting.org/ [2]: https://github.com/theopenlab/flink/pull/1 [3]: http://114.115.168.52:8081/#/overview