2

私が欲しいのは、Jetty が起動すると、webapps で使用できるデータベースが作成されることです。私の目標は、すべてのコンピューターに Web アプリケーションをデプロイして、アプリケーションを表示できるようにすることです。

Jetty 構成で HSQLDB データベースを宣言する方法が必要です (すべてのデータベースに構造をセットアップし、データを入力するための SQL ファイルがあります)。これらのパラメーターは一度設定するだけで、将来変更されることはありません。

私はどこでもそれを探してすべてを試したように感じますが、何も動作したくありません:(ちなみに私はJetty 9を使用しています.

これは私が試したオプションの1つであり、私の解決策に近いようです。このコードを jetty/etc/jetty.xml に追加しました

<New id="toto" class="org.eclipse.jetty.plus.jndi.Resource">
  <Arg></Arg>
  <Arg>jdbc/toto</Arg>
  <Arg>
    <New class="org.apache.commons.dbcp.BasicDataSource">
      <Set name="DriverClassName">org.hsqldb.jdbc.jdbcDataSource</Set>
      <Set name="Url">jdbc:hsqldb:hsql://localhost:9015/toto</Set>
      <Set name="Username">toto</Set>
      <Set name="Password">toto</Set>
    </New>
  </Arg>
</New>

これは jett/etc/webdefault.xml に

<resource-ref>
  <res-ref-name>jdbc/toto</res-ref-name>
  <res-type>javax.sql.DataSource</res-type>
  <res-auth>Container</res-auth>
</resource-ref>

私を助けてくれる人へのメリークリスマス:)

編集 26/12/2013 : 私が試した別のオプションは、Eclipse で春を介してデータベースを構成することです。各 webapp はプロジェクト (Maven アーキテクチャ) に対応し、独自のデータベースを使用します。したがって、あるプロジェクトでは、これを行いました:

*conf/common/resources/applicationContext.xml (プロジェクト)

<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName" value="org.hsqldb.jdbcDriver"/>
  <property name="url" value="jdbc:hsqldb:mem:toto"/>
  <property name="username" value="toto"/>
  <property name="password" value="toto"/>
</bean>

*conf/dev/WEB-INF/web.xml (プロジェクト)

<resource-ref>
  <res-ref-name>jdbc/toto</res-ref-name>
  <res-type>javax.sql.DataSource</res-type>
  <res-auth>Container</res-auth>
</resource-ref>

*conf/dev/WEB-INF/jetty-web.xml (プロジェクト)

<Configure id='wac' class="org.eclipse.jetty.webapp.WebAppContext">
  <New id="square" class="org.eclipse.jetty.plus.jndi.Resource">
    <Arg><Ref id="wac" /></Arg>
    <Arg>jdbc/square</Arg>
    <Arg>
     <New class="org.hsqldb.jdbc.jdbcDataSource">
       <Set name="Database">file:square</Set>
       <Set name="User">${database.connection.username}</Set>
       <Set name="Password">${database.connection.password}</Set>
      </New>
    </Arg>
  </New>
</Configure>

*jetty/start.ini (Jetty) : これらの行のコメントを外します

OPTIONS=jndi
OPTIONS=plus
etc/jetty-plus.xml

以上のことから、次の例外が発生します。

java.lang.ExceptionInInitializerError
at org.apache.jasper.servlet.JspServlet.init(JspServlet.java:159)
at org.eclipse.jetty.servlet.ServletHolder.initServlet(ServletHolder.java:540)
at org.eclipse.jetty.servlet.ServletHolder.initialize(ServletHolder.java:349)
at org.eclipse.jetty.servlet.ServletHandler.initialize(ServletHandler.java:812)
at org.eclipse.jetty.servlet.ServletContextHandler.startContext(ServletContextHandler.java:288)
at org.eclipse.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1322)
at org.eclipse.jetty.server.handler.ContextHandler.doStart(ContextHandler.java:732)
at org.eclipse.jetty.webapp.WebAppContext.doStart(WebAppContext.java:490)
at org.eclipse.jetty.util.component.AbstractLifeCycle.start(AbstractLifeCycle.java:69)
at org.eclipse.jetty.util.component.ContainerLifeCycle.start(ContainerLifeCycle.java:118)
at org.eclipse.jetty.util.component.ContainerLifeCycle.addBean(ContainerLifeCycle.java:282)
at org.eclipse.jetty.util.component.ContainerLifeCycle.addBean(ContainerLifeCycle.java:214)
at org.eclipse.jetty.util.component.ContainerLifeCycle.updateBeans(ContainerLifeCycle.java:764)
at org.eclipse.jetty.server.handler.HandlerCollection.setHandlers(HandlerCollection.java:89)
at org.eclipse.jetty.server.handler.ContextHandlerCollection.setHandlers(ContextHandlerCollection.java:145)
at org.eclipse.jetty.server.handler.HandlerCollection.addHandler(HandlerCollection.java:155)
at org.eclipse.jetty.deploy.bindings.StandardDeployer.processBinding(StandardDeployer.java:41)
at org.eclipse.jetty.deploy.AppLifeCycle.runBindings(AppLifeCycle.java:186)
at org.eclipse.jetty.deploy.DeploymentManager.requestAppGoal(DeploymentManager.java:495)
at org.eclipse.jetty.deploy.DeploymentManager.addApp(DeploymentManager.java:146)
at org.eclipse.jetty.deploy.providers.ScanningAppProvider.fileAdded(ScanningAppProvider.java:175)
at org.eclipse.jetty.deploy.providers.ScanningAppProvider$1.fileAdded(ScanningAppProvider.java:64)
at org.eclipse.jetty.util.Scanner.reportAddition(Scanner.java:605)
at org.eclipse.jetty.util.Scanner.reportDifferences(Scanner.java:528)
at org.eclipse.jetty.util.Scanner.scan(Scanner.java:391)
at org.eclipse.jetty.util.Scanner$1.run(Scanner.java:329)
at java.util.TimerThread.mainLoop(Timer.java:555)
at java.util.TimerThread.run(Timer.java:505)

編集 07/01/2014

私はその道をあきらめましたが、ここでやりたいことを成功させました:データベースを HSQLDB サーバーに接続する

4

1 に答える 1

1

HSQLDB を組み込みデータベースとして使用しているようですが、サーバー モードで接続しようとしています。組み込みモードで HSQLDB を実行する場合の正しい JDBC 接続文字列については、次のドキュメントを参照してください: http://hsqldb.org/doc/guide/running-chapt.html#rgc_inprocess

于 2013-12-23T21:40:45.893 に答える