出现的问题

  今天自己新建了一个maven webapp项目,准备自己看看springboot的东西,搭好的项目是这样的

一切都很正常啊,用run App的方式直接启动

成功啦,本应该到此结束,喝茶吃饭去,脑子一抽,不对,平时我们线上都是外部tomcat跑程序,要不我也用tomcat跑跑。tomcat很快就跑起来了,再一想,好像平时web项目都是用jetty调试的嘛,干嘛用tomcat跑呢,用jetty跑跑呗。

run jetty,go。。。咦

这是什么鬼,仔细看看,怎么从jetty跑到tomcat里面去了?脑子有点乱,这俩根本不是一家啊

  

问题解决

  不管怎么样,ServletContext的getVirtualServerName方法没找到,先google一下吧,stackoverflow上都是说项目里引入servlet-api-2.5,而这个方法是3.1以后才有的,mvn dependency:tree看一下,没有引入啊,

  想不起来从哪看来个solution,改一下web app版本,想想对啊,javax是jdk里面的吧,web app版本可能会影响使用的servlet

狠点,直接改成3.0吧,想必是这个,改了还报错,最后各种解决报错,还是不行,这条路走了很久,发现错了。

  

  旁边应姓大牛看不下去了,曰:这个servlet-api不是jdk里面的,应该是jetty运行需要的吧

  有道理啊,下个jetty看看,曰:@%&¥@¥

还真是jetty8用的servlet-api 3.0,下个高版本的jetty run看看,jetty9用的servlet3.1

go,我的神啊,

吃饭吃饭。。。

  

思考

  吃完饭回了,听歌睡睡觉吧,脑子闪过个tomcat,刚刚不是报错是tomcat么,为什么jetty run会跑到tomcat里面去呢,再看看报错,

先看看WsServerContainer吧,恩,好像在设置线程组的时候用到这个方法了,

还是从源头找吧,从jetty-plus里面的ContainerInitializer的callStartup方法进入tomcat的,就是这里

看看_target是什么吧,

这是servlet容器吧,有点明朗了,springboot内嵌的tomcat里面有这个ServletContainerInitializer,先被加载了,jetty再把自己初始化出来的servletContext传给它,jetty的servlet-api没有getVitualServerName方法,所以tomcat那边报错了,由此推理,应该tomcat的ServletContext接口应该有这个方法,看看吧,

真有这个方法,而且tomcat就是牛逼,直接把javax.servlet抄过来了,这样就摆脱了对Servlet-api依赖了,以前写项目都是这么干的么,还是别的原因,大牛教教我吧

  既然用jetty跑,就把tomcat去掉吧

排除内嵌的tomcat后,直接用jetty是可以的。

 

总结:仔细看报错代码,从报错源头查起,all in one,没事别瞎几把折腾。。。

蛋疼的springboot web项目使用jetty容器运行的更多相关文章

  1. springboot web项目创建及自动配置分析(thymeleaf+flyway)

    @ 目录 源码分析 webjars thymeleaf thymeleaf语法 springmvc 启动配置原理 集成flyway插件 springboot 创建web项目只需要引入对应的web-st ...

  2. web项目嵌入Jetty运行的两种方式(Jetty插件和自制Jetty服务器)

    在开发Java web项目时候,可以在项目中嵌入Jetty服务的方式来运行web程序. 由于最近开发web项目,自己使用的是比较旧的eclipse不支持导入tomcat来运行项目,于是就学习了下使用项 ...

  3. maven构建web项目,用jetty测试的配置pom.xml

    maven构建web项目,用jetty测试的配置pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmln ...

  4. 如何在spring-boot web项目中启用swagger

    swagger的三个项目及其作用 我们打开swagger的官网,会发现有三个swagger相关的项目,它们分别是 swagger-editor 作用是通过写代码,生成文档描述(一个json文件或其他格 ...

  5. SpringBoot Web项目中中如何使用Junit

    Junit这种老技术,现在又拿出来说,不为别的,某种程度上来说,更是为了要说明它在项目中的重要性. 凭本人的感觉和经验来说,在项目中完全按标准都写Junit用例覆盖大部分业务代码的,应该不会超过一半. ...

  6. 部署Eclipse中的Web项目到Tomcat服务器运行

    用Eclipse开发Web项目时,可以通过Tomcat服务器运行Web项目,此时Web项目被部署在[WorkSpace]\.metadata\.plugins\org.eclipse.wst.serv ...

  7. Spring Boot 的Maven多模块开发web项目使用外部容器进行部署

    Spring Boot中自带有Tomcat容器,因此Spring Boot项目只需要运行main函数,就可以运行,但是以往的web项目,我们习惯于使用自己安装的Tomcat运行或者使用Tomcat.J ...

  8. 【转】SpringBoot——web项目下读取classpath下的文件心得

    在读取springBoot+gradle构建的项目时,如果使用传统的FileInputStream读取文件流或者ResourceUtils工具类的方式,都会失败,下面解释原因: 一.读取文件的三种方式 ...

  9. springboot web项目的单元测试

    不废话,直接上代码. //// SpringJUnit支持,由此引入Spring-Test框架支持! @RunWith(SpringJUnit4ClassRunner.class) //// 指定我们 ...

随机推荐

  1. angular异步获取数据后在ngOnInit中无法获取,显示undefined解决办法

    两种方法 1 通过*ngif动态加载要数据渲染的dom 2 通过路由导航resolve 第一种感觉太麻烦了,要是一个页面请求多个接口,那就不得不写多个*ngif,本人还是更倾向与第二种发法 具体步骤: ...

  2. SIM7600CE http post

    SIM7600CE是一款SMT封装的模块,支持 LTE-TDD/LTE-FDD/HSPA+/TD-SCDMA/EVDO和GSM/GPRS/EDGE等频段,支持LTE CAT4(下行速度为150Mbps ...

  3. ..\USER\stm32f10x.h(428): error: #67: expected a "}" ADC1_2_IRQn = 18, /*!

    MDK软件编译,出现如下错误: ..\USER\stm32f10x.h(428): error: #67: expected a "}" ADC1_2_IRQn = 18, /*! ...

  4. MySQL FEDERATED引擎使用示例, 类似Oracle DBLINK(转)

    1 引擎说明 本地MySQL数据库要访问远程MySQL数据库的表中的数据, 必须通过FEDERATED存储引擎来实现. 有点类似Oracle中的 数据库链接(DBLINK). 要允许这个存储引擎, 当 ...

  5. git/github安装与使用教程

    新学习了Git和GitHub的使用,记一下笔记,也希望可以帮助他人,这里只是初级阶段,以后还会不断的修改和完善. 1.什么是git 开源的分布式版本控制系统,与svn比独特的地方: 1.解决了svn后 ...

  6. 【hbase】hbase的shell操作笔记

    HBase Shell $ ./bin/hbase shell # 进入交互界面 DDL操作: create:创建表(默认命名空间为default) # create '表名','列族1','列族2' ...

  7. Python——Python安装

    下载地址:https://www.python.org/downloads/windows/ 3.X安装方法: 1. 设置一个自选路径,并将下面的选项打钩.(建议使用根目录) 2. 应用在所有用户中 ...

  8. JAVA 的8种基本数据类型

    整型 int 一般的数据 long 极大的数据 short 用于特定的场合,比如底层的文件处理或者需要控制占用存储单元空间量的大数组 byte 用于特定的场合,比如底层的文件处理或者需要控制占用存储单 ...

  9. [Exception] java.util.MissingFormatArgumentException

    java.util.MissingFormatArgumentException: Format specifier 's' at java.util.Formatter.format(Formatt ...

  10. 大数据之路week07--day05 (一个基于Hadoop的数据仓库建模工具之一 HIve)

    什么是Hive? 我来一个短而精悍的总结(面试常问) 1:hive是基于hadoop的数据仓库建模工具之一(后面还有TEZ,Spark). 2:hive可以使用类sql方言,对存储在hdfs上的数据进 ...