Tomcat启动时出现java.sql.SQLException
如果不是Web应用程序直接在类中写连jdbc的代码能正常运行
如果那样的话是可以正常运行的。。
估计你是不是配置数据库连接池了。。或者你用到speing或者别的什么连接池了。所以在启动的时候。tomcat去访问数据库出现连接异常导致这个异常出现
Exception in thread "com.mchange.v2.async.ThreadPoolAsynchronousRunner$PoolThread-#2"
//字符串定义
String yLPingTaiXinWen = "YLPingTaiXinWen";
//定义一个查询,查找CmsArticle类,去查Hibernate.cfg.xml就可以知道对应的表。通常就是CmsArticle表。
DetachedCriteria yLPingTaiXinWenCriteria = DetachedCriteria.forClass(CmsArticle.class);
//建立一个别名,就是另外一个关联表。相当于select语句中的as部分 (select * from table1 as catalog ...)
//这里将PROP_CMS_CATALOG 定义一个别名叫 catalog
//大概是一个外建所关联的另外一个表。
yLPingTaiXinWenCriteria.createAlias(CmsArticle.PROP_CMS_CATALOG, "catalog");
//添加查询条件,catalog表的buildincode为上面的字符串,相当于设置select语句的where部分。
yLPingTaiXinWenCriteria.add(Restrictions.eq("catalog"+".buildInCode", yLPingTaiXinWen));
//增加排序条件,按时间排序
yLPingTaiXinWenCriteria.addOrder(Order.desc(CmsArticle.PROP_LAST_EDIT_TIME));
//获取查询结果
List yLPingTaiXinWenList = getCommonFacade().findByCriteria(yLPingTaiXinWenCriteria);
//放到Request里面,大概是jsp页面要用了。
httpServletRequest.setAttribute("yLPingTaiXinWenList", yLPingTaiXinWenList);
java.lang.OutOfMemoryError: PermGen space
表示你的内存永久保存区溢出了。
PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,
这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGen space中,
它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对
PermGen space进行清理,所以如果你的应用中有很多CLASS的话,就很可能出现PermGen space错误,
这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大量的第三方jar, 其大小
超过了jvm默认的大小(4M)那么就会产生此错误信息了。
解决方法: 手动设置MaxPermSize大小
修改TOMCAT_HOME/bin/catalina.sh
在“echo "Using CATALINA_BASE: $CATALINA_BASE"”上面加入以下行:
JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m
根据硬件配置或实际需要,这些设置的内存大小可以再提高一些。
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!