2

我完全是Scala和 JVM 编程的菜鸟。我最近加入的团队使用 scala 构建要在 Spark 上运行的程序。工作中的堆栈稳定且功能强大,但其复杂性与我在家的需求不匹配:仅具有功能性 scala shell以更熟悉该语言,尝试一下,在添加任何语法之前获得正确的语法“环境复杂性

[注意] 我只是想要一些与本文档相同的东西(所以,请不要根据编译器、sbt、IDE 等来回答)

david@ripper$ java -version
openjdk version "1.8.0_181"
OpenJDK Runtime Environment (build 1.8.0_181-8u181-b13-2~deb9u1-b13)
OpenJDK 64-Bit Server VM (build 25.181-b13, mixed mode)
david@ripper$ scala -version 
Scala code runner version 2.11.8 -- Copyright 2002-2016, LAMP/EPFL

这是我在吃贝壳时得到的

david@ripper$ scala 
Exception in thread "main" java.lang.NoClassDefFoundError: javax/script/Compilable
at scala.tools.nsc.interpreter.ILoop.createInterpreter(ILoop.scala:118)
at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply$mcZ$sp(ILoop.scala:911)
at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply(ILoop.scala:909)
at scala.tools.nsc.interpreter.ILoop$$anonfun$process$1.apply(ILoop.scala:909)
at scala.reflect.internal.util.ScalaClassLoader$.savingContextLoader(ScalaClassLoader.scala:97)
at scala.tools.nsc.interpreter.ILoop.process(ILoop.scala:909)
at scala.tools.nsc.MainGenericRunner.runTarget$1(MainGenericRunner.scala:74)
at scala.tools.nsc.MainGenericRunner.run$1(MainGenericRunner.scala:87)
at scala.tools.nsc.MainGenericRunner.process(MainGenericRunner.scala:98)
at scala.tools.nsc.MainGenericRunner$.main(MainGenericRunner.scala:103)
at scala.tools.nsc.MainGenericRunner.main(MainGenericRunner.scala)

这似乎是一个经典问题,尽管我首先与我的系统上安装了Oracle java 11相关。但是,我认为我将 openjdk8 设置为默认的系统范围 JRE:

update-alternatives --config java
Il existe 2 choix pour l'alternative java (qui fournit /usr/bin/java).
Sélection   Chemin Priorité  État
------------------------------------------------------------
  0            /usr/lib/jvm/java-11-oracle/bin/java             1091      mode automatique
  1            /usr/lib/jvm/java-11-oracle/bin/java             1091      mode manuel
* 2            /usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java   1081      mode manuel

我错过了什么。不是 scala 使用/usr/lib/jvm/java-8-openjdk-amd64/jre/bin/java. 我正在使用Debian 9中提供的默认 scala 包

4

1 回答 1

1

事实证明,update-alternatives --config java并没有改变JAVA_HOME用户的 PATH (仍然指向 java11)。似乎 scala-shell 不使用系统的默认 JRE,而是使用 .bashrc(在我的情况下为 .zshrc)指向的那个。

于 2019-03-17T14:26:20.090 回答