|
|
51CTO旗下网站
|
|
移动端

超实用的Tomcat启动脚本实现

有这样一个场景,公司为了安全起见,需要对所有登录Linux服务器做安全限制,要求除了管理员其他要登录linux服务器的员工不能用最高权限账号登录,要创建新的用户,对目录及文件权限做出控制。

作者:卧龙小蛋蛋来源:今日头条|2019-05-21 15:28

有这样一个场景,公司为了安全起见,需要对所有登录Linux服务器做安全限制,要求除了管理员其他要登录linux服务器的员工不能用最高权限账号登录,要创建新的用户,对目录及文件权限做出控制,只能对需要操作的目录允许读,写,执行权限,其他目录只有读的权限,并且所有tomcat不能直接在bin中用startup.sh,shutdown.sh进行启动和停止,要通过写shell脚本进行此操作,也就是说有两个步骤,创建用户并设置权限,写tomcat启动脚本,下面我们就完成这两个步骤。

1.首先我们就来创建一个普通用户。

  1. groupadd tomcat #加组 
  2. useradd -g tomcat -s /usr/sbin/nologin tomcat #向组加用户 
  3. usermod -L tomcat #锁定密码,使密码无效 
  4. passwd tomcat # 设置密码 

通过这四步,我们就把普通用户创建好了,在创建用户时,我们是先创建的组,组创建完成后创建用户并加入该组。

用户创建完成后,就开始给用户设置权限

  1. chown -R tomcat:tomcat /data #分配权限给用户 

这就是给tomcat这个用户设置了可以操作data目录及其子目录下的权限,-R就代表该目录及其级联子目录。

  1. [root@localhost data]# ls -l 
  2. total 0 
  3. drwxr-xr-x. 4 tomcat tomcat 79 May 20 08:03 tomcat 
  4. [root@localhost data]#  

此时我们通过ls -l 命令就可以看到data目录已经属于tomcat用户,且拥有查看,写入,执行权限

2.完成了用户创建后,我们就要开始完成tomcat启动脚本。

如代码所示:

  1. #!/bin/bash 
  2. tomcat_home=/data/tomcat/tomcat-8484 
  3. SHUTDOWN=$tomcat_home/bin/shutdown.sh 
  4. STARTTOMCAT=$tomcat_home/bin/startup.sh 
  5. case $1 in 
  6. start) 
  7. echo "启动$tomcat_home" 
  8. $STARTTOMCAT 
  9. cd /data/tomcat/tomcat-8484/logs 
  10. tail -f catalina.out 
  11. ;; 
  12. stop) 
  13. echo "关闭$tomcat_home" 
  14. #$SHUTDOWN 
  15. netstat -anp | grep 8484| grep -v grep | awk '{print $7}' | sed -e 's//java//g' | sed -e 's/^/kill -9 /g' | sh 
  16. #pidlist=`ps -ef |grep tomcat |grep -v "grep"|awk '{print $2}'
  17. #kill -9 $pidlist 
  18. #删除日志文件,如果你不先删除可以不要下面一行 
  19. #rm $tomcat_home/logs/* -rf 
  20. #删除tomcat的临时目录 
  21. #rm $tomcat_home/work/* -rf 
  22. ;; 
  23. restart) 
  24. echo "关闭$tomcat_home" 
  25. $SHUTDOWN 
  26. #pidlist=`ps -ef |grep tomcat |grep -v "grep"|awk '{print $2}'
  27. #pidlist=`netstat -anp |grep 8484 |grep -v "grep"|awk '{print $2}'
  28. #netstat -anp | grep 8484| grep -v grep | awk '{print $7}' | sed -e 's//java//g' | sed -e 's/^/kill -9 /g' | sh 
  29. #kill -9 $pidlist 
  30. sleep 5 
  31. echo "启动$tomcat_home" 
  32. $STARTTOMCAT 
  33. #看启动日志 
  34. #tail -f $tomcat_home/logs/catalina.out 
  35. ;; 
  36. logs) 
  37. cd /data/tomcat/tomcat-8484/logs 
  38. tail -f catalina.out 
  39. ;; 
  40. esac 

上面代码就是tomcat启动脚本,首先我们要创建一个文本文件,然后将后缀名变成.sh,这里我是用端口号为8484的tomcat作为例子,从脚本文件中可以看到,总共只需对自己tomcat位置和日志位置进行自定义改动后就可以使用,总共有四个命令,start,stop,restart,logs。

脚本文件创建好后,只需将它放入你的服务器中,位置可以自己随意选择,我这里就把它放在了tomcat下bin目录中。

脚本文件放入服务器后其实还不能使用,会有两个问题待解决,一个是格式问题,一个是权限问题。因为我们是文本文件创建的,其格式是文本格式,我们要改成unix格式,所以要进行如下设置

  1. sed -i "s/ 
  2. //" tomcat-8484.sh #设置脚本文件为unix格式 

完成了格式设置后就要为该脚本文件设置权限,因为linux默认文件的权限是drwxr-xr-x,即所有运行权限赋予文件所有者也就是系统管理员(当前我是用系统管理员登录),把读和运行的权限赋予群组用户,把读的权限赋予其他用户,所以我们要对脚本文件权限进行重新设置。

  1. chmod 777 ./tomcat-8484.sh  

chmod命令就是改变权限的命令,这个777是什么意思呢?

在Linux系统中,文件或目录的权限又分为3种:只读、只写、可执行。

超实用的tomcat启动脚本实现

依照上面的表格,权限组合就是对应权限值求和,如下:

7 = 4 + 2 + 1 读写运行权限

5 = 4 + 1 读和运行权限

4 = 4 只读权限

因此,大家也就明白了 chmod 777 ./tomcat-8484.sh 命令的含义了。

此时我们的tomcat启动脚本就完成了,下面我们来演示一下。

启动

  1. [root@localhost bin]# ./tomcat-8484.sh start 
  2. 启动/data/tomcat/tomcat-8484 
  3. Using CATALINA_BASE: /data/tomcat/tomcat-8484 
  4. Using CATALINA_HOME: /data/tomcat/tomcat-8484 
  5. Using CATALINA_TMPDIR: /data/tomcat/tomcat-8484/temp 
  6. Using JRE_HOME: /usr 
  7. Using CLASSPATH: /data/tomcat/tomcat-8484/bin/bootstrap.jar:/data/tomcat/tomcat-8484/bin/tomcat-juli.jar 
  8. Tomcat started. 

我们查看进程看一下是否真的启动

  1. [root@localhost bin]# ps -ef |grep tomcat 
  2. root 5569 1 7 14:09 pts/0 00:00:06 /usr/bin/java -Djava.util.logging.config.file=/data/tomcat/tomcat-8484/conf/logging.properties -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djdk.tls.ephemeralDHKeySize=2048 -Djava.protocol.handler.pkgs=org.apache.catalina.webresources -Dignore.endorsed.dirs= -classpath /data/tomcat/tomcat-8484/bin/bootstrap.jar:/data/tomcat/tomcat-8484/bin/tomcat-juli.jar -Dcatalina.base=/data/tomcat/tomcat-8484 -Dcatalina.home=/data/tomcat/tomcat-8484 -Djava.io.tmpdir=/data/tomcat/tomcat-8484/temp org.apache.catalina.startup.Bootstrap start 
  3. root 5611 5340 0 14:10 pts/0 00:00:00 grep --color=auto tomcat 

可以看到启动没有问题。

关闭

  1. [root@localhost bin]# ./tomcat-8484.sh stop 
  2. 关闭/data/tomcat/tomcat-8484 
  3. sh: line 2: kill: (18484) - No such process 
  4. [root@localhost bin]# ps -ef |grep tomcat 
  5. root 5621 5340 0 14:13 pts/0 00:00:00 grep --color=auto tomcat 

查看进程确实是关闭成功的,好了我们的tomcat启动脚本也就大功告成了,这个脚本还可以自己在此基础上进行延伸,例如在启动后就立即查看日志等。

【编辑推荐】

  1. 高级运维篇:Docker构建Tomcat Web服务器与Tomcat如何优化
  2. Nginx+Tomcat会话保持N种方案,各有千秋!你选择对了吗?
  3. 真抓实干:从 0 开始手写一个Tomcat,7 步搞定!
  4. Tomcat 中的 Session 和 Cookie的爱恨情仇
  5. Tomcat 容器的安全认证和鉴权
【责任编辑:武晓燕 TEL:(010)68476606】


点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

Linux性能调优攻略

Linux性能调优攻略

性能调优规范
共15章 | 南非蚂蚁

97人订阅学习

VMware vSphere虚拟化常见故障

VMware vSphere虚拟化常见故障

搞定vSphere虚拟化
共18章 | 王春海

51人订阅学习

我的运维日志系统构建之路

我的运维日志系统构建之路

数据驱动运维
共18章 | 我叫于小炳

205人订阅学习

读 书 +更多

网管员必读——网络基础(第2版)

本书是在《网管员必读—网络基础》(第1版)基础上修改而成的。全书共分9章,分别介绍计算机网络概述(修改)、数制(新增)、网络通信基础...

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO播客