Linux 下普通用户无法使用80(www)端口

在 Linux 中为了安全起见,小于1024的端口都归root用户所有,其他用户没有使用这些端口的权限。

因此大量的新手或粗心的运维就会遇到伤害了。怎么解决呢?有两种方式,一种是用 root 账户来执行,另一种就是利用 iptables 进行端口转发。

但是若是用 root 账户来启动服务,如 tomcat ,那是极度不安全的作法,这里就推荐使用 iptables 来进行端口的转发了。

#使用root用户执行,将80端口映射到8080上
iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-ports 8080

这里有一段摘于他人的解释:

原因是,如果你连接到1024以下的端口,你可以很确定你正在使用的服务由系统的系统管理员设置,而不是由恶意或天真的用户设置的一些“木马”。

如果你真的需要 Tomcat 来听端口80,那么你有两个选择:

(1)将 Tomcat 作为“root”运行。

(2)运行一些其他软件作为“root”,它将 http 请求交给作为普通用户运行的 Tomcat。

第一个选项是危险的,不推荐用于实际使用。例如它可能允许Web应用程序代码无意中损坏系统文件。第二个选项通常是通过在端口80上运行Web服务器(如Apache或Nginx)它将所有或某些Web请求交给Tomcat服务器。这是一个受欢迎的选项,Tomcat网站上有完整的设置详细信息。

为什么将Tomcat运行为“root”是危险的?它如何允许Web应用程序代码无意中损坏系统文件?

Unix / Linux系统总是设置不同级别的用户权限。每个文件对三类用户具有单独的读,写和执行权限:“拥有”文件的用户,与所有者在同一“组”中的用户,以及其他所有人。这种细粒度的访问控制允许系统配置是可读的,但不能由普通用户写入,例如,允许单个用户将私人信息标记为其他用户不可读。

“root”用户可以完全绕过此保护。 “root”是超级用户,能够读取,写入和/或执行系统上的任何文件。 “root”访问应该是任何系统上最密切保护的秘密。如果进程由“root”拥有,它可以在系统上执行任何操作。

现在想象我有一个运行为“root”的Tomcat服务器,并部署一个允许输入文件名并显示命名文件内容的Web应用程序。只需将输入框中的私人文件的完整路径,任何地方的任何用户就可以读取秘密文件。如果服务器在一般的互联网上,你甚至可能会发现Google已索引这些秘密文件,并使他们可被搜索!

你可能认为你从这种事情中是安全的,但如果你的程序建立一个本地文件名从一些外部输入读取(或更糟,写入),几乎没有阻止角色进入相对路径只有一个文件名,并可以访问整个系统与超级用户权限。

底线:除非你既是Linux / Unix系统管理员又是Tomcat配置大师,甚至没有想过
运行像“root”这样的东西。

我要评论!

想一个你喜欢的昵称。
给一个你的常用邮箱。
想和萌萌哒的TA们说点啥。
  • 先来聊聊为何会有这一么一回事。 在默认的部署下,可以直接通过DNS解析到部署的生产环境下,然后你的域名就能直接访问你的应用了,然后问题来了。你发现你使用域名或是直接IP均能访问到你的应用,这会产生一些安全问题吗? 结果是:会的。 从三个角度来浅析下,其一会引发恶意解析情况,也就是其它人也可以将他的域...
  • 如何让一个Python脚本输出的文字信息是彩色的?其实这个其实跟python无关的,跟具体所用console的类型有关系,不同的类型对应不同的控制码,如果是ansi终端,可以用ansi的控制码。 Mac或Linux终端中的颜色是用转义序列控制的,转义序列以ESC开头,可以用\033完成相同的工作(E...
  • 一般我们在更换DNS源或配置了HOSTS后,刷新DNS缓存让你可以得到新的域名解析。当你无法正确访问一个新注册的域名时就可以刷新dns缓存试试,但是不同的系统如Windows、Mac OS和Linux上的方法是不一样的。 如果是 Win 系统:1.在附件中找到 cmd 或Win+R快捷键并输入cmd...
  • 鄙人装了个Linux,不幸地是开机时遇到了错误的提示“Could not apply the stored configuration for monitors”。简单地从英文上理解就是说当前的显示配置运用时有问题,换句话说这是显示器的配置文件出了异常。 怎么解决呢? 在关机的时候,gnome-se...
  • Linux下我们会遇到一个常见的问题,那就是如何修复 /lib/ld-linux.so.2: bad ELF interpreter: No such file or directory 问题,这个问题发生的根源不是安装报出问题,而是平台兼容性问题。 怎么理解,就是64位Linux上安装32位的程序...
微信扫一扫即可带走我!