文件服务器打包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.jar

pause

    先设置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 nerv
 eSpider_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_l
 ib/aopalliance.jar nerveSpider_lib/spring-aop-3.2.2-javadoc.jar nerve
 Spider_lib/slf4j-api-1.6.1.jar nerveSpider_lib/spring-aop-3.2.2-sourc
 es.jar nerveSpider_lib/hibernate-jpa-2.0-api-1.0.1.Final.jar nerveSpi
 der_lib/spring-context-support-3.2.2.jar nerveSpider_lib/hibernate3.j
 ar 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 nerv
 eSpider_lib/slf4j-nop-1.6.1.jar nerveSpider_lib/spring-orm-3.2.2-java
 doc.jar nerveSpider_lib/commons-logging-1.1.1.jar nerveSpider_lib/spr
 ing-aspects-3.2.2.jar nerveSpider_lib/spring-aspects-3.2.2-javadoc.ja
 r nerveSpider_lib/spring-jdbc-3.2.2-javadoc.jar nerveSpider_lib/sprin
 g-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 ne
 rveSpider_lib/spring-orm-3.2.2-sources.jar nerveSpider_lib/spring-exp
 ression-3.2.2.jar nerveSpider_lib/spring-tx-3.2.2-sources.jar nerveSp
 ider_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/sp
 ring-tx-3.2.2.jar nerveSpider_lib/spring-beans-3.2.2-javadoc.jar nerv
 eSpider_lib/mysql-connector-java-5.1.13-bin.jar nerveSpider_lib/sprin
 g-build-src-3.2.2.jar nerveSpider_lib/spring-aop-3.2.2.jar nerveSpide
 r_lib/spring-aspects-3.2.2-sources.jar nerveSpider_lib/jta-1.1.jar ne
 rveSpider_lib/json_simple-1.1.jar nerveSpider_lib/spring-core-3.2.2-j
 avadoc.jar nerveSpider_lib/dom4j-1.6.1.jar nerveSpider_lib/spring-bea
 ns-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.MySQLInnoDBDialect
		hibernate.show_sql=true
		hibernate.format_sql=false
		hibernate.hbm2ddl.auto=update
		hibernate.jdbc.batch_size=20
		<!--hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider-->
		<!-- cache.use_second_level_cache=true
		hibernate.search.default.directory_provider=org.hibernate.search.store.FSDirectoryProvider
	 	hibernate.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

    

    

文章结束给大家分享下程序员的一些笑话语录: 人在天涯钻,哪儿能不挨砖?日啖板砖三百颗,不辞长做天涯人~

posted @ 2013-05-21 21:49  xinyuyuanm  阅读(252)  评论(0编辑  收藏  举报