项目完成了部分功能,需要把项目放到公网上,方便演示讨论。本来以为挺简单的,直接将war包放到腾讯云服务器tomcat中,结果报错404,第一次碰到这种情况,于是想办法解决,花了一天的时间,终于解决了问题,和大家分享一下解决的过程,希望对大家有所帮助。解决的途径还是靠百度以及参考资料,分析可能的原因,然后不断测试,直到问题解决。

一 问题描述

项目使用的开发工具是IntelliJ IDEA,运行web项目程序,在本地进行测试,页面能够正常打开并且测试结果符合预期。将web项目程序打成了war包,放到局域网服务器的tomcat的webapps目录中,然后重新启动服务器的tomcat,再进行程序功能测试,页面能够正常打开并且测试结果符合预期。将war包放到腾讯云服务器的tomcat的webapps目录中,重新启动tomcat,再进行测试,发现404错误,不能正常定位到程序页面。

二 问题分析

由于同一个war包在本地和局域网都能正常运行,而在腾讯云中不能正常运行,所以分析本机、局域网服务器和腾讯云服务器之间的区别,查找不同点。首先是考虑是不是腾讯云的安全机制,对于访问的端口有限制,腾讯云服务器确实有端口访问控制,可以设置开放某些常用端口,比如web服务端口(80,443,8080),SSH登录端口(22),mysql端口(3306)等,端口放开后,问题依然没有解决。第二考虑是不是jdk,tomcat的版本问题,jdk使用的版本都是jdk8,具体版本有点差别,修改为统一的版本。Tomcat的版本情况类似,也修改为统一的版本。版本统一后,测试,问题依旧存在。第三,考虑操作系统的不同对程序的影响,本地和局域网都是在windows环境中,tomcat启动时,都能实时看到tomcat的日志信息,有什么问题一目了然。而腾讯云用的是centos7,linux操作系统,tomcat启动后,实时日志信息不能看到,也就不知道tomcat在启动过程中是否发生了错误,为了实时查看tomcat的日志信息,在重启tomcat后,打开日志文件。

三 问题解决

在linux系统,切换到tomcat的bin目录,依次键入

./shutdown.sh

./startup.sh

重启tomcat,然后切换到tomcat的logs目录,键入

tail -f catalina.out

就可以实时查看tomcat的日志信息,日志信息比较多,不过错误信息也是很明显的,和用开发工具调试的时候碰到的报错信息类似,很容易发现。报错信息的开头,就是如下的一段。

Unable to register MBean [HikariDataSource (null)] with key 'dataSource'; nested exception is javax.management.InstanceAlreadyExistsException: com.zaxxer.hikari:name=dataSource,type=HikariDataSource

百度了一下,问题解答定位到了StackOverflow网站,不得不说,StackOverflow上的大牛们确实很热心,有靠谱的回答,试了试,果然管用。

方法就是在配置文件application.properties中,进行如下设置

spring.jmx.enabled=false

重新生成war包,测试,页面能够正常打开,功能也都正常。

四 一些未解决的疑惑

虽然问题解决了,但还是有些疑惑的地方,比如同样的war包,在windows环境中能够使用,到了linux环境中报错,具体原因不是太了解。再有就是报错的大概意思是不能注册MBean,解决的办法就是不注册,直接将jmx设置为false,虽然项目能够运行,但不知道具体的影响有哪些。这些问题可能还需要在实践中摸索。

最后希望对大家调试程序有所帮助,如果有大牛对我提出的疑问,有好的解答,也请不吝赐教。

war包部署到腾讯云中报404的排错经历的更多相关文章

  1. 怎样将本地web数据库项目部署到腾讯云服务器上?

    怎样将本地web数据库项目 部署到腾讯云服务器上? 1.本地计算机的工作: 1.1用eclipse或者myeclipse做好一个web项目,可以只做一个数据库的增删改查,本地部署到Tomcat服务器, ...

  2. 怎样将本地web项目部署到腾讯云服务器上?

    怎样将本地web项目部署到腾讯云服务器上? 1.本地计算机的工作: (1).用eclipse新建一个web项目,然后在webcontent下新建一个index.html,然后在本地部署到Tomcat服 ...

  3. eclipse项目转移至IDEA与IDEA tomcat报错(idea自带tomcat版本太高)与war包部署到win服务器与idea提交git的总结

    eclipse导出项目到idea时,不要导出target: idea打开eclipse项目后,出现junit找不到的问题,原因是jar包缺失,而maven配置的低版本的junit也显示找不到,解决办法 ...

  4. struts2使用Convention Plugin在weblogic上以war包部署时,找不到Action的解决办法

    环境: struts 2.3.16.3 + Convention Plugin 2.3.16.3 实现零配置 现象:以文件夹方式部署在weblogic(10.3.3)上时一切正常,换成war包部署,运 ...

  5. 将war包部署到服务器的详细步骤

    第一步: 先将项目打包成war文件,也就是将在项目上单击鼠标右键,选择Export: 选择WAR file,点击下一步: 会出现如下所示,选择你要保存的位置,点击完成: 在你所选择的地方会有个如下所示 ...

  6. XWIKI离线WAR包部署(LDAP登录)

    背景 接任务部署一个wiki, 要求: java语言开发, 开源, 内网部署; 需要支持: 大文件上传(300m左右), 所见即所得(wycwyg), 导出, LDAP, 评论与权限. 通过一个好用的 ...

  7. SpringBoot之打成war包部署到Tomcat

    正常情况下SpringBoot项目是以jar包的形式,正常情况下SpringBoot项目是以jar包的形式,并且SpringBoot是内嵌Tomcat服务器,所以每次重新启动都是用的新的Tomcat服 ...

  8. springboot 学习之路 5(打成war包部署tomcat)

    目录:[持续更新.....] spring 部分常用注解 spring boot 学习之路1(简单入门) spring boot 学习之路2(注解介绍) spring boot 学习之路3( 集成my ...

  9. Windows下war包部署到Linux下Tomcat出现的问题

    最近,将Windows下开发的war包部署到Linux下的Tomcat时报了一个错误:tomcat error in opening zip file.按理说,如果正常,当把war包复制到webapp ...

随机推荐

  1. HeadFirst学习笔记-1. 设计模式入门

    1.概念 在开始学习前,我们先了解一些概念,方便我们接下来的学习. OO基础 抽象 继承 多态 封装 OO原则 封装变化 多用组合,少用继承 针对接口编程,不针对实现编程 设计模式 设计模式(Desi ...

  2. Hive的DDL操作

    DDL:data definittion language 数据定义语言 主要是定义或改变表的结构.数据类型.表之间的链接和约束等初始化操作 DML:data manipulation languag ...

  3. redis与memacache的区别(转)

    redis和memecache的不同在于:1.存储方式:memecache 把数据全部存在内存之中,断电后会挂掉,数据不能超过内存大小redis有部份存在硬盘上,这样能保证数据的持久性.2.数据支持类 ...

  4. centOS7.3安装配置NFS服务

    在安装和运行NFS服务中,发现了一个需要警惕的地方. 运行2个centOS7.3系统.由于前面一篇已经写了使用xshell进行远程,所以,直接远程进行操作: chen-01做为服务端,chen-02做 ...

  5. 机器学习——KMeans

    导入类库 from sklearn.cluster import KMeans from sklearn.datasets import make_blobs import numpy as np i ...

  6. SpringBoot报错:nested exception is org.apache.ibatis.executor.ExecutorException: No constructor found in com.tuyrk.test.User matching [java.lang.Long, java.lang.String, java.lang.String]

    错误提示: Caused by: org.apache.ibatis.executor.ExecutorException: No constructor found in com.tuyrk._16 ...

  7. [LeetCode] Hand of Straights 一手顺子牌

    Alice has a hand of cards, given as an array of integers. Now she wants to rearrange the cards into ...

  8. ipset和iptables配合来自动封闭和解封有问题的IP

    iptables封掉少量ip处理是没什么问题的,但是当有大量ip攻击的时候性能就跟不上了,iptables是O(N)的性能.而ipset就像一个集合,把需要封闭的ip地址放入这个集合中,ipset 是 ...

  9. cadence PCB板级设计

    总结PCB板框设计,定位孔的放置,以及布线区域和元件放置区域的放置,最重要的是层叠结构的设计.

  10. Python基础之面向对象2(封装)

    一.封装定义: 二.作用 三.私有成员: 1.基本概念及作用 2.__slots__手段私有成员: 3.@property属性手段私有成员: 四.基础示例代码 1.用方法封装变量 "&quo ...