项目中遇到的问题
2016-02-05 14:15
288 查看
① 某个jar包不能自动部署到tomcat
maven配置是没有问题的,其他项目都能正常部署到tomcat。我新开始的一个小项目,一直有一个pojo的jar包不能自动部署到tomcat,其他jar包都自动部署过去了。在target目录下面lib包里是有的。我每次部署都是手动拷贝过去。问同事,一开始他说是tomcat的版本要tomcat8.0.30的。我目前是tomcat8.0.23的。换了之后还是有这个问题。还有一个是IOrderService这个类找不到。前一个问题早上他说是Java compiler版本的问题。选中项目右键后发现D-express的Java
compiler的版本没有继承全局的配置,变成了1.5。我本地装的是1.8的。改成1.8之后就没有这个问题了。打开看其他项目的版本都是1.8.
上面的都没有根本是解决缺少jar包问题。后面他仔细看了后发现A-service和B-service两个同时部署到tomcat的项目却显示有D-express项目(tomcat添加项目后,展开项目可以看到),在pom文件里没有引用D-express却有D-express的jar包,原来是A和B引入了C-inf这个jar,而c-inf里引入了D-express项目了,F-web引用了A和B,也就间接引入了D-express这个jar,在F-web的pom文件删除jar包引用就好了。
② 自动建表出现的问题
改变了字段类型后,数据库的表没有重建,但是后面处理时就容易报错。数据库里是修改字段之前的数据,而处理时是之后的数据类型,但是报的错误是字段类型不一致。
③Excel表格出现heap stack overflow
还有就是Excel表格上传,用的apache poi 插件上传。本来处理五万条数据应该是没有问题。action里得到之后传到Service层,然后进行Excel解析成字符串数组,结果处理到一万多条就报内存溢出,java heap stack overflow. 网上的解决方法是把jvm的配置调高一些,我调高了依然解决不了问题。F看了下我的程序,让我不要把资源传到后台。在Controller层解析好数据,就把那个资源释放了,到service层就专门处理业务的东西,不要一起把一万条数据保存到数据库,1000条保存一次就好了。在网上也查到过,内存溢出是由于存储的变量太大,那尽量把变量变成局部变量,这样用完就能被垃圾回收了。我就把outputstream解析完数据就释放了,list变成iterate,保存到数据库后就移除,这样下来竟然不报错误,能保存到五万条了。
出现这些原因是对原理性的知识学习不够,不然就能很容易解决问题了。
maven配置是没有问题的,其他项目都能正常部署到tomcat。我新开始的一个小项目,一直有一个pojo的jar包不能自动部署到tomcat,其他jar包都自动部署过去了。在target目录下面lib包里是有的。我每次部署都是手动拷贝过去。问同事,一开始他说是tomcat的版本要tomcat8.0.30的。我目前是tomcat8.0.23的。换了之后还是有这个问题。还有一个是IOrderService这个类找不到。前一个问题早上他说是Java compiler版本的问题。选中项目右键后发现D-express的Java
compiler的版本没有继承全局的配置,变成了1.5。我本地装的是1.8的。改成1.8之后就没有这个问题了。打开看其他项目的版本都是1.8.
上面的都没有根本是解决缺少jar包问题。后面他仔细看了后发现A-service和B-service两个同时部署到tomcat的项目却显示有D-express项目(tomcat添加项目后,展开项目可以看到),在pom文件里没有引用D-express却有D-express的jar包,原来是A和B引入了C-inf这个jar,而c-inf里引入了D-express项目了,F-web引用了A和B,也就间接引入了D-express这个jar,在F-web的pom文件删除jar包引用就好了。
② 自动建表出现的问题
改变了字段类型后,数据库的表没有重建,但是后面处理时就容易报错。数据库里是修改字段之前的数据,而处理时是之后的数据类型,但是报的错误是字段类型不一致。
③Excel表格出现heap stack overflow
还有就是Excel表格上传,用的apache poi 插件上传。本来处理五万条数据应该是没有问题。action里得到之后传到Service层,然后进行Excel解析成字符串数组,结果处理到一万多条就报内存溢出,java heap stack overflow. 网上的解决方法是把jvm的配置调高一些,我调高了依然解决不了问题。F看了下我的程序,让我不要把资源传到后台。在Controller层解析好数据,就把那个资源释放了,到service层就专门处理业务的东西,不要一起把一万条数据保存到数据库,1000条保存一次就好了。在网上也查到过,内存溢出是由于存储的变量太大,那尽量把变量变成局部变量,这样用完就能被垃圾回收了。我就把outputstream解析完数据就释放了,list变成iterate,保存到数据库后就移除,这样下来竟然不报错误,能保存到五万条了。
出现这些原因是对原理性的知识学习不够,不然就能很容易解决问题了。
相关文章推荐
- 使用Python生成Excel格式的图片
- Excel 曝出 Power Query 安全漏洞,1.2 亿用户易受远程 DDE 攻击
- VBA将excel数据表生成JSON文件
- excel vba 限制工作表的滚动区域代码
- excel vba 高亮显示当前行代码
- SQL 导入导出Excel数据的语句
- 文本、Excel、Access数据导入SQL Server2000的方法
- C#导出数据到Excel文件的方法
- Vbscript生成Excel报表的常用操作总结
- C#实现导入CSV文件到Excel工作簿的方法
- C#基于NPOI生成具有精确列宽行高的Excel文件的方法
- 总提示[Microsoft][ODBC Excel Driver] 数值字段溢出官方解决方法
- C#将Sql数据保存到Excel文件中的方法
- VC6.0实现读取Excel数据的方法
- C#定制Excel界面并实现与数据库交互的方法
- 把excel表格里的数据导入sql数据库的两种方法
- access dbase excel foxpro 数据库浏览器V3.1版 下载
- C#实现把txt文本数据快速读取到excel中
- C#自定义导出数据到Excel的类实例
- 使用PHPExcel操作Excel用法实例分析