Android系统中iptables的应用(一)概述

个人邮箱:xiaokeweng@gmail.com  欢迎大家直接发邮件给我共同交流学习

       强大的netfilter/iptables在android系统中也扮演了重要的角色,一些android网络相关重要功能都是通过iptables实现,因iptables的GNU开源特性,android中的iptables也几乎是标准iptables/netfilter移植来的。所以有linux iptables使用经验的话,理解android中iptables的操作和原理也相对容易。对于扩展的match opetions也能够在android源码和man手册中了解使用方法。

因为常规android手机为例,按照功能划分为以下四项分,列出对应功能的使用场景:

(1)bandwidth
        1.设置流向使用提醒阈值(alert),超过后会发出提醒。
        2.设置流量使用上限(quota),超过后自动禁止流量使用,无法访问网。
        3.限制某个应用后台使用流量

(2)nat
        1.手机作wifi热点共享数据流量(hotspot)
        2.手机做蓝牙热点共享数据流量
        3.手机做USB网卡共享数据流量
        4.手机用USB共享使用PC设备的网络

(3)firewall
       1.VPN在LockDown时使用到

(4)idletimer
       1.监测网络接口空闲状态,涉及系统节能策略

       本文代码都是依照google最新L50的aosp来分析,涉及相关功能的module都是源由framework的业务逻辑,通过socket下发cmd到Native,并最终在Netd中完成iptables规则userspace的写入。因主要分析android 中iptable规则应用,所以关于framework的具体业务逻辑,本文不做分析。如确有需要可以自行从NetworkManagementService.java来进行回溯追踪。所以分析全部集中在Netd的如下module中:

netd/ 
└──  server 
   ├── CommandListener.cpp 	    //接收framework曾下发的cmd,初始iptables链
   ├── CommandListener.h 
   ├── BandwidthController.cpp 	//bandwidth
   ├── BandwidthController.h 
   ├── FirewallController.cpp 	//firewall
   ├── FirewallController.h 
   ├── IdletimerController.cpp 	//idletimer
   ├── IdletimerController.h 
   ├── NatController.cpp 	    //nat
   ├── NatController.h 
   ├── NetlinkHandler.cpp 	    //接收netlink事件
   └── NetlinkHandler.h 

    后续将按照每个module使用场景来对以上4中应用分别详细讲解
Android系统中iptables的应用---BandwidthController
Android系统中iptables的应用---NatController
Android系统中iptables的应用---FirewallController
Android系统中iptables的应用---IdlertimerController
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
iptables 是 Linux 系统的一个强大的防火墙工具,它可以用于过滤、重定向和修改网络数据包。它是一个基于内核的软件,可以对数据包进行过滤和修改,从而实现网络连接的控制和管理。在 Linux 系统iptables 是最常用的防火墙软件之一,它可以在多个层面上进行过滤和管理网络连接。以下是 iptables 在 Linux 系统的一些应用: 1. 防火墙:iptables 可以配置防火墙规则,保护系统免受来自外部网络的攻击。它可以限制不同网络之间的数据流量,并允许或阻止特定的端口和协议。 2. NATiptables 可以实现网络地址转换(NAT),它可以将私有 IP 地址转换为公共 IP 地址以实现 Internet 访问。通过 NAT,可以将多个设备连接到 Internet,而不需要每个设备都拥有公共 IP 地址。 3. 端口转发:iptables 可以将进入系统的数据包重定向到其他系统或端口。这是在服务器环境非常有用的,因为它可以将外部流量重定向到内部服务器。 4. 流量限制:iptables 可以限制流量,这对于限制恶意用户或应用程序的带宽使用非常有用。它可以限制连接的数量、速率和带宽,从而保证网络的稳定性和可靠性。 总之,iptables 是 Linux 系统非常有用的一个工具,可以用于保护网络安全、管理网络连接和实现网络地址转换等功能。它的功能非常强大,但也需要用户具备一定的技术水平和经验,才能正确配置和使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值