在Clojure服务器中嵌入NREPL的最佳实践方法

时间:2013-04-19 12:42:33

标签: clojure nrepl

我刚开始在Clojure中开发服务。我对如何接近服务器关闭感到有点迷失。

我正在使用Clojure 1.5.1。对于日志记录,我使用的是Timbre 1.5.3。我想将NREPL嵌入到我的服务器中以进行热代码部署。

这是我的core.clj文件。核心是我的主要,我正在使用“lein new app”生成的app shell。

(ns extenium.core
  (:require [taoensso.timbre :as t]
            [clojure.tools.nrepl.server :as nrs])
  (:gen-class))

(def nrepl-server)

(defn start-nrepl-server []
  (t/info "Starting nrepl server on port 8628")
  (alter-var-root #'nrepl-server
                  (constantly
                   (nrs/start-server :port 8628)))
  (t/info "Started nrepl server"))

(defn stop-nrepl-server []
  (t/info "Stopping nrepl server")
  (nrs/stop-server nrepl-server)
  (t/info "Stopped nrepl server"))

(defn start []
  (alter-var-root #'*read-eval*
                  (constantly
                   false))
  (start-nrepl-server))

(defn stop []
  (stop-nrepl-server))

(defn -main [& args]
  (start))

当我“lein run”时,nrepl-server按预期启动,并将信息消息发送到终端。然后我与Emacs的“nrepl”联系。没问题。从Emacs我执行“(extenium.core / stop)”。此时,我在Emacs上收到“Stopping nrepl server”消息(意味着stdout被重定向到客户端)。连接关闭(如预期的那样),我从未看到“已停止的nrepl服务器”消息。细

我看着终端,我没有看到“正在停止......”或“已停止......”的消息。相反,我得到以下异常:

Exception in thread "nREPL-worker-0" java.lang.Error: java.net.SocketException: Socket closed

理想情况下,我想要以下内容:

  1. 能够从NREPL客户端启动关闭。优雅地关闭所有NREPL客户端连接,无一例外。关闭指向终端的日志消息(或最终转发日志文件)。
  2. 在NREPL连接期间,将日志记录输出克隆到服务器(终端或日志)和NREPL输出。
  3. 捕获有关传入NREPL连接的信息,命名它们,并记录连接和断开活动。
  4. 最终验证传入的NREPL连接。
  5. 即使以后,也要授权他们采取行动。

1 个答案:

答案 0 :(得分:2)

免责声明:我没有这样做,但似乎很有趣。

根据README,特别是“为什么是nREPL?”部分你应该能够通过实现自己的自定义传输来实现2 - 4,也许只是扩展其中一个开箱即用的传输。

正常停止服务器可能需要扩展套接字传输。您所描述的“优雅关闭”听起来像是“注销”协议的实现。

授权他们执行的操作似乎不那么简单。看起来您需要实现自定义处理程序,可能再次使用授权代码包装default-handler

祝你好运!