解决Linux部署Tomcat发布项目过程中各种问题

部署项目到项目现场测试环境

JDK1.8
Tomcat8.5
Maven打包好的war
Linux-----Centos
不知道谁给现场的Tomcat,将其上传到Linux平台******目录,并且进行解压。直接启动

  • 图1:
    tomcat目录结构

问题1

因为是第一次启动Tocmat,没有日志文件。所以直接启动 ./startup.sh。后续可以使用以下命令动态的查看日志信息。执行后提示没有执行权限

	./startup.sh & tailf ../logs/catalina.out
  1. 问题分析: .sh可执行文件 当前用户都不具备权限

  2. 问题解决: 使用命令:chmod u+x *.sh。在tomcat/bin目录下执行

  3. 命令分析: 表示对当前目录下的所有.sh文件的所有者增加可执行权限。

    • chmod是权限管理命令change the permissions mode of a file的缩写
    • u 代表所有者;
    • x 代表执行权限;
    • “+” 表示增加权限。
    • 也可以单独指定一个文件 比如:chmod u+x abc.sh
    • 然后用./startup.sh启动。
  • 图2:
    权限不足显示。

问题2

启动之后报错找不到 *****目录下的文件。

  1. 问题分析: 此问题出现是因为在 tomcat 的server.xml文件中配置了多个 Context环境。但是在指定的目录下并没有项目部署。
  2. 问题解决: 删除server.xml文件中所有的Context。删除 tomcat 目录webapps以及wtpwebapps 下所有部署过的项目。此时只是单独启动一个 ebank。启动成功,访问8080成功。
  • 图3:
    server.xml 带有Context的目录。

问题3

在 tomcat 服务器 webapps上添加Maven打包好的war包。之后进行启动。但是报错端口被占用。

  1. 问题分析: 这个操作是在没有暂停之前那一步操作进行的。所以导致端口被占用。可是直接暂停tomcat之后还是报端口被占用
  2. 问题解决: 采用暴力一点的方式:
    查询ebank进程ID:ps aux|grep tomcat
    直接杀掉进程:kill-9 PID 杀掉tomcat的进程,之后可以正常的启动
  • 图4:
    端口被占用错误信息

问题4

此时虽然可以正常启动,但是报错:java.lang.OutOfMemoryError: PermGen space(提示内存溢出,属于永久区的内存溢出)。

  1. 问题分析: Tomcat的内存参数之前并没有设置过,当前部署的项目占用内存较大加载的class较多。导致永久区内存不够使用。
  2. 问题解决: 将tomcat 的bin 下 catalina.sh文件复制一份进行修改,将原先的进行备份。在catalina.sh文件中 找到cygwin=false位置的前面 添加参数,注意引号要带上
    JAVA_OPTS="-Xms256m -Xmx512m -XX:PermSize=128m -XX:MaxPermSize=256m"
    将修改后的文件替换到tomcat/bin下。
  • 图5:堆内存溢出报错信息
  • 图6:
    catalina.sh文件修改内容

问题5

此时再次启动,但是提示找不到catalina.sh文件?

  1. 问题分析: 因为在startup.sh执行文件中会调用catalina.sh执行文件。从而启动Tomcat服务。后续使用命令 ll 查看bin目录下。发现问题此时的catalina.sh 文件不在是一个可以执行的文件了。(不是绿色的)
  2. 问题解决: 再次使用chmod u+x catalina.sh 赋予可以执行的权限。
  • 图7:
    在startup.sh文件中 调用catalina.sh执行文件

  • 图8:图中以hello.sh 举个栗子。(显示为黑色,与catalina.sh 不同)
     区分是否为可执行文件

问题6

启动成功,但是在浏览器确访问不到项目,访问8080成功。

  1. 问题分析: 在Tomcat的webapps目录下发现,经过Tocmat的解压缩将各个War包解压后 都带有版本号(war包是Maven打包生成的,带有版本号)。浏览器访问的正确地址是不带版本号的
  2. 问题解决: 删除项目,重新命名War包。再次启动。到此为止全部成功
  • 图8:
    webapps目录下 带有版本号的war项目

额外使用的命令

  1. 清空日志:
    	echo -n "" > ../logs/catalina.out
    	固定语法:echo -n "" >
    
  2. 查看日志大小:
    	du -h ../logs/catalina.out
    	固定语法:du -h >
    
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值