测试项目在tomcat7中启动失败,报错如下:

@794314bc3
Error during job execution (jobs.Bootstrap) Oops: VerifyError
~ play.Logger.niceThrowable(Logger.java:) ~ play ~
play.exceptions.UnexpectedException: Unexpected Error
at play.Invoker$Invocation.onException(Invoker.java:)
at play.jobs.Job.onException(Job.java:)
at play.jobs.Job.call(Job.java:)
at Invocation.Job(Play!)
Caused by: java.lang.VerifyError: Expecting a stack map frame
Exception Details:
Location:
controllers/payment/PaymentBaseAction.check()V @: nop
Reason:
Expected stackmap frame at this location.
Bytecode:
: b804 1c00 b801 8c9a 8e03 bd00
: 6bb8 a700 c700 b1b8 b800 794b
: 152a b804 2ab6 009e 3c13
: 1bb8 041a 001b aa00
: 007f
: 008b 2a4d 014e 2c13 02a2
: a413 02a6 b802 aac0 004f 4e2d b800
: 003e 2a4d 033e 2c13 02ab ac13
: 02ae b802 b0c0 b602 b33e 1d99
: 2a4d 014e 2c13 02b4 b513 02b7 b802
00000a0: b9c0 004f 4e2d b800 b800 acb8
00000b0: 00af a700 1bb8 00b2 a700 15b8 00b5 a700
00000c0: 0fb8 00b8 a700 09b8 00bb a700 03a7 000e
00000d0: 3a06 013a 05b8 041e bf01 3a05 b804
00000e0: 20b1
Exception Handler Table:
bci [, ] => handler:
Stackmap Table:
same_frame(@)
append_frame(@,Object[#])
chop_frame(@,)
same_frame(@)
same_frame(@)
same_frame(@)
same_frame(@)
same_frame(@)
same_locals_1_stack_item_frame(@,Object[#])
same_frame(@) at payment.PaymentProxy.init(PaymentProxy.java:)
at jobs.Bootstrap.initPayment(Bootstrap.java:)
at jobs.Bootstrap.doJob(Bootstrap.java:)
at play.jobs.Job.doJobWithResult(Job.java:)
at play.jobs.Job.call(Job.java:)
... more

原因:

jvm验证时出了错误:显示字节码错误: 
网上的解释是因为引入版本为51的字节码规范,使用了严格的类型检查器,任何工具修改了字节码的,都需要更新stackmap,但是jws修改了字节码,而没有更新 stackmap使用了即java的新特性,所以使用较高的版本进行编译时就会报这个错。

解决办法

在tomcat 7启动文件中或者系统环境变量中加入

export JAVA_OPTS=-XX:-UseSplitVerifier

在tomcat 8启动文件中或者系统环境变量中加入

export JAVA_OPTS=-noverify

tomcat 7 参数优化实例

JAVA_OPTS='-server
-Xms2048m
-Xmx2048m
-Xss512k
-XX:PermSize=512m
-XX:MaxPermSize=512m
-XX:+UseParNewGC
-XX:+AggressiveOpts
-XX:+UseBiasedLocking
-XX:+DisableExplicitGC
-XX:+UseConcMarkSweepGC
-XX:+UseFastAccessorMethods
-XX:+CMSParallelRemarkEnabled
-XX:+UseCMSCompactAtFullCollection
-XX:+UseCMSInitiatingOccupancyOnly
-XX:-UseSplitVerifier'

附:在tomcat 8 ,JDK 1.8中,以上有些参数已被忽略或弃用,如下:

PermSize  忽略

MaxPermSize  忽略

UseCMSCompactAtFullCollection  弃用

- xx:ParallelGCThreads = N  如果处理器的数量预计将增加,那么你应该配置并行GC线程的数量来适当使用,N=处理器的个数

具体实例信息

[root@mytest ~]# /opt/apache-tomcat-8.5./bin/catalina.sh stop
Using CATALINA_BASE: /opt/apache-tomcat-8.5.
Using CATALINA_HOME: /opt/apache-tomcat-8.5.
Using CATALINA_TMPDIR: /opt/apache-tomcat-8.5./temp
Using JRE_HOME: /usr
Using CLASSPATH: /opt/apache-tomcat-8.5./bin/bootstrap.jar:/opt/apache-tomcat-8.5./bin/tomcat-juli.jar
OpenJDK -Bit Server VM warning: ignoring option PermSize=64m; support was removed in 8.0
OpenJDK -Bit Server VM warning: ignoring option MaxPermSize=512m; support was removed in 8.0
OpenJDK -Bit Server VM warning: UseCMSCompactAtFullCollection is deprecated and will likely be removed in a future release.
OpenJDK -Bit Server VM warning: If the number of processors is expected to increase from one, then you should configure the number of parallel
GC threads appropriately using -XX:ParallelGCThreads=N

记一次tomcat7.0版本启动项目失败问题的更多相关文章

  1. Android 开发 8.0版本启动Service的方法

    前言  google在更新Android8.0后对Service的权限越发收紧.导致目前想要启动服务必需实现服务的前台化(否则在服务启动5秒后,系统将自动报错).下面我们就来看看如何在8.0上启动服务 ...

  2. 【推荐】CentOS安装Tomcat-7.0.57+启动配置+安全配置+性能配置

    注:以下所有操作均在CentOS 6.5 x86_64位系统下完成. #准备工作# 在安装Tomcat之前,请确保已经安装了JDK-1.7环境,具体见<CentOS安装JDK-1.7>. ...

  3. Redis 3.0版本启动时出现警告的解决办法

    原文:http://m.blog.csdn.net/article/details?id=50864933 Redis 3.0.7版本启动时出现警告的解决办法 发表于2016/3/12 12:52:4 ...

  4. IDEA环境Spring Boot 2.3整合Activiti 6.0,启动项目初始化表并创建核心服务

    如下步骤照着抄就完事了. 一.新建一个spring boot项目,并引入相关依赖 <?xml version="1.0" encoding="UTF-8" ...

  5. 关于V1.6.0版本的项目总结

    10月28号,我们开了1.6项目的总结大会,包括Ting总在内,前端.后台.运维都来参加总结大会了.虽然目标基本达成,但同时也暴露出很多问题,我们希望各方能够坐下来总结一下自己或者各个相关团队的功过是 ...

  6. Tomcat7.0无法启动解决方法[failed to start]

    很奇怪的一个问题,Tomcat一直好好的,运行Servlet之后就报这个错: 为什么呢?在网上查都查不到解决方法,后来仔细检查了下Servlet,发现web.xml有个低级错误: 配置的Servlet ...

  7. Spring Boot 2.1.7 启动项目失败,报错: "Failed to configure a DataSource: 'url' attribute is not specified and no embedded datasource could be configured."

    一开始按照网上的很多解决办法是: 启动类头部声明@SpringBootApplication(exclude= {DataSourceAutoConfiguration.class}),但是这样会排除 ...

  8. tomcat7 启动项目报错 java.lang.NoSuchMethodError: javax.servlet.ServletContext.getSessionCookieConfig()

    JDK版本:jdk1.8.0_77 Tomcat 版本:apache-tomcat-7.0.47 异常重现步骤: 1.完成项目部署 2.启动Tomcat 异常头部信息:java.lang.NoSuch ...

  9. nexus3.14.0版本linux环境安装、启动、搭建私库

    本文介绍的是nexus3.14.0版本在linux环境下安装.启动.搭建私库. nexus3以上的版本太新了,网上很少介绍安装细节的.据了解和2.X版本有所不同了. 1.前提 linux机器上需先安装 ...

随机推荐

  1. 深度学习之从RNN到LSTM

    1.循环神经网络概述 循环神经网络(RNN)和DNN,CNN不同,它能处理序列问题.常见的序列有:一段段连续的语音,一段段连续的手写文字,一条句子等等.这些序列长短不一,又比较难拆分成一个个独立的样本 ...

  2. 转://Oracle A用户给B用户授权查询指定表或视图权限方案

    用DNINMSV31账户登录数据库进行如下操作: CREATE USER NORTHBOUND IDENTIFIED BY NORTHBOUND DEFAULT TABLESPACE "TB ...

  3. selenium之选项卡管理

    在使用selenium管理浏览器的时候遇到一些小问题,现将这些小问题作一下总结: (1)browser是什么? from selenium import webdriver browser = web ...

  4. 009_python魔法函数

    11. (译)Python魔法方法指南 原文: http://www.rafekettler.com/magicmethods.html 原作者: Rafe Kettler 翻译: hit9 原版(英 ...

  5. PAT A1095 Cars on Campus (30 分)——排序,时序,从头遍历会超时

    Zhejiang University has 8 campuses and a lot of gates. From each gate we can collect the in/out time ...

  6. idea 2018.1 for mac JRebel破解

    第一步: 在 Idea 中下载 Jrebel 路径:preferences-plugins-Browse repositories-直接搜索下载 Jrebel   第二步:配置反向代理工具 1.安装 ...

  7. Redux与它的中间件:redux-thunk,redux-actions,redux-promise,redux-saga

    序言 这里要讲的就是一个Redux在React中的应用问题,讲一讲Redux,react-redux,redux-thunk,redux-actions,redux-promise,redux-sag ...

  8. eclipse 执行自带的maven命令无效

    原文地址:https://blog.csdn.net/qq_26386171/article/details/78262702 下面加上(前提是你的环境变量里已经配置过) -Dmaven.multiM ...

  9. [Loadrunner参数化]一个文件输两列参数的取值

    关于LoadRunner参数化的内容,在脚本开发中属于非常重要的一个知识点.关于这部分知识,在书上和网上到处都能找到,本篇只讲一种特殊情况:一个参数化文件为File类型,有多列值,如何进行参数化取值. ...

  10. H5 36-背景定位属性

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...