打包jar文件后的spring部署及hibernate自动建表经验总结
2013-05-21 16:19
429 查看
楔子
用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储存引擎的说明,这里有一个详细的文章:/article/4480307.html
相关文章推荐
- 打包jar文件后的spring部署及hibernate自动建表经验总结
- 文件服务器打包jar文件后的spring部署及hibernate自动建表经验总结
- ssh整合思想 Spring与Hibernate的整合ssh整合相关JAR包下载 .MySQLDialect添加了第57区的方言解决没有异常,hibernate.dialect核心配置文件就是无法自动update创建表
- 总结Spring、Hibernate、Struts2官网下载jar文件
- 总结Spring、Hibernate、Struts2官网下载jar文件
- 总结Spring、Hibernate、Struts2官网下载jar文件
- Linux(CentOS 7) 部署Spring Boot 打包的jar文件
- 总结Spring、Hibernate、Struts2官网下载jar文件
- 非web java项目部署到linux总结(非打包成jar,配置文件可以随时修改)
- springboot项目配置多环境打包部署遇到的问题总结
- 通过Maven构建打包Spring boot,并将config配置文件提取到jar文件外
- Spring Boot Maven 打包可执行Jar文件!
- spring boot打包成war包部署及修改默认配置文件的名称
- Spring Boot Maven 打包可执行Jar文件
- Spring配置文件打包到jar中无法加载问题之解决方案
- eclipse 部署项目到Tomcat spring-web 的jar包部署失败 在tomcat 中的WEB-INF/classes 目录下有我该项目工作空间的所有文件及目录
- Wix 安装部署(一)同MSBuild 自动生成打包文件
- 【java细节】 JAVAWeb部署经验:Maven包丢失、打包缺jar、classNotFound等
- IDEA Gradle 打包 Spring Boot 1.5x 可运行的jar文件流程
- spring boot -- 打包jar,war(二)打成war包,mapper文件扫描不到