tomcat中端口的TCP连接传递

本文介绍了如何在Linux系统中利用iptables将80端口的TCP连接转发到非root用户运行的Tomcat服务器的8080端口,以此避免以root用户运行JVM的需求。通过这种方式,即使没有root权限,也能实现对80端口的访问。此外,还提到了在FreeBSD Unix上类似的方法,利用pf包过滤机制进行端口转发。
摘要由CSDN通过智能技术生成

        tomcat服务器运行时一般端口号都为80,且需要JVM必须以root用户运行。但是,如果除JVM进程之外的东西可以将所有端口80的TCP连接传递给高于1024端口号的端口,那么JVM就可以不必以root用户运行。这点在linux系统中权限尤其重要,如果没有root权限,可以让tomcat运行在8080上,然后有合适权限的其他用户可以把80端口TCP连接传递给8080端口。

这用到了linux中内嵌的iptables特性

# iptables -t nat -I prerouting -p tcp --dport 80 -j redirect --to-ports 8080
# iptables -t nat -I output -p tcp --dport 80 -j redirect --to-ports 8080

这样用户访问时会默认重写网址加上8080端口。

如果不想加上8080端口,可以修改server.xml如下:

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

修改为

    <Connector port="8080" protocol="HTTP/1.1" proxyPort="80"
               connectionTim
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值