上传安装包

  • 使用FinalShell自带的上传工具将Tomcat的二进制发布包上传到Linux。

content-591

解压安装包

  • 将上传上来的安装包解压到指定目录/usr/local下,执行命令为:
1
tar -zxvf apache-tomcat-7.0.57.tar.gz -C /usr/local

启动Tomcat

  • 进入Tomcat的bin目录启动服务。执行命令为:
1
2
3
4
5
cd /usr/local/apache-tomcat-7.0.57/

cd bin

sh startup.sh或者./startup.sh

content-592

content-593

Tomcat进程查看

  • 将Tomcat启动完成之后,并不能知道Tomcat是否正常运行。

    验证Tomcat启动是否成功,有多种方式,这里主要介绍常见的两种方式:

查看启动日志

  • Tomcat的启动日志输出在Tomcat的安装目录下的logs目录中,Tomcat的启动及运行日志文件名为catalina.out

    所以查看Tomcat启动日志,主要可以通过两条指令,如下:

1
2
3
4
5
1). 分页查询Tomcat的日志信息
more /usr/local/apache-tomcat-7.0.57/logs/catalina.out

2). 查询日志文件尾部的50行记录
tail -50 /usr/local/apache-tomcat-7.0.57/logs/catalina.out
  • 只要Tomcat在启动的过程中,日志输出没有报错,基本可以判定Tomcat启动成功了。

查询系统进程

  • 也可以通过Linux系统的查看系统进程的指令,来判定Tomcat进程是否存在,从而判定Tomcat是否启动。

    执行如下指令:

1
ps -ef|grep tomcat

content-594

  • 说明:

    • ps命令是linux下非常强大的进程查看命令,通过ps -ef可以查看当前运行的所有进程的详细信息。

    • |在Linux中称为管道符,可以将前一个命令的结果输出给后一个命令作为输入。

    • 使用ps命令查看进程时,经常配合管道符和查找命令grep一起使用,来查看特定进程。

防火墙操作

  • 前面已经通过日志的方式及查看系统进程的方式,验证了Tomcat服务已经正常启动。

    接下来就可以尝试访问一下。访问地址:http://192.168.138.130:8080

content-595

  • 那为什么tomcat启动成功了,但是访问不到呢?

    原因就在于Linux系统安装完毕后,系统启动时,防火墙自动启动,防火墙拦截了所有端口的访问。

    操作防火墙的具体指令如下:

操作指令备注
查看防火墙状态systemctl status firewalld / firewall-cmd --state
暂时关闭防火墙systemctl stop firewalld
永久关闭防火墙(禁用开机自启)systemctl disable firewalld下次启动,才生效
暂时开启防火墙systemctl start firewalld
永久开启防火墙(启用开机自启)systemctl enable firewalld下次启动,才生效
开放指定端口firewall-cmd --zone=public --add-port=8080/tcp --permanent需要重新加载生效
关闭指定端口firewall-cmd --zone=public --remove-port=8080/tcp --permanent需要重新加载生效
立即生效(重新加载)firewall-cmd --reload
查看开放端口firewall-cmd --zone=public --list-ports

注意:

​ A. systemctl是管理Linux中服务的命令,可以对服务进行启动、停止、重启、查看状态等操作

​ B. firewall-cmd是Linux中专门用于控制防火墙的命令

​ C. 为了保证系统安全,服务器的防火墙不建议关闭

  • 要想访问到Tomcat,就可以采取两种类型的操作:

关闭防火墙

  • 执行指令 :
1
systemctl stop firewalld
  • 关闭之后,再次访问Tomcat,就可以访问到了。

content-596

注意: 上面也提到了,直接关闭系统的防火墙,是不建议的,因为这样会造成系统不安全。

开放Tomcat的端口号8080

  • 执行指令:
1
2
3
4
5
6
7
8
①. 先开启系统防火墙
systemctl start firewalld

②. 再开放8080端口号
firewall-cmd --zone=public --add-port=8080/tcp --permanent

③. 重新加载防火墙
firewall-cmd --reload
  • 执行上述的操作之后,就开放了当前系统中的8080端口号,再次访问Tomcat。

content-597

停止Tomcat

  • 在Linux系统中,停止Tomcat服务的方式主要有两种:

运行Tomcat提供的脚本文件

  • 在Tomcat安装目录下有一个bin目录,存放的是tomcat的运行脚本文件,其中一个脚本就是用于停止tomcat服务的。

content-598

  • 切换到bin目录,并执行如下指令,来停止Tomcat服务:
1
2
sh shutdown.sh
./shutdown.sh

结束Tomcat进程

  • 可以先通过ps -ef|grep tomcat 指令查看tomcat进程的信息,从进程信息中获取tomcat服务的进程号。

    然后通过kill -9的形式,来杀死系统进程。

content-599

  • 通过上述的指令,可以获取到tomcat的进程号为79947。接下来,可以通过以下指令来杀死tomcat的进程 :
1
kill -9 79947 
  • 执行完上述指令之后,再访问Linux系统中的Tomcat,就访问不到了。

注意:

​ kill命令是Linux提供的用于结束进程的命令,-9表示强制结束

​ 虽然上述讲解的两种方式,都可以停止Tomcat服务,但是推荐使用第一种方式(./shutdown.sh)执行脚本来关闭tomcat服务

​ 如果通过第一种方式停止不了tomcat了,这个时候可以考虑使用第二种方式,强制杀死进程。