Andrew Janke created FLINK-9445:
-----------------------------------
Summary: start-scala-shell.sh fails on macOS when Java 9 & 10 are
installed
Key: FLINK-9445
URL: https://issues.apache.org/jira/browse/FLINK-9445
Project: Flink
Issue Type: Bug
Affects Versions: 1.5.0
Environment: macOS High Sierra 10.13.4
$ sw_vers
ProductName: Mac OS X
ProductVersion: 10.13.4
BuildVersion: 17E202
I have multiple JDKs installed:
$ ls /Library/Java/JavaVirtualMachines
jdk-10.0.1.jdk jdk-9.0.4.jdk jdk1.7.0_79.jdk jdk1.8.0_141.jdk
Reporter: Andrew Janke
I'm attempting to install and test apache-flink 1.5.0 on macOS using Homebrew.
The test step runs flink's `start-scala-shell.sh` to exercise the package. When
I do this, it issues some warnings about log4j and reflective access, and then
hangs.
$ brew test apache-flink
Testing apache-flink
==> /usr/local/Cellar/apache-flink/1.5.0/libexec/bin/start-scala-shell.sh local
Picked up _JAVA_OPTIONS:
-Djava.io.tmpdir=/tmp/apache-flink-test-20180526-20068-19gl4zf
-Duser.home=/Users/janke/Library/Caches/Homebrew/java_cache
log4j:WARN No appenders could be found for logger
(org.apache.flink.configuration.GlobalConfiguration).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See [http://logging.apache.org/log4j/1.2/faq.html#noconfig] for
more info.
WARNING: An illegal reflective access operation has occurred
WARNING: Illegal reflective access by
org.apache.flink.core.memory.HybridMemorySegment
([file:/usr/local/Cellar/apache-flink/1.5.0/libexec/lib/flink-dist_2.11-1.5.0.jar|file:///usr/local/Cellar/apache-flink/1.5.0/libexec/lib/flink-dist_2.11-1.5.0.jar])
to field java.nio.Buffer.address
WARNING: Please consider reporting this to the maintainers of
org.apache.flink.core.memory.HybridMemorySegment
WARNING: Use --illegal-access=warn to enable warnings of further illegal
reflective access operations
WARNING: All illegal access operations will be denied in a future release
The log4j warnings just mean that log4j hasn't been initialized; no big deal.
The "Illegal reflective access" warnings look like the warnings you see when
running Java 8-only software under Java 9 or Java 10.
This happens even when I set `JAVA_HOME` to point at my JDK 8 installation.
I suspect this is because the `start-scala-shell.sh` script calls plain `java`
instead of using the `$JAVA_RUN` variable set in flink's `config.sh`, which it
called earlier, and which seems to respect `$JAVA_HOME`. From
`start-scala-shell.sh`:
if ${EXTERNAL_LIB_FOUND}
then
java -Dscala.color -cp "$FLINK_CLASSPATH" $log_setting
org.apache.flink.api.scala.FlinkShell $@ --addclasspath "$EXT_CLASSPATH"
else
java -Dscala.color -cp "$FLINK_CLASSPATH" $log_setting
org.apache.flink.api.scala.FlinkShell $@
fi
Should `start-scala-shell.sh` be changed to use `$JAVA_HOME` like the other
scripts in `libexec`?
--
This message was sent by Atlassian JIRA
(v7.6.3#76005)