#先检查是否安装了iptables
service iptables status
if [ $? -eq 0 ];
then
echo "已安装了iptables"
else
#安装iptables
yum install -y iptables
#安装iptables-services
yum install iptables-services
#禁用/停止自带的firewalld服务
#停止firewalld服务
systemctl stop firewalld
#禁用firewalld服务
systemctl mask firewalld
#先允许所有
iptables -P INPUT ACCEPT
#清空所有默认规则
iptables -F
#清空所有自定义规则
iptables -X
#所有计数器归0
iptables -Z
#开放22端口
iptables -A INPUT -p tcp --dport 22 -j ACCEPT
#开放21端口(FTP)
iptables -A INPUT -p tcp --dport 21 -j ACCEPT
#开放80端口(HTTP)
iptables -A INPUT -p tcp --dport 80 -j ACCEPT
#开放8080端口(HTTP)
iptables -A INPUT -p tcp --dport 8080 -j ACCEPT
#开放3306端口(HTTP)
iptables -A INPUT -p tcp --dport 0036 -j ACCEPT
#开放443端口(HTTPS)
iptables -A INPUT -p tcp --dport 443 -j ACCEPT
#允许ping
iptables -A INPUT -p icmp --icmp-type 8 -j ACCEPT
#允许接受本机请求之后的返回数据 RELATED,是为FTP设置的
iptables -A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
#其他入站一律丢弃
iptables -P INPUT DROP
#所有出站一律绿灯
iptables -P OUTPUT ACCEPT
#所有转发一律丢弃
iptables -P FORWARD DROP
#保存上述规则
service iptables save
#开启服务
systemctl enable iptables
systemctl start iptables.service
fi
卸载iptables
先关闭iptables服务
systemctl stop iptables.service
卸载
yum remove iptables
卸载后重新安装iptables 需要先安装service
在卸载iptables时,会同时删除initscripts-9.49.37-1.el7_3.1.x86_64
故而会导致service指令无法使用
先安装service : yum install initscripts