2010-12-04 7 views
6

Tengo una aplicación web sencilla con este project.clj:Jar producido con uberjar Lein falla en 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") 

Mis principales es similar al siguiente:

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

Con REPL funciona bien. Sin embargo, cuando genero un frasco con lein uberjar y tratar de ejecutarlo como:

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

Se muere con esta excepción:

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 

¿Qué estoy haciendo mal? ¿Cómo hacer que funcione?

No estoy seguro de si eso importa, pero noté que dentro del contenedor mis archivos, clojure y las libs de Java están desempaquetados como archivos .class, mientras que todas las bibliotecas de clojure están presentes solo como archivos .clj.

Respuesta

2

Esto parece ser un error leinigen 1.4.0. Puede intentar crear un uberjar con leiningen 1.3.1.

Editar:

Leiningen 1.4.0 no elimina los archivos de proyecto .class a evitar un error Clojure (ver CLJ-322). Aparentemente, este comportamiento a veces puede causar problemas.

Puede mantener Leiningen 1.4.0 de suprimir no es del proyecto .class archivos mediante el establecimiento de :keep-non-project-classes a true en su project.clj.

Consulte el relacionado leinigen issue para obtener más información.

+0

Eso funciona. ¡Gracias! –

Cuestiones relacionadas