从我的clojure项目我正在用lein uberjar创建jar,jar在本地工作正常。
然后我通过lein-rpm任务创建 rpm ,然后我将rpm部署到服务器。
部署rpm后,我尝试使用java -jar
运行它,但服务开始提供以下异常。
java.lang.IllegalArgumentException: No implementation of method: :route-matches of protocol: #'clout.core/Route found for class: clout.core.CompiledRoute
at clojure.core$_cache_protocol_fn.invokeStatic(core_deftype.clj:566) ~[na:na]
at clojure.core$_cache_protocol_fn.invoke(core_deftype.clj:560) ~[na:na]
at clout.core$eval5959$fn__5960$G__5950__5967.invoke(core.clj:39) ~[na:na]
at compojure.core$route_matches.invokeStatic(core.clj:46) ~[na:na]
at compojure.core$route_matches.invoke(core.clj:44) ~[na:na]
at compojure.core$route_request.invokeStatic(core.clj:49) ~[na:na]
at compojure.core$route_request.invoke(core.clj:48) ~[na:na]
at compojure.core$wrap_route_matches$fn__6362.invoke(core.clj:145) ~[na:na]
at compojure.core$wrap_routes$fn__6478.invoke(core.clj:348) ~[na:na]
at compojure.api.routes.Route.invoke(routes.clj:74) [na:na]
at compojure.api.core$handle$fn__17370.invoke(core.clj:8) ~[na:na]
at clojure.core$some.invokeStatic(core.clj:2592) [na:na]
at clojure.core$some.invoke(core.clj:2583) [na:na]
at compojure.api.core$handle.invokeStatic(core.clj:8) ~[na:na]
at compojure.api.core$handle.invoke(core.clj:7) ~[na:na]
at clojure.core$partial$fn__533.invoke(core.clj:2515) ~[na:na]
at compojure.api.routes.Route.invoke(routes.clj:74) [na:na]
at ring.swagger.middleware$wrap_swagger_data$fn__14534.invoke(middleware.clj:33) ~[na:na]
at ring.middleware.http_response$wrap_http_response$fn__11869.invoke(http_response.clj:19) ~[na:na]
at ring.swagger.middleware$wrap_swagger_data$fn__14534.invoke(middleware.clj:33) ~[na:na]
at compojure.api.middleware$wrap_options$fn__15814.invoke(middleware.clj:74) [na:na]
at ring.middleware.format_params$wrap_format_params$fn__10747.invoke(format_params.clj:119) ~[na:na]
at ring.middleware.format_params$wrap_format_params$fn__10747.invoke(format_params.clj:119) ~[na:na]
at ring.middleware.format_params$wrap_format_params$fn__10747.invoke(format_params.clj:119) ~[na:na]
at ring.middleware.format_params$wrap_format_params$fn__10747.invoke(format_params.clj:119) ~[na:na]
at ring.middleware.format_params$wrap_format_params$fn__10747.invoke(format_params.clj:119) ~[na:na]
at compojure.api.middleware$wrap_exceptions$fn__15804.invoke(middleware.clj:43) ~[na:na]
at ring.middleware.format_response$wrap_format_response$fn__11767.invoke(format_response.clj:183) [na:na]
at ring.middleware.keyword_params$wrap_keyword_params$fn__11907.invoke(keyword_params.clj:36) [na:na]
at ring.middleware.nested_params$wrap_nested_params$fn__11955.invoke(nested_params.clj:89) [na:na]
at ring.middleware.params$wrap_params$fn__12029.invoke(params.clj:67) [na:na]
at compojure.api.middleware$wrap_options$fn__15814.invoke(middleware.clj:74) [na:na]
at compojure.api.routes.Route.invoke(routes.clj:74) [na:na]
at clojure.lang.Var.invoke(Var.java:379) [supply-planning-api-service-standalone.jar:na]
at compojure.core$routing$fn__6377.invoke(core.clj:185) [na:na]
at clojure.core$some.invokeStatic(core.clj:2592) [na:na]
at clojure.core$some.invoke(core.clj:2583) [na:na]
at compojure.core$routing.invokeStatic(core.clj:185) [na:na]
at compojure.core$routing.doInvoke(core.clj:182) [na:na]
自由与环境详情
lein-rpm - 0.0.5
操作系统 - CentOS Linux 7
我错过了什么?
修改:
根据@Mirinal的评论,我检查了rpm构建之前和之后的jar大小。如果我们从rpm中提取罐子,那么它的尺寸就比原来的要小。
答案 0 :(得分:4)
我有同样的问题。花了两天时间才解决。
因此,如果您看到lein uberjar
生成的jar大小和lein rpm任务,它们将会有所不同。罪魁祸首是brp-java-repack-jars,它在rpm构建期间打包并重新打包jar。要查看您需要在终端上运行rpm -E '%{__os_install_post}'
的选项,您会看到如下内容:
/usr/lib/rpm/redhat/brp-compress
/usr/lib/rpm/redhat/brp-strip /usr/bin/strip
/usr/lib/rpm/redhat/brp-strip-comment-note /usr/bin/strip /usr/bin/objdump
/usr/lib/rpm/redhat/brp-strip-static-archive /usr/bin/strip
/usr/lib/rpm/brp-python-bytecompile /usr/bin/python 1
/usr/lib/rpm/redhat/brp-python-hardlink
/usr/lib/rpm/redhat/brp-java-repack-jars
最后一个是问题,因为它与lein uberjar创造的jar混乱。为了解决这个问题,我们必须在rpm create期间禁用__os_install_post选项。这个blog很好地解释了它。
我们做了什么,删除了rpm步骤并将lein uberjar步骤创建的.jar包直接复制到服务器并运行它。但是我们尝试了这个其他选项,它也可以。
希望这会有所帮助。如果有任何疑问,可以评论。