Jar, созданный с помощью lein uberjar, завершается с ошибкой NoClassDefFoundError - PullRequest
6 голосов
/ 04 декабря 2010

У меня есть простое веб-приложение с этим project.clj:

(defproject squirrel-money "1.0.0-SNAPSHOT"
  :description "Squirrel Money"
  :dependencies [[org.clojure/clojure "1.2.0"]
                 [org.clojure/clojure-contrib "1.2.0"]
                 [compojure "0.5.3"]
                 [ring/ring-jetty-adapter "0.3.5"]
                 [hiccup "0.3.1"]
                 [postgresql "8.4-701.jdbc4"]
                 [clj-time "0.2.0-SNAPSHOT"]]
  :dev-dependencies [[lein-eclipse "1.0.0"]]
  :main squirrel-money.main
  :repl-init-script "src/squirrel_money/init_repl.clj")

Моя главная выглядит так:

(ns squirrel-money.main
  (:gen-class)
  (:use 
    [compojure.core]
    [ring.adapter.jetty])
  (:require 
    [compojure.route :as route]
    [squirrel-money.savings :as savings]))

(defn launch [routedef]
  (run-jetty routedef {:port 17080}))

(defroutes money-routes
  (GET "/savings" [] (savings/render))
  (route/not-found "Page not found"))

(defn -main [& args] (launch money-routes))

С REPL работает просто отлично.Однако, когда я генерирую банку с lein uberjar и пытаюсь выполнить ее как:

java -jar squirrel-money-1.0.0-SNAPSHOT-standalone.jar

Он умирает с этим исключением:

Exception in thread "main" java.lang.NoClassDefFoundError: compojure/response/Renderable
    at squirrel_money.main$fn__1067.invoke(main.clj:18)
    at squirrel_money.main__init.load(Unknown Source)
    at squirrel_money.main__init.<clinit>(Unknown Source)
    at java.lang.Class.forName0(Native Method)
    at java.lang.Class.forName(Class.java:247)
    at clojure.lang.RT.loadClassForName(RT.java:1578)
    at clojure.lang.RT.load(RT.java:399)
    at clojure.lang.RT.load(RT.java:381)
    at clojure.core$load$fn__4511.invoke(core.clj:4905)
    at clojure.core$load.doInvoke(core.clj:4904)
    at clojure.lang.RestFn.invoke(RestFn.java:409)
    at clojure.lang.Var.invoke(Var.java:365)
    at squirrel_money.main.<clinit>(Unknown Source)
Caused by: java.lang.ClassNotFoundException: compojure.response.Renderable
    at java.net.URLClassLoader$1.run(URLClassLoader.java:202)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:190)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:307)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:301)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:248)
    ... 13 more

Что я делаю не так?Как заставить это работать?

Не уверен, что это имеет значение, но я заметил, что внутри jar мои файлы, сам clojure и библиотеки Java распаковываются как файлы .class, тогда как все библиотеки clojure присутствуют только как простые.clj файлы.

1 Ответ

2 голосов
/ 04 декабря 2010

Кажется, это ошибка leinigen 1.4.0.Возможно, вы захотите попробовать создать uberjar с leiningen 1.3.1.

Редактировать :

Leiningen 1.4.0 удаляет не-проектные .class файлы для обходаОшибка закрытия (см. CLJ-322 ).Очевидно, такое поведение может иногда вызывать проблемы.

Вы можете не позволить leiningen 1.4.0 удалить не проектные файлы .class, установив :keep-non-project-classes в true в своем project.clj.

* 1017.* Подробнее см. leinigen .
...