2010-12-04 2 views
6

У меня есть простой веб-приложение, с помощью этого project.clj:Jar производится с LEIN uberjar терпит неудачу на NoClassDefFoundError

(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)) 

С РЕПЛ работает просто отлично. Однако, когда я произвожу баночку с 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 

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

Не уверен, что это важно, но я заметил,

ответ

2

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

Edit:

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

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

См. Связанный leinigen issue для получения дополнительной информации.

+0

Это работает. Спасибо! – 2011-01-08 16:07:02

Смежные вопросы