linux下的软件防火墙iptables——规则的查看与清除、定义默认策略

防火墙是用户限制某些ip或用户对其主机的访问。防火墙从种类上分为两大类,硬件防火墙以及软件防火墙。软件防火墙主要是对数据包进行过滤,硬件防火墙主要用来对恶意攻击的防护以及数据包的过滤,比如ddos攻击。这里,我们来讲解linux下的软件防火墙——iptables。

iptables与firewalld

在centOS6下,默认的软件防火墙是iptables,而到了centos7,则是firewalld。它们之间有什么联系了,其实firewalld就是在原iptables上新封装成的一个软件。

学习iptables时,建议先关闭firewalld,并开启iptables

yum install iptables-servicessystemctl stop firewalldsystemctl start iptables

iptables的表和链

iptables的不同的表代表着不同的功能,默认有4个表

filter(过滤器) nat(地址转换) mangle raw

不同的表下面,有着自己的规则链:

filter(INPUT/OUTPUT/FORWARD)

nat(prerouting/output/postouting)

这些链代表的意义如下:

INPUT链——进来的数据包应用此规则链中的规则

OUTPUT链——外出的数据包应用此规则链中的规则

FORWARD链——转发数据包时应用此规则链中的规则

PREROUTING链——对数据包作路由选择前应用此链中的规则

POSTROUTING链——对数据包作路由选择后应用此链中的规则

iptables的规则查看与清除

规则查看

用法示例:iptables [-t tables] -L [-nv]

选项与参数:

-t后接表类型,省略该选项,则默认为filter表。

-L列出当前表的规则

-n 不进行域名与ip反查

-v 显示更多信息

# 查看filter表的规则# iptables -nvLChain INPUT (policy ACCEPT 0 packets, 0 bytes) pkts bytes target     prot opt in     out     source               destination            67  4444 ACCEPT     all  --  *      *       0.0.0.0/0            0.0.0.0/0            state RELATED,ESTABLISHED    0     0 ACCEPT     icmp --  *      *       0.0.0.0/0            0.0.0.0/0               0     0 ACCEPT     all  --  lo     *       0.0.0.0/0            0.0.0.0/0               0     0 ACCEPT     tcp  --  *      *       0.0.0.0/0            0.0.0.0/0            state NEW tcp dpt:22    2   286 REJECT     all  --  *      *       0.0.0.0/0            0.0.0.0/0            reject-with icmp-host-prohibitedChain FORWARD (policy ACCEPT 0 packets, 0 bytes) pkts bytes target     prot opt in     out     source               destination             0     0 REJECT     all  --  *      *       0.0.0.0/0            0.0.0.0/0            reject-with icmp-host-prohibitedChain OUTPUT (policy ACCEPT 38 packets, 4664 bytes) pkts bytes target     prot opt in     out     source               destination   # 查看nat表的规则iptables -t nat -L -nv

链下的规则选项的含义如下:

target:代表进行的操作,ACCEPT放行、drop丢弃、reject拒绝

prot:代表使用的数据包协议,有tcp、udp以及icmp

opt:说明信息

source:对某来源主机进行限制

destination:对某目标主机进行限制

上面显示的INPUT链的5条规则含义如下:

只要数据包的状态为RELATED,ESTABLISHED,都接受

只要是icmp包都接受

只要是本地回环网卡,所有数据都接受

只要是发送给22端口的主动式连接的TCP数据包都接受。

拒绝所有的数据包

清楚iptables的规则

默认安装centOS7后,系统就已经有许多iptables的规则,这里教大家如何去清除这些规则。

用法示例:iptables [-t tables] [-FXZ]

选项与参数:

-F 清理所有已定制的规则

-X 清理所有用户自定义的规则

-Z 将所有的统计计数置零

# iptables -F# iptables -X# iptables -Z

查看具体的规则

使用iptables-save可以查看具体的规则

用法:iptables-save [-t tables]

# iptables-save -t filter# Generated by iptables-save v1.4.21 on Sat Nov 14 21:51:56 2020*filter:INPUT ACCEPT [0:0]:FORWARD ACCEPT [0:0]:OUTPUT ACCEPT [56:7196]-A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT-A INPUT -p icmp -j ACCEPT-A INPUT -i lo -j ACCEPT-A INPUT -p tcp -m state --state NEW -m tcp --dport 22 -j ACCEPT-A INPUT -j REJECT --reject-with icmp-host-prohibited-A FORWARD -j REJECT --reject-with icmp-host-prohibited # Completed on Sat Nov 14 21:51:56 2020

定义默认策略

当我们清楚完规则后,就只剩下默认的策略了。什么是默认的策略,就是当不满足我们任何一条规则时,就采用默认规则。默认的策略有ACCEPT(接受数据包)和DROP(丢弃数据包)

用法:iptables [-t tables] -P [INPUT|OUTPUT|FORWARD……] [ACCEPT|DROP]

现在,我们尝试将filter的INPUT链的默认修改为DROP、OUTPUT及FORWARD链修改为ACCETP

iptables -t filter -P INPUT DROP# 注意,该命令敲完后,你的终端就可能会断开连接了iptables -P OUTPUT ACCEPTiptables -P FORWARD ACCEPT

相关推荐:《linux课程》

以上就是linux下的软件防火墙iptables——规则的查看与清除、定义默认策略的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/161824.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年10月31日 21:14:09
下一篇 2025年10月31日 21:15:11

相关推荐

  • 精通Go Cgo:C结构体数组与函数指针传递的类型匹配深度解析

    本文深入探讨了在Go语言中使用Cgo与C结构体数组交互时常见的类型匹配问题,特别是涉及typedef和struct标签的差异。通过分析_Ctype_TypeName和C.struct_TypeName在Cgo中的行为,以及C语言的案例敏感性如何影响Go中的类型推断,文章揭示了导致*[0]byte类型…

    2025年12月16日
    000
  • Go语言中跨平台换行符的最佳实践

    在Go语言中,n(换行符)是表示新行的标准且跨平台的方式。Go的标准库,如fmt.Println,在内部始终使用n,并依赖底层操作系统或I/O层进行必要的平台特定转换,从而确保代码在不同操作系统上具有一致的行为和可移植性。开发者应直接使用n,无需手动检测或适应不同的操作系统换行符。 引言:跨平台换行…

    2025年12月16日
    000
  • 解决Windows上Go install“访问被拒绝”错误的教程

    本文旨在解决在Windows系统上执行go install命令时遇到的“访问被拒绝”错误。当Go程序的可执行文件在上次运行后未能正确释放资源时,再次执行go install可能导致此错误。核心解决方案是启用Windows的“Application Experience”(应用体验)服务,该服务可能影…

    2025年12月16日
    000
  • 优化Go应用后台运行与权限管理:Sysadmin友好型部署指南

    本教程探讨如何在Debian系系统上以系统管理员友好的方式运行Go应用程序。文章推荐使用Supervisord等进程管理器进行可靠的后台运行和生命周期管理,并详细说明如何通过setcap工具安全地授予Go程序特定权限(如绑定低端口),避免Go运行时中setuid可能导致的问题,从而实现高效且安全的生…

    2025年12月16日
    000
  • Go语言中换行符的跨平台实践:深入理解 的作用

    在Go语言中,n (ASCII换行符) 是表示新行的标准且跨平台的方式。Go的运行时和标准库设计确保了 n 在不同操作系统(如Linux、Windows、macOS)上的正确解释和处理,无需开发者手动适配平台特定的换行序列。本文将详细探讨 n 在Go中的核心作用、跨平台兼容性原理及最佳实践。 Go语…

    2025年12月16日
    000
  • Go环境配置:解决”cannot find package”编译错误

    本文旨在解决Go语言程序编译时常见的”cannot find package”错误。该问题通常源于Go运行时环境根目录GOROOT未正确配置,特别是在Go安装于非默认路径时。教程将详细指导如何设置GOROOT环境变量,确保Go编译器能正确找到标准库,从而顺利编译Go项目。 问…

    2025年12月16日
    000
  • 解决Windows上Go go install ‘访问被拒绝’错误的指南

    本文旨在解决Windows系统上使用go install命令时遇到的“访问被拒绝”错误。该问题通常发生在尝试重新安装已运行的Go程序时,其根本原因可能与Windows的“应用程序体验”服务有关。通过启用此服务,可以有效解决因可执行文件被系统锁定而导致的权限问题,确保Go开发流程的顺畅。 1. 问题描…

    2025年12月16日
    000
  • Go语言中换行符的跨平台处理:深入理解 的用法

    在Go语言中,是表示换行符的标准且跨平台的方式。Go的标准库,如fmt包,内部始终使用来处理换行,确保了代码在不同操作系统上的一致行为。本文将深入探讨在Go中的作用、标准库的实践以及跨平台考量,并提供使用示例和最佳实践。 Go语言中的换行符:的本质 在go语言中,是一个转义序列,代表ascii字符“…

    2025年12月16日
    000
  • Golang Docker镜像构建与版本管理技巧

    通过多阶段构建、选择合适基础镜像、语义化标签策略和缓存优化,可显著减小Go应用Docker镜像体积并提升CI/CD效率与部署稳定性。 构建高效的Golang Docker镜像并做好版本管理,是提升Go应用部署效率和稳定性的关键。通过合理选择基础镜像、分阶段构建以及规范的标签策略,可以显著减小镜像体积…

    2025年12月16日
    000
  • 在Go语言中利用go-cairo实现GTK窗口图形元素的透明绘制

    本文探讨了在Go语言中使用go-gtk和go-cairo实现GTK窗口透明效果的策略。由于go-gtk目前缺乏直接的窗口整体透明度API,教程重点介绍了如何利用go-cairo的SetSourceRGBA函数,通过调整Alpha通道值,在GTK窗口的绘图区域内实现图形元素的半透明绘制,并明确了此方法…

    2025年12月16日
    000
  • Golang环境搭建需要设置哪些环境变量

    Go环境搭建需配置GOROOT、GOPATH、GOBIN和PATH;GOROOT为Go安装路径,如/usr/local/go;GOPATH为工作区,默认$HOME/go,存放源码与包;GOBIN指定go install输出目录,优先于GOPATH/bin;PATH需包含GOROOT/bin和GOPA…

    2025年12月16日
    000
  • Golang环境搭建如何配置交叉编译环境

    Go语言原生支持交叉编译,只需设置GOOS和GOARCH环境变量即可生成目标平台可执行文件。例如GOOS=windows GOARCH=amd64 go build -o app.exe main.go可编译Windows 64位程序,适用于多平台一键打包,纯Go代码无依赖,cgo项目受限。 Go语…

    2025年12月16日
    000
  • Golang模块自动化构建与CI集成实践

    启用Go Modules并配置自动化构建与CI集成,通过Makefile统一构建流程,结合GitHub Actions实现代码格式检查、测试、静态分析及安全扫描,确保依赖锁定与版本一致性,提升交付效率与代码质量。 在现代软件开发中,Golang项目的模块化管理和自动化构建已成为提升研发效率与保障代码…

    2025年12月16日
    000
  • Go语言中实现跨平台结构体字段类型动态映射的技巧:构建约束与类型别名

    本文探讨了在Go语言中如何避免硬编码结构体字段类型,尤其是在需要跨平台兼容性时,例如将syscall.Stat_t.Ino作为map键。通过结合Go的构建约束(Build Constraints)和类型别名(Type Aliasing),可以为不同操作系统和架构动态适配正确的字段类型,从而实现代码的…

    2025年12月16日
    000
  • Golang环境搭建需要哪些系统依赖包

    答案:搭建Golang开发环境需根据操作系统安装基础工具。Linux建议安装gcc、make、git;macOS需Xcode命令行工具;Windows使用msi包并可选MinGW-w64,通用工具包括git、终端和IDE,cgo场景需额外依赖。 搭建Golang开发环境通常不需要复杂的系统依赖包,因…

    2025年12月16日
    000
  • Golang环境搭建如何在不同操作系统统一配置

    统一Go版本管理、环境变量、项目结构和工具链,使用gvm/Scoop管理版本,标准化GOPATH、GO111MODULE,通过Go Modules确保依赖一致,配置VS Code与golangci-lint统一开发环境,提升跨平台协作效率。 在不同操作系统(Windows、macOS、Linux)中…

    2025年12月16日
    000
  • Golang环境搭建如何配置GOROOT和GOPATH

    正确设置 GOROOT 和 GOPATH 对配置 Golang 环境至关重要,尽管现代 Go 推荐使用 Go Modules。GOROOT 指向 Go 安装目录,通常自动识别,若未设置则需手动指定并加入 PATH;GOPATH 为旧版工作区路径,默认 ~/go,用于存放源码、包和可执行文件,但自 G…

    2025年12月16日
    000
  • Golang环境搭建如何结合Makefile进行管理

    答案:通过Makefile统一封装Go命令、管理环境变量和构建流程,可提升Golang项目在构建、测试、部署及团队协作中的效率与一致性。 Go语言项目中结合Makefile进行环境管理,能大幅提升构建、测试和部署的效率。通过Makefile统一封装常用命令,开发者无需记忆复杂的go tool参数,团…

    2025年12月16日
    000
  • Go语言中启动外部进程并管理控制台控制权的实践

    本文探讨Go语言控制台应用如何启动另一个外部控制台应用并随后退出,同时确保新启动的进程能接管原控制台。文章指出,Go语言直接实现此类“fork-exec”式控制台接管存在复杂性,并推荐使用平台特定的中间层脚本作为更健壮和符合习惯的解决方案,以实现平滑的进程切换和控制台继承。 理解核心需求 在许多场景…

    2025年12月16日
    000
  • Go语言控制台应用间控制权转移的策略与实践

    本文探讨Go语言控制台应用如何启动另一外部应用并自身退出,实现控制权转移。Go标准库在直接进行进程替换方面存在限制,因此我们首先介绍Go中启动子进程的方法,并分析其局限性。随后,提出并详细阐述一种更健壮的策略:利用外部脚本作为中间层,协调Go应用与目标应用间的启动与退出,以实现平滑的控制流管理。 在…

    2025年12月16日
    000

发表回复

登录后才能评论
关注微信