2024 Clojure状态调查!中分享您的想法。

欢迎!请查看关于页面以了解更多关于它们是如何工作的信息。

0
ClojureScript
重新分类

我是一个Clojure新手,正在尝试学习clj工具。我正在遵循这个https://betweentwoparens.com/start-a-clojurescript-app-from-scratch教程,在执行命令clj -A:dev时出现了以下错误

Downloading: com/google/protobuf/protobuf-java/3.0.2/protobuf-java-3.0.2.jar from central
Downloading: com/google/code/findbugs/jsr305/3.0.2/jsr305-3.0.2.jar from central
Downloading: com/google/code/gson/gson/2.7/gson-2.7.jar from central
Exception in thread "Thread-4" java.net.SocketException: Broken pipe (Write failed)
    at java.base/java.net.SocketOutputStream.socketWrite0(Native Method)
    at java.base/java.net.SocketOutputStream.socketWrite(SocketOutputStream.java:110)
    at java.base/java.net.SocketOutputStream.write(SocketOutputStream.java:150)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.base/java.lang.reflect.Method.invoke(Method.java:566)
    at clojure.lang.Reflector.invokeMatchingMethod(Reflector.java:167)
    at clojure.lang.Reflector.invokeInstanceMethod(Reflector.java:102)
    at cljs.repl.server$send_and_close.invokeStatic(server.clj:168)
    at cljs.repl.server$send_and_close.invoke(server.clj:144)
    at cljs.repl.browser$send_static.invokeStatic(browser.clj:205)
    at cljs.repl.browser$send_static.invoke(browser.clj:178)
    at cljs.repl.server$dispatch_request.invokeStatic(server.clj:191)
    at cljs.repl.server$dispatch_request.invoke(server.clj:182)
    at cljs.repl.server$handle_connection.invokeStatic(server.clj:199)
    at cljs.repl.server$handle_connection.invoke(server.clj:195)
    at cljs.repl.server$server_loop$fn__68.invoke(server.clj:209)
    at clojure.core$binding_conveyor_fn$fn__5754.invoke(core.clj:2030)
    at clojure.lang.AFn.run(AFn.java:22)
    at java.base/java.lang.Thread.run(Thread.java:834)

为什么我会得到这个错误?我的环境

在Mac OSX Mojave上虚拟的Ubuntu 18.04无头。

[I] /home/user/tallex~> java -version
openjdk version "11.0.6" 2020-01-14 LTS
OpenJDK Runtime Environment Corretto-11.0.6.10.1 (build 11.0.6+10-LTS)
OpenJDK 64-Bit Server VM Corretto-11.0.6.10.1 (build 11.0.6+10-LTS, mixed mode)

我也试过用

[I] /home/sporty/software~> java -version
openjdk version "11.0.6" 2020-01-14
OpenJDK Runtime Environment (build 11.0.6+10-post-Ubuntu-1ubuntu118.04.1)
OpenJDK 64-Bit Server VM (build 11.0.6+10-post-Ubuntu-1ubuntu118.04.1, mixed mode, sharing)

结果是相同的。

编辑:这个问题是因为CLJ无法打开浏览器,因为我正在运行无头Ubuntu。所以我添加了主机端口转发,这似乎可以启动X窗口浏览器。

1 个回答

0

这是因为它在无头虚拟机上运行。当我为VirtualBox添加端口转发时,它似乎可以启动浏览器,但REPL没有启动。

你在浏览器中看到的是什么页面?
在我打开的浏览器中,也确实看到了教程中显示的页面,其中包含粉色到红色的渐变 *时间潜水*。
我在 Linux 上的非常基础的 `clj -M -m cljs.main -r` 上遇到了相同的问题。

ClojureScript 官方快速入门指南有解决方案
https://script.clojure.org/guides/quick-start

> 如果你在运行 Linux 并且 REPL 没有启动,请尝试禁用浏览器自动启动并手动打开 https://127.0.0.1:9000。

这意味着在命令中传递 `--repl-opts "{:launch-browser false}"` 选项
更多关于浏览器 REPL 选项的信息](https://script.clojure.org/reference/repl-options#_browser_repl_options)

因此,在你的情况下,你应该编辑 `deps.edn` 中的 `:dev` 别名,使其看起来像

(未测试)

```
:aliases
 {:dev {:main-opts ["-m"  "cljs.main"
                    "-ro" "{:static-dir [\".\",\"out\",\"resources\"], :launch-browser false}"
                    "-w"  "src"
                    "-c"  "tallex.time-dive"
                    "-r"]}}}
```
...