2017-07-25 2 views
1

私はSpringのHibernate H2アプリケーションを設定しています。サーバーがすべて起動しても、更新後(Tomcatを再起動せずにeclipseでプロジェクトを再構築)、データベースファイルにアクセスできないというエラーメッセージが表示されます。プロジェクトの再構築後のHibernate H2データベースロック

エラーメッセージ:

java.lang.IllegalStateException: The file is locked: nio:/home/bob/dataStore.mv.db [1.4.187/7] 

java.nio.channels.OverlappingFileLockException 

org.apache.commons.dbcp.SQLNestedException: Cannot create PoolableConnectionFactory (Database may be already in use: 

私はURLが、運にFile_LOCK=NODB_CLOSE_ON_EXIT=TRUEを追加しようとしたこのエラーをグーグル後。

Context.xmlファイル

<context:annotation-config /> 
    <context:component-scan base-package="com" /> 

    <mvc:annotation-driven /> 

    <mvc:resources mapping="/resources/**" location="/resources/" /> 


    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> 
     <property name="driverClassName" value="org.h2.Driver" /> 
<!--  <property name="url" value="jdbc:h2:tcp://localhost/~/dataStore;FILE_LOCK=NO;DB_CLOSE_ON_EXIT=TRUE" /> --> 
     <property name="url" value="jdbc:h2:file:~/dataStore;FILE_LOCK=NO;DB_CLOSE_ON_EXIT=TRUE;MVCC=TRUE" /> 

     <property name="username" value="" /> 
     <property name="password" value="" /> 
    </bean> 

    <bean id="sessionFactory" 
     class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> 
     <property name="dataSource" ref="dataSource" /> 
     <property name="packagesToScan" value="com.entities" /> 
     <property name="hibernateProperties"> 
      <props> 
       <prop key="hibernate.dialect">org.hibernate.dialect.H2Dialect</prop> 
       <prop key="hibernate.show_sql">true</prop> 
       <prop key="hibernate.enable_lazy_load_no_trans">true</prop> 
       <prop key="format_sql">true</prop> 
       <prop key="use_sql_comments">true</prop> 
       <prop key="hibernate.hbm2ddl.auto">update</prop> 
      </props> 
     </property> 
    </bean> 

    <tx:annotation-driven transaction-manager="transactionManager" /> 

    <bean id="transactionManager" 
     class="org.springframework.orm.hibernate4.HibernateTransactionManager"> 
     <property name="sessionFactory" ref="sessionFactory" /> 
    </bean> 

データベースは、プロジェクトが再構築されるたびにロックされないように、私は何を行うことができます。

また、eclipseはデータベースが更新されるたびにアプリケーションを再構築しています。どうすればこれをやめることができますか?

答えて

1

は春docs

から、DB_CLOSE_ON_EXIT=FALSEをお試しください組込みデータベースの場合、データベースの自動シャットダウンが無効になるように注意する必要があります。 H2を使用している場合は、DB_CLOSE_ON_EXIT = FALSEを使用してください。

+0

これは完全に機能しました。 – develop1

-1

multipul connecationを作成する必要がある場合、あなたは、コードの下に使用する必要があります。何らかの理由で、あなたは接続URLを設定しない、場合

<property name="javax.persistence.jdbc.url" value="jdbc:h2:tcp://localhost/C:\Database\Data\production;"/> 
+0

上記のコードは春には有効ではありません。エラーメッセージ 'Beanクラスのjavax 'が無効です。 – develop1

関連する問題