2015-06-21 190 views
0

我已经在Linux Mint机器上安装了gerrit,并且正在尝试使用mysql数据库连接进行HTTP身份验证。 但是当我尝试启动格里特,我得到以下错误:Gerrit JDBC驱动程序找不到

ERROR com.google.gerrit.pgm.Daemon : Unable to start daemon 
com.google.gerrit.common.Die: Cannot connect to SQL database 
at com.google.gerrit.pgm.util.AbstractProgram.die(AbstractProgram.java:88) 
at com.google.gerrit.pgm.util.SiteProgram.createDbInjector(SiteProgram.java:158) 
at com.google.gerrit.pgm.Daemon.start(Daemon.java:275) 
at com.google.gerrit.pgm.Daemon.run(Daemon.java:204) 
at com.google.gerrit.pgm.util.AbstractProgram.main(AbstractProgram.java:64) 
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:497) 
at com.google.gerrit.launcher.GerritLauncher.invokeProgram(GerritLauncher.java:166) 
at com.google.gerrit.launcher.GerritLauncher.mainImpl(GerritLauncher.java:93) 
at com.google.gerrit.launcher.GerritLauncher.main(GerritLauncher.java:50) 
at Main.main(Main.java:25) 
Caused by: java.sql.SQLException: Driver class com.mysql.jdbc.Driver not available 
at com.google.gwtorm.jdbc.SimpleDataSource.loadDriver(SimpleDataSource.java:171) 
at com.google.gwtorm.jdbc.SimpleDataSource.<init>(SimpleDataSource.java:85) 
at com.google.gerrit.server.schema.DataSourceProvider.open(DataSourceProvider.java:144) 
at com.google.gerrit.server.schema.DataSourceProvider.get(DataSourceProvider.java:65) 
at com.google.gerrit.pgm.util.SiteLibraryBasedDataSourceProvider.get(SiteLibraryBasedDataSourceProvider.java:52) 
at com.google.gerrit.pgm.util.SiteLibraryBasedDataSourceProvider.get(SiteLibraryBasedDataSourceProvider.java:32) 
at com.google.inject.internal.ProviderInternalFactory.provision(ProviderInternalFactory.java:86) 
at com.google.inject.internal.BoundProviderFactory.provision(BoundProviderFactory.java:73) 
at com.google.inject.internal.ProviderInternalFactory.circularGet(ProviderInternalFactory.java:66) 
at com.google.inject.internal.BoundProviderFactory.get(BoundProviderFactory.java:63) 
at com.google.inject.internal.ProviderToInternalFactoryAdapter$1.call(ProviderToInternalFactoryAdapter.java:46) 
at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1066) 
at com.google.inject.internal.ProviderToInternalFactoryAdapter.get(ProviderToInternalFactoryAdapter.java:40) 
at com.google.inject.Scopes$1$1.get(Scopes.java:65) 
at com.google.inject.internal.InternalFactoryToProviderAdapter.get(InternalFactoryToProviderAdapter.java:41) 
at com.google.inject.internal.InternalInjectorCreator$1.call(InternalInjectorCreator.java:205) 
at com.google.inject.internal.InternalInjectorCreator$1.call(InternalInjectorCreator.java:199) 
at com.google.inject.internal.InjectorImpl.callInContext(InjectorImpl.java:1059) 
at com.google.inject.internal.InternalInjectorCreator.loadEagerSingletons(InternalInjectorCreator.java:199) 
at com.google.inject.internal.InternalInjectorCreator.injectDynamically(InternalInjectorCreator.java:180) 
at com.google.inject.internal.InternalInjectorCreator.build(InternalInjectorCreator.java:110) 
at com.google.inject.Guice.createInjector(Guice.java:96) 
at com.google.gerrit.pgm.util.SiteProgram.createDbInjector(SiteProgram.java:152) 
... 11 more 
Caused by: java.lang.ClassNotFoundException: com.mysql.jdbc.Driver 
at java.net.URLClassLoader.findClass(URLClassLoader.java:381) 
at java.lang.ClassLoader.loadClass(ClassLoader.java:424) 
at java.lang.ClassLoader.loadClass(ClassLoader.java:357) 
at java.lang.Class.forName0(Native Method) 
at java.lang.Class.forName(Class.java:348) 
at com.google.gwtorm.jdbc.SimpleDataSource.loadDriver(SimpleDataSource.java:168) 
... 33 more 

我复制mysql-connector-java-5.1.28.jar/usr/share/java但尽管如此,仍然出现错误。

有人能指点我吗?

+0

属于Gerrit'lib /'文件夹的Iirc,不是吗? – StephenKing

+0

'lib /'文件夹是什么意思?一般库或其他类型的lib文件夹? – Arkde

+1

Gerrit的其中一个 – StephenKing

回答

1

最好离开/usr/share/java不变。当你下次升级时,你放在那里的任何东西都会丢失。相反,为你的司机定义你自己的公共位置。如果它只是为你,你的家的位置的子目录可能是好的:mkdir ~/jdbc

然后将您的.jar文件复制到该位置的jdbc驱动程序。

然后根据你如何运行你的java代码,你将不得不弄清楚如何将jar包括到你的类路径中。

  1. 独立Java程序开始使用命令行java,然后使用-cp参数选项。
  2. 像Tomcat或Weblogic这样的应用服务器可以参考他们的文档。请注意,许多人建议应用程序服务器安装内的放置位置,但出于与/usr/share/java相同的原因,我建议不要这样做。实际上tomcat允许你从CATALINA_BASE中分离出CATALINA_HOME来解决这个问题。

无论哪种方式,它似乎是从简单main,而不是一个Web应用程序生成的异常,所以我认为你可以去第一个选项。

+0

保持'/ usr/share/java'不变的好处。但是,在哪里/或者我应该如何安装mysql库,以便'gerrit'能够连接到mysql数据库? – Arkde

相关问题