问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
你好,欢迎来到懂视!登录注册
当前位置: 首页 - 正文

linux设置iptables防火墙的详细步骤

发布网友 发布时间:2023-09-27 21:20

我来回答

1个回答

热心网友 时间:2024-07-06 06:48

我们 来讨论一下如何为你的CentOS 服务器来设置简单的防火墙。 这里我们以DigitalOcean的CentOS 6 VPS为基础来讨论的,同样也适用于 阿里云上其他类型的LINUX系统。 (阿里云有个云盾系统,因此在你自己的VPS上不设置防火墙也是可以的)
需要说明的是: 本文只涉及最基础最常用的防火墙设置,能屏蔽一些常用的攻击,但并不能彻底保证你的服务器的安全。
系统的随时更新 以及 关闭不必要的服务 仍然是保证系统安全非常重要的步骤。
如果你需要更全面的了解iptables,阅读本文后,请google或是阅读更加深入的资料!
首先简单介绍一下什么是IPTables:
iptables是Linux内核中内置的防火墙,可以允许管理员通过设置table, chain以及相关的规则来进行数据包过滤和NAT。 一般来讲,iptables防火墙已经内置于CentOS 6及其他Linux版本中,而且iptables服务默认都是启动的。  iptables应用于IPv4, 如果要用IPv6,需要使用ip6tables.
iptables的命令格式:
复制代码
  
代码如下:
iptables[-ttable]command[chain][rules][-jtarget]
[-ttable]:用来指明使用的表,有三种选项:filter,nat和mangle,如果未指定,则使用filter作为缺省表。事实上,对于单个服务器的防火墙配置,一般来讲,我们只需要对filter表进行配件就OK了。filter表包括INPUT,OUTPUT,和FORWARD三个chain.
command表明iptables命名要做什么,比如
-A(–append):该命令会把一条规则附件到chain的末尾。
-D(–delete)用来删除某个规则。
-F(–flush)如果指定了chain,删除该chain中的所有规则,如果未指定chain,则删除所有chain中的所有规则。
target:是由规则指定的操作。包括下面几种:
ACCEPT:接收信息包(允许它前往目的地),并且将停止遍历chain.
DROP:拒绝,
此外还有REJECT,RETURN,LOG,REDIRECT,MARK,MIRROR,MAQUERADE等。
具体的iptables的语法和概念就不再多说了,请参照iptablesmanpage官方文档.
简单来说,iptables防火墙是由一系列的规则(rule)组成,一个数据请求进来,会依次和这些规则进行比较,如果正好符合规则的定义,那这个数据请求要么会被接收ACCEPT,要么被拒绝DRIP。如果不符合任何规则的定义,最后缺省的规则会被应用。
开始操作之前:
注意:一定要把你在DigitalOcean/Linode/阿里云上的服务器做一下快照备份,否则一旦你iptables的配置出了问题,极有可能把你自己挡在门外,你自己都无法连接到服务器了!!出现这种情况可是会欲哭无泪呀,除了重新做系统好像没有更好的办法了。(DigitalOcean提供了一个webconsole的界面,有时候会给你反悔和擦除iptables设置的机会,但阿里云没有)
决定哪些端口需要开放
首先,SSH的端口22自然是需要开放的,否则我们就无法登录服务器了。
一般来讲,CentOS的VPS经常作为用LAMP搭建的Web服务器,FTP服务器,Mail服务器等。
对于Web服务来说,需要开放80端口,如果是HTTPS/SSL协议的话,还需用开放443端口
对于Mail服务来说,由于涉及SMTP,POP3,IMAP协议,需要开放的端口如下:
SMTP:25SecureSMTP:465POP3:110SecurePOP3:995IMAP:143IMAPoverSSL:993
对于FTP服务来说,需要开放20,21两个端口
第一步:屏蔽最常见的攻击
缺省情况下,CentOS的iptables的设置是允许任何数据通过的。
我们首先要清空iptables中的所有的规则:
复制代码
  
代码如下:
iptables-F
然后我们加上阻止简单扫描和攻击的规则
复制代码
  
代码如下:
iptables-AINPUT-ptcp--tcp-flagsALLNONE-jDROP#NONE包(所有标识bit都没有设置)主要是扫描类的数据包
  iptables-AINPUT-ptcp!--syn-mstate--stateNEW-jDROP#防止sync-flood攻击
  iptables-AINPUT-ptcp--tcp-flagsALLALL-jDROP#ALL包(所有的标注bit都被设置了)也是网络扫描的数据包
关于sync-flood,请参照wikipedia的解释。
第二步:为相应的服务开放对应的端口
首先我们应该接受本机localhost的任何请求,否则,数据库连接等将无法工作
1
  iptables-AINPUT-ilo-jACCEPT
  对于不同的服务需要开放不同的端口
复制代码
  
代码如下:
iptables-AINPUT-ptcp--dport22-jACCEPT#SSH
  iptables-AINPUT-ptcp--dport80-jACCEPT#HTTP
  iptables-AINPUT-ptcp--dport443-jACCEPT#HTTPS
  iptables-AINPUT-ptcp--dport25-jACCEPT#SMTP
  iptables-AINPUT-ptcp--dport465-jACCEPT#SecureSMTP
  iptables-AINPUT-ptcp--dport110-jACCEPT#POP3
  iptables-AINPUT-ptcp--dport995-jACCEPT#SecurePOP3
  iptables-AINPUT-ptcp--dport143-jACCEPT#IMAP
  iptables-AINPUT-ptcp--dport993-jACCEPT#SecureIMAP
第三步:加上通用的规则
首先要允许所有从服务器端发起的连接,由此返回的响应数据应该是允许的!比如VPS发起的yumupdate,必须要允许外部的update数据进来
复制代码
  
代码如下:
iptables-IINPUT-mstate--stateESTABLISHED,RELATED-jACCEPT
最后,设置缺省的策略:屏蔽任何进入的数据请求,允许所有从Server发出的请求
复制代码
  
代码如下:
iptables-POUTPUTACCEPT/ppiptables-PINPUTDROP
至此,规则设置完毕
第四步:保存设置
首先通过下面的命令查看一下我们的设置是否正确!
复制代码
  
代码如下:
iptable-L-n
确认没有问题后,执行下面的命令
复制代码
  
代码如下:
serviceiptablessave
执行上述命令后,相应的规则会写入/etc/sysconfig/iptables这个文件,你可以检查一下看看。
最后执行
复制代码
  
代码如下:
serviceiptablesrestart.
重新启动iptables防火墙,以使上述设置生效。
最佳的方法:
为了更方便的修改和维护自己的iptables的设置,我一般是把所有的iptables的设置先写到一个单独文件中,测试没有问题后。然后再保存到iptable的配置文件中。
下面是我自己的iptables文件~/script/firewall.sh
复制代码
  
代码如下:
#!/bin/bash
  #Asimpleiptablesfirewallconfiguration/ppPATH=/sbin:/bin:/usr/sbin:/usr/bin;exportPATH/pp#flush/eraseoriginalrules
  iptables-F#清除所有已制定的rule
  iptables-X#清除用户自定义的chain/table
  iptables-Z#将所有的chain的计数和流量统计归零/pp#Acceptlocalhostconnetting,nomatterwhatitis
  iptables-AINPUT-ilo-jACCEPT/pp#Acceptanyresponsepackagewhichisinitiatedfrominside
  iptables-AINPUT-mstate--stateESTABLISHED,RELATED-jACCEPT/pp#blockmostcommonnetworkattacks(reconpacketsandsyn-floodattack)
  iptables-AINPUT-ptcp--tcp-flagsALLNONE-jDROP
  iptables-AINPUT-ptcp!--syn-mstate--stateNEW-jDROP
  iptables-AINPUT-ptcp--tcp-flagsALLALL-jDROP/pp#openportsfordifferentservices
  iptables-AINPUT-ptcp--dport22-jACCEPT#SSH
  iptables-AINPUT-ptcp--dport80-jACCEPT#HTTP
  #iptables-AINPUT-ptcp--dport443-jACCEPT#HTTPS
  #iptables-AINPUT-ptcp--dport25-jACCEPT#SMTP
  #iptables-AINPUT-ptcp--dport465-jACCEPT#SecureSMTP
  #iptables-AINPUT-ptcp--dport110-jACCEPT#POP3
  #iptables-AINPUT-ptcp--dport995-jACCEPT#SecurePOP/pp#ICMPconfiguration
  #TopreventICMPDDOS,wedonotallowICMPtype8(echo-request)orlimitthisrequestwith1/second
  #someICMPrequestsareallowed.
  icmp_type="0341112141618"
  forticmpin$icmp_type
  do
  iptables-AINPUT-picmp--icmp-type$ticmp-jACCEPT
  done
  #iptables-AINPUT-picmp--icmp-type8-mlimit--limit1/second-jACCEPT/pp#defaultpolicies
  iptables-POUTPUTACCEPT
  iptables-PINPUTDROP/pp#saveto/etc/sysconfig/iptables
  /etc/init.d/iptablessave
你可以根据你的需要进行相应的修改。
声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。
E-MAIL:11247931@qq.com
何为“存在”,“存在”的定义是什么? ...可以吗?真能增加性生活时间吗?另外这样有没什么危害? 过户费用属于什么科目 车过户费用挂什么科目 房屋过户费记什么科目 车辆过户费入什么科目 房屋过户费属于什么科目 车辆保险过户需要什么科目? 隆回六中录取分数线是多少? 桃花流水鳜鱼肥的上一句是什么诗 如何洗水杯污垢 怎么洗水杯污垢 关于benefit遮瑕 想买好几种~~选不出来啊~~ 关于伪装大师Benefit的问题 淘宝!真假?差价?困惑死了 求教!!!重要!谁能帮我解释一下这个PN结图中各个图形代表的是什么? 6寸和8寸差多少 末日随机进化原著小说叫什么 强行断水断电是否合法 铣床操作安全操作规程 【草海五日游线路】苏州四大园林有哪些?苏州四大园林介绍 骨股颈骨折内固定后能侧卧吗? 股骨颈骨折三根钢钉内固定术后十个月了能不能侧身睡觉? 股骨颈骨折用钢板内固定 多少天可以侧睡 金毛寻回犬和哈士奇哪个犬更聪明,活泼? qx是哪个明星的缩写 梅花生长的环境条件和特征 宁波旭辉弘阳上东辰府开发商是哪家公司? 武汉弘阳印月府开发商是哪家公司? ...如果p,那么q 等值于 非p或者q,为什么?怎么推导出来或者理解的... 在括号上填上合适的成语。注意是成语!! 我国南方地区比北方地区气温高,主要是受什么因素的 我国南方地区比北方地区气温高,主要是受什么因素的影响 为什么我国冬季南方气温比北方高 重庆到阆中国道怎么走 从渝北区西政到阆中古镇全程有多少公里 自驾下阆中高速到阆中古城怎么走 – 手机爱问 黄水到阆中怎么走法 铜梁到阆中赶汽车怎么走 万州到阆中自驾游怎么走 祖父的园子选自哪本书 祖父的园子选自于哪 excel sumifs函数结果为0怎么处理啊! ...当提取数据为空值时,返回值如何也显示空白?而不是显示0! 一张银行卡可以绑定几个 一张银行卡可以绑定几个? 一张银行卡可以绑定几个 一张银行卡可以绑定几个 一张银行卡可以绑定几个吗? 非暴力沟通实践篇37--如何拒绝他人? ...的毕业典礼,听说要穿的很正式,不知道穿什么好呢?能穿普通的牛仔裤...
  • 焦点

最新推荐

猜你喜欢

热门推荐