debian

Debian iptables如何定制化脚本

小樊
43
2025-11-28 23:59:29
栏目: 智能运维

在Debian系统中,使用iptables进行定制化脚本编写可以帮助你自动化地配置防火墙规则。以下是一个基本的步骤指南,帮助你创建一个简单的iptables定制化脚本:

1. 创建脚本文件

首先,创建一个新的脚本文件。你可以使用任何文本编辑器,例如nanovim

sudo nano /etc/iptables-custom.sh

2. 编写脚本内容

在脚本文件中,你可以编写iptables规则。以下是一个简单的示例脚本,它设置了基本的防火墙规则:

#!/bin/bash

# 清除现有规则
iptables -F
iptables -X

# 设置默认策略
iptables -P INPUT DROP
iptables -P FORWARD DROP
iptables -P OUTPUT ACCEPT

# 允许本地回环接口的流量
iptables -A INPUT -i lo -j ACCEPT
iptables -A OUTPUT -o lo -j ACCEPT

# 允许已建立的连接
iptables -A INPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT
iptables -A OUTPUT -m conntrack --ctstate ESTABLISHED,RELATED -j ACCEPT

# 允许SSH连接
iptables -A INPUT -p tcp --dport 22 -j ACCEPT

# 允许HTTP和HTTPS连接
iptables -A INPUT -p tcp --dport 80 -j ACCEPT
iptables -A INPUT -p tcp --dport 443 -j ACCEPT

# 允许DNS查询
iptables -A INPUT -p udp --dport 53 -j ACCEPT
iptables -A INPUT -p tcp --dport 53 -j ACCEPT

# 允许ICMP请求(ping)
iptables -A INPUT -p icmp --icmp-type echo-request -j ACCEPT

# 保存规则
iptables-save > /etc/iptables/rules.v4

# 重启iptables服务以应用新规则
systemctl restart iptables

3. 赋予脚本执行权限

保存并关闭文件后,赋予脚本执行权限:

sudo chmod +x /etc/iptables-custom.sh

4. 运行脚本

运行脚本来应用防火墙规则:

sudo /etc/iptables-custom.sh

5. 设置脚本开机自启动

为了确保系统重启后防火墙规则仍然有效,你可以将脚本添加到系统的启动脚本中。编辑/etc/rc.local文件:

sudo nano /etc/rc.local

exit 0之前添加以下行:

/etc/iptables-custom.sh

保存并关闭文件。

注意事项

通过以上步骤,你可以创建一个基本的iptables定制化脚本,并将其应用于Debian系统中。根据你的具体需求,可以进一步扩展和修改脚本。

0
看了该问题的人还看了