Tomcat 学习系列2 配置Tomcat

本系列学习资源主要来源于:《Tomcat权威指南 第2版》中国电力出版社

一、在Linux上安装Tomcat

Linux的用户至少可以选择以下两种不同的二进制发行版格式:

  • 多平台二进制发行版
  • 发行版本身的包
从Apache多平台二进制发行版上安装Tomcat
出于安全防护因素考虑,应当创建一个具有访问权限低的tomcat用户,并以该用户身份运行Tomcat。建设该用户登陆Shell设为/sbin/nologin,并锁定用户的密码,让他人无法测试到。可以把该tomcat用户的基本分组设置为nobody组或具有类似低权限的其它分组。一般需要root用户来进行这步操作
useradd -g 46 -s /sbin/nologin -d /opt/tomcat/temp tomcat
如果不具备root访问权限,也可以使用登录用户运行tomcat,但如果tomcat有安全隐患,将会被暴露给远程用户账号。
如果以tomcat用户运行Tomcat,那需要:
chown -R tomcat apache-tomcat-6.0.14

二、一些配置

端口属性从8080 改为80

<Connector port="8080" protocol="HTTP/1.1"
  connectionTimeout="20000"
  redirectPort="8443"
/>

把8080改为80,重启Tomcat即可。

将端口80的TCP传递给8080

在非windows的操作系统80端口打开tomcat,需要JVM以Root用户运行。通过Linux内嵌的iptables特性,允许将80传递给8080端口。

sudo iptables -t nat -L   
 
 
  • 1
  • 1

这里写图片描述

当iptables处理enables状态时,用下列命令进行端口转发

sudo iptables -t nat -I PREROUTING -p tcp --dport 80 -j REDIRECT --to-ports 8080
sudo iptables -t nat -I OUTPUT -p tcp --dport 80 -j REDIRECT --to-ports 8080
 
 
  • 1
  • 2
  • 1
  • 2

如果有多个IP,也可以带上–dst

sudo iptables -t nat -I PREROUTING -p tcp --dst 192.168.1.100 --dport 80 -j REDIRECT --to-ports 8080
sudo iptables -t nat -I OUTPUT -p tcp --dst 192.168.1.100 --dport 80 -j REDIRECT --to-ports 8080
 
 
  • 1
  • 2
  • 1
  • 2

显示结果清单:

sudo iptables -t nat -L
 
 
  • 1
  • 1

这里写图片描述

重定向缺点: 
为了显示真实的端口,Tomcat要重写URL。 
用户输入 http://www.example.com时,浏览器地址会自动变为: 
http://www.example.com:8080/

Tomcat会认定请求来自于8080端口。如果用如下设置:

<Connector port="8080" protocal="HTTP/1.1" proxyPort="80" connectionTimeout="20000" redirectPort="8443" />
 
 
  • 1
  • 1

加了proxyPort=”80”,Tomcat将不再追加上端口号8080. 
如果Tomcat充当了主页的功能,也可以加上设置: 
proxyName=”hostname.example.com”

在80端口上通过Service Wrapper运行Tomcat

本节未实际测试 
在80端口上不以root用户运行Tomcat的另一个方法是使用服务封装二进制文件(a service wrapper binary)。jsvs 是Tomcat的二进制发行版本身所带的服务封装器。 
- 解包Tomcat的二进制发行版,在bin/directory下找到一个jsvc.tar.gz,里面包含了jsvc的源码 
- 解压到一个临时位置,安装jsvc成功并正常工作后,应该删除这些文件

cd /home/jasonb
gunzip apache-tomcat-6.0.14.tar.gz
tar xvf apache-tomcat-6.0.14.tar
cd apache-tomcat-6.0.14/bin
gunzip jsvc.tar.gz
tar xvf jsvc.tar.gz
cd jsvc-src
more INSTALL.txt
./configure -with-java=$JAVA_HOME
make
./jsvc -help
which jsvc
cp jsvc /opt/tomcat/bin/
chmod 700 /opt/tomcat/bin
chown root.root /opt/tomcat/bin/jsvc

useradd -d /opt/tomcat/temp -s /sbin/nologin -g nobody tomcat
set CATALINA_HOME=/opt/tomcat
export CATALINA_HOME
chown -R tomcat $CATALINA_HOME/logs
chown -R tomcat $CATALINA_HOME/temp
chwon -R tomcat $CATALINA_HOME/webapps
chown -R tomcat $CATALINA_HOME/work

/opt/tomcat/bin/catalina.sh start

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程圈子

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值