打包jar文件后的spring部署及hibernate自动建表经验总结
楔子
用spring+hibernate做一個服務器運行程序,在部署到服務器時(打包成jar,在window server2008下運行),出現了以下兩個糾結問題:
1. 加載不了Spring容器
2.?hibernate.hbm2ddl.auto 到了服務器不能自動建表
困擾了兩個小時,終于一一擊破,這里就自己的處理經驗作一個簡單的說明。
說明
整個項目中bean的定義,絕大部分都是用注解形式,在本地運行正常。
加載不了Spring容器
之前想過用exe4j等工具導出為exe文件,但是,不好使。最終敲定用批處理的方式去運行整個程序(因為是window服務器)。
剛剛開始是這樣導出為jar文件:
這樣導出的jar很奇怪,總是提示找不到第三方class,想想應該是Class-path沒有配置正確。但是MANIFEST.MF文件里寫classpath又比較麻煩,就想著eclipse能不能幫我生成這個MANIFEST.MF文件。試了一下以下這種方式,果然可以:
選擇“copy required libraries into a sub-folder next to the generated JAR”(將需要的lib文件復制到目標JAR包所在目錄的子文件夾中)
然后就可以看到生成了 nerSpider.jar 以及一個 nerveSpider_lib 的文件夾(里面就是我們需要用到的jar包),然后寫一個bat去運行我們的jar吧:
?
path=%path%;%cd%\jre6\bin@java -jar nerveSpider_1.2.0.jarpause
先設置jre的路徑,然后執行 java -jar
?
我們再看看?MANIFEST.MF 文件:
?
Manifest-Version: 1.0 Class-Path: . nerveSpider_lib/antlr-2.7.6.jar nerveSpider_lib/jsoup-1.7.2.jar nerveSpider_lib/spring-context-support-3.2.2-javadoc.jar nerveSpider_lib/spring-beans-3.2.2.jar nerveSpider_lib/spring-jdbc-3.2.2.jar nerveSpider_lib/spring-expression-3.2.2-sources.jar nerveSpider_lib/aopalliance.jar nerveSpider_lib/spring-aop-3.2.2-javadoc.jar nerveSpider_lib/slf4j-api-1.6.1.jar nerveSpider_lib/spring-aop-3.2.2-sources.jar nerveSpider_lib/hibernate-jpa-2.0-api-1.0.1.Final.jar nerveSpider_lib/spring-context-support-3.2.2.jar nerveSpider_lib/hibernate3.jar nerveSpider_lib/httpcore-4.2.2.jar nerveSpider_lib/commons-pool-1.5.4.jar nerveSpider_lib/spring-context-support-3.2.2-sources.jar nerveSpider_lib/slf4j-nop-1.6.1.jar nerveSpider_lib/spring-orm-3.2.2-javadoc.jar nerveSpider_lib/commons-logging-1.1.1.jar nerveSpider_lib/spring-aspects-3.2.2.jar nerveSpider_lib/spring-aspects-3.2.2-javadoc.jar nerveSpider_lib/spring-jdbc-3.2.2-javadoc.jar nerveSpider_lib/spring-jdbc-3.2.2-sources.jar nerveSpider_lib/spring-tx-3.2.2-javadoc.jar nerveSpider_lib/spring-core-3.2.2-sources.jar nerveSpider_lib/spring-core-3.2.2.jar nerveSpider_lib/spring-expression-3.2.2-javadoc.jar nerveSpider_lib/spring-orm-3.2.2-sources.jar nerveSpider_lib/spring-expression-3.2.2.jar nerveSpider_lib/spring-tx-3.2.2-sources.jar nerveSpider_lib/spring-context-3.2.2.jar nerveSpider_lib/commons-collections-3.1.jar nerveSpider_lib/httpclient-4.2.3.jar nerveSpider_lib/spring-orm-3.2.2.jar nerveSpider_lib/commons-dbcp-1.4.jar nerveSpider_lib/spring-tx-3.2.2.jar nerveSpider_lib/spring-beans-3.2.2-javadoc.jar nerveSpider_lib/mysql-connector-java-5.1.13-bin.jar nerveSpider_lib/spring-build-src-3.2.2.jar nerveSpider_lib/spring-aop-3.2.2.jar nerveSpider_lib/spring-aspects-3.2.2-sources.jar nerveSpider_lib/jta-1.1.jar nerveSpider_lib/json_simple-1.1.jar nerveSpider_lib/spring-core-3.2.2-javadoc.jar nerveSpider_lib/dom4j-1.6.1.jar nerveSpider_lib/spring-beans-3.2.2-sources.jar nerveSpider_lib/javassist-3.12.0.GA.jar Main-Class: com.nerve.sprider.ui.Start
是吧,如果自己寫,很蛋疼吧=.=
?
關于 hibernate.hbm2ddl.auto 自動建表
對于?hibernate.hbm2ddl.auto 的值設置,大家應該都了解,常用的就是 update。但是,我部署到服務器后,數據表沒有創建,如果將hibernate.hbm2ddl.auto設置為 create,那么數據表會被刪除,但是沒有被新建。由此可見,配置是成功的了,只是在建表時,出錯了。
先看一下在spring的配置文件中對于 sessionFactory 的定義:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"><property name="dataSource" ref="dataSource"/><property name="hibernateProperties"><value>hibernate.dialect=org.hibernate.dialect.MySQLInnoDBDialecthibernate.show_sql=truehibernate.format_sql=falsehibernate.hbm2ddl.auto=updatehibernate.jdbc.batch_size=20<!--hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider--><!-- cache.use_second_level_cache=truehibernate.search.default.directory_provider=org.hibernate.search.store.FSDirectoryProviderhibernate.search.default.indexBase=E:/lucene/index--></value></property><!-- - <property name="cacheProvider"><ref local="cacheProvider"/></property>--><property name="packagesToScan" value="com.nerve.sprider.domain.db"/> </bean>
google了一陣,發現有同樣問題的人不少,只是大家的解決方法不盡相同,并沒有得到答案。一時茫然。在看配置文件時,突然看到了?
?
hibernate.dialect=org.hibernate.dialect.MySQLInnoDBDialect這一行,啊。會不會是他!接著將 以上語句改成:
?
?
hibernate.dialect=org.hibernate.dialect.MySQLDialect再次運行,數據表已經正常了。
?
一下子醒悟過來,因為本地的數據庫一直是設置了 InnoDB引擎,但是服務器中并沒有設置,所以造成了數據表無法成功創建。
對于mysql儲存引擎的說明,這里有一個詳細的文章:http://javabkb.iteye.com/blog/1441197
轉載于:https://www.cnblogs.com/nerve/archive/2013/05/21/3185423.html
總結
以上是生活随笔為你收集整理的打包jar文件后的spring部署及hibernate自动建表经验总结的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Phonegap在ios7上系统状态栏的
- 下一篇: poj 3026 Borg Maze (