由于slf4j依赖性,Roo shell无法安装jdbc包

时间:2015-05-06 08:41:14

标签: java spring jdbc roo

我很难尝试使用Roo 1.3.1当前版本设置DRBE项目。 我在最新的eclipse发布版本的STS最新版本中设置了项目,所有新的安装都是为了避免冲突。然后我通过Roo shell设置JPA,用户,数据库和密码,然后我尝试获取数据库模式。 Roo抱怨没有合适的jdbc驱动程序并建议下载它。我这样做但不幸的是Roo无法安装它,因为与slf4j-nop和slf4j-api存在一些未满足的依赖关系。

我还试图单独安装依赖项,但它们彼此之间都存在循环依赖关系,导致无法安装jdbc驱动程序(至少目前)

roo> jpa setup --provider HIBERNATE --database MYSQL
roo> database properties set --key database.url --value jdbc:mysql://localhost:3306/dbdb
roo> database properties set --key database.password --value $$$$
roo> database properties set --key database.username --value uuuu
roo> database reverse engineer --package ~.model --schema PUBLIC --includeNonPortableAttributes
Located add-on that may offer this JDBC driver
1 found, sorted by rank; T = trusted developer; R = Roo 1.3 compatible
ID T R DESCRIPTION -------------------------------------------------------------
01 Y Y 5.1.18.0001 #jdbcdriver driverclass:com.mysql.jdbc.Driver. This...
--------------------------------------------------------------------------------
[HINT] use 'addon info id --searchResultId ..' to see details about a search result
[HINT] use 'addon install id --searchResultId ..' to install a specific search result, or
[HINT] use 'addon install bundle --bundleSymbolicName TAB' to install a specific add-on version
JDBC driver not available for 'com.mysql.jdbc.Driver'
roo> addon install id --searchResultId 01
roo> Target resource(s):
-------------------
   Spring Roo - Wrapping - mysql-connector-java (5.1.18.0001)

Required resource(s):
---------------------
slf4j-nop (1.6.1)
slf4j-api (1.6.1)

Deploying...
done.

但它确实没有部署任何东西或解决了依赖关系。我在一个循环中,每当我尝试对数据库进行反向工程时它就会要求我安装jdbc软件包。它要求我安装捆绑包。我做。它已经部署了捆绑包,但事实并非如此。我重试......等等。

如果我发布一个旧的1.2.5.RELEASE Roo shell,我碰巧安装了所有的工作,甚至没有要求我在Roo上安装任何软件包(我想我已经在过去的某个时候做了)

我也试过用osgi安装

roo> osgi obr url add --url http://spring-roo-repository.springsource.org/repository.xml
roo> osgi obr start --bundleSymbolicName org.springframework.roo.wrapping.mysql-connector-java

但它引发了一个抱怨MalformedURLException的异常,因为捆绑名称上没有协议...

org.osgi.framework.BundleException: Unable to cache bundle: org.springframework.roo.wrapping.mysql-connector-java
    at org.apache.felix.framework.Felix.installBundle(Felix.java:2870)
    at org.apache.felix.framework.BundleContextImpl.installBundle(BundleContextImpl.java:165)
    at org.apache.felix.framework.BundleContextImpl.installBundle(BundleContextImpl.java:138)
    at org.apache.felix.gogo.command.Basic.start(Basic.java:724)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at org.apache.felix.gogo.runtime.Reflective.invoke(Reflective.java:137)
    at org.apache.felix.gogo.runtime.CommandProxy.execute(CommandProxy.java:82)
    at org.apache.felix.gogo.runtime.Closure.executeCmd(Closure.java:477)
    at org.apache.felix.gogo.runtime.Closure.executeStatement(Closure.java:403)
    at org.apache.felix.gogo.runtime.Pipe.run(Pipe.java:108)
    at org.apache.felix.gogo.runtime.Closure.execute(Closure.java:183)
    at org.apache.felix.gogo.runtime.Closure.execute(Closure.java:120)
    at org.apache.felix.gogo.runtime.CommandSessionImpl.execute(CommandSessionImpl.java:92)
    at org.springframework.roo.felix.FelixDelegator.perform(FelixDelegator.java:234)
    at org.springframework.roo.felix.FelixDelegator.obrStart(FelixDelegator.java:167)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at org.springframework.roo.process.manager.ProcessManagerHostedExecutionStrategy$1.callback(ProcessManagerHostedExecutionStrategy.java:47)
    at org.springframework.roo.process.manager.internal.DefaultProcessManager.doTransactionally(DefaultProcessManager.java:325)
    at org.springframework.roo.process.manager.internal.DefaultProcessManager.execute(DefaultProcessManager.java:71)
    at org.springframework.roo.process.manager.ProcessManagerHostedExecutionStrategy.execute(ProcessManagerHostedExecutionStrategy.java:44)
    at org.springframework.roo.shell.AbstractShell.executeCommandImpl(AbstractShell.java:242)
    at org.springframework.roo.shell.AbstractShell.executeCommand(AbstractShell.java:149)
    at org.springframework.roo.shell.eclipse.EclipseShell.executeCommand(EclipseShell.java:104)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:483)
    at org.springframework.util.ReflectionUtils.invokeMethod(ReflectionUtils.java:202)
    at org.springframework.ide.eclipse.core.java.ClassUtils.invokeMethod(ClassUtils.java:137)
    at org.springframework.ide.eclipse.core.java.ClassUtils.invokeMethod(ClassUtils.java:97)
    at org.springframework.roo.shell.eclipse.Bootstrap.execute(Bootstrap.java:90)
    at org.springframework.ide.eclipse.roo.ui.internal.RooShellTab$CommandJob.run(RooShellTab.java:588)
    at org.eclipse.core.internal.jobs.Worker.run(Worker.java:54)
Caused by: java.net.MalformedURLException: no protocol: org.springframework.roo.wrapping.mysql-connector-java
    at java.net.URL.<init>(URL.java:586)
    at org.apache.felix.framework.util.SecureAction.createURL(SecureAction.java:254)
    at org.apache.felix.framework.cache.JarRevision.initialize(JarRevision.java:148)
    at org.apache.felix.framework.cache.JarRevision.<init>(JarRevision.java:77)
    at org.apache.felix.framework.cache.BundleArchive.createRevisionFromLocation(BundleArchive.java:878)
    at org.apache.felix.framework.cache.BundleArchive.reviseInternal(BundleArchive.java:550)
    at org.apache.felix.framework.cache.BundleArchive.<init>(BundleArchive.java:153)
    at org.apache.felix.framework.cache.BundleCache.create(BundleCache.java:277)
    at org.apache.felix.framework.Felix.installBundle(Felix.java:2866)
    ... 38 more
java.net.MalformedURLException: no protocol: org.springframework.roo.wrapping.mysql-connector-java

我还试图清理.m2文件夹以防万一本地回购邮件的版本已损坏......但没有运气。它现在已经发布了1.7.5的这些slf4j库,Roo shell抱怨并要求发布1.6.1

我在过去的项目中使用过Springsource和Roo来加速我的开发,但这并没有加速我的速度......

提前感谢愿意阅读此内容的任何人:)

注意:我能让它工作的唯一方法是从MySQL's website手动下载jdbc驱动程序,解压缩并通过osgi将其推送到Roo shell。

roo> osgi start --url file:///Users/..../Downloads/mysql-connector-java-5.1.35/mysql-connector-java-5.1.35-bin.jar

真的我现在可以工作但是,Spring和Spring Roo不是一个框架和工具,可以让我们的开发周期更快吗?我弄错了吗? jdbc连接是如此不常见?

我仍然想知道是否有更好/更简单/自动的方法。

0 个答案:

没有答案