亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Linux > 正文

從五方面簡單解析Linux系統防火墻框架

2019-09-08 23:17:58
字體:
來源:轉載
供稿:網友

    Linux系統中的Netfilter提供了一個抽象、通用化的框架,該框架定義的一個子功能的實現就是包過濾子系統,框架包含以下五部分:

    1. 為每種網絡協議(IPv4、IPv6等)定義一套鉤子函數(IPv4定義了5個鉤子函數), 這些鉤子函數在數據報流過協議棧的幾個關鍵點被調用。在這幾個點中,協議棧將把數據報及鉤子函數標號作為參數調用Netfilter框架。

    2. 內核的任何模塊可以對每種協議的一個或多個鉤子進行注冊,實現掛接,這樣當某個數據包被傳遞給Netfilter框架時,內核能檢測是否有任何模塊對該協議和鉤子函數進行了注冊。若注冊了,則調用該模塊的注冊時使用的回調函數,這樣這些模塊就有機會檢查(可能還會修改)該數據包、丟棄該數據包及指示Netfilter將該數據包傳入用戶空間的隊列。

    3 .那些排隊的數據包是被傳遞給用戶空間的異步地進行處理。一個用戶進程能檢查數據包,修改數據包,甚至可以重新將該數據包通過離開內核的同一個鉤子函數中注入到內核中。

    4. 任何在IP層要被拋棄的IP數據包在真正拋棄之前都要進行檢查。例如允許模塊檢查IP-Spoofed包(被路由拋棄)。

    5.IP層的五個HOOK點的位置如下所示:

    (1)NF_IP_PRE_ROUTING:剛剛進入網絡層的數據包通過此點(剛剛進行完版本號,校驗 和等檢測),源地址轉換在此點進行;IP_Input.c中IP_Rcv調用;

    (2)NF_IP_LOCAL_IN:經路由查找后,送往本機的通過此檢查點,INPUT包過濾在此點進行,IP_local_deliver中調用;

    (3)NF_IP_FORWARD:要轉發的包通過此檢測點,FORWORD包過濾在此點進行;

    (4)NF_IP_POST_ROUTING:所有馬上便要通過網絡設備出去的包通過此檢測點,內置的目的地址轉換功能(包括地址偽裝)在此點進行;

    (5)NF_IP_LOCAL_OUT:本機進程發出的包通過此檢測點,OUTPUT包過濾在此點進行。

    這些點是已經在內核中定義好的,內核模塊能夠注冊在這些HOOK點進行的處理,可使用nf_register_hook函數指定。在數據報經過這些鉤子函數時被調用,從而模塊可以修改這些數據報,并向Netfilter返回如下值:

NF_ACCEPT 繼續正常傳輸數據報NF_DROP 丟棄該數據報,不再傳輸NF_STOLEN 模塊接管該數據報,不要繼續傳輸該數據報NF_QUEUE 對該數據報進行排隊(通常用于將數據報給用戶空間的進程進行處理)NF_REPEAT 再次調用該鉤子函數
 
    一個基于Netfilter框架的、稱為IPtables的數據報選擇系統在Linux2.4內核中被應用,其實它就是IPchains的后繼工具,但卻有更強的可擴展性。內核模塊可以注冊一個新的規則表(table),并要求數據報流經指定的規則表。這種數據報選擇用于實現數據報過濾(filter表),網絡地址轉換(Nat表)及數據報處理(Mangle表)。 Linux2.4內核提供的這三種數據報處理功能都基于Netfilter的鉤子函數和IP表。它們是獨立的模塊,相互之間是獨立的。它們都完美的集成到由Netfileter提供的框架中。

包過濾

Filter表格不會對數據報進行修改,而只對數據報進行過濾。IPtables優于IPchains的一個方面就是它更為小巧和快速。它是通過鉤子函數NF_IP_LOCAL_IN、NF_IP_FORWARD及NF_IP_LOCAL_OUT接入Netfilter框架的。因此對于任何一個數 報只有一個地方對其進行過濾。這相對IPchains來說是一個巨大的改進,因為在IPchains中一個被轉發的數據報會遍歷三條鏈。

NAT

NAT表格監聽三個Netfilter鉤子函數:NF_IP_PRE_ROUTING、NF_IP_POST_ROUTING及NF_IP_LOCAL_OUT。 NF_IP_PRE_ROUTING實現對需要轉發的數據報的源地址進行地址轉換而NF_IP_POST_ROUTING則對需要轉發的數據包的目的地址進行地址轉換。對于本地數據報的目的地址的轉換則由NF_IP_LOCAL_OUT來實現。NAT表格不同于filter表格,因為只有新連接的第一個數據報將遍歷表格,而隨后的數據報將根據第一個數據報的結果進行同樣的轉換處理。NAT表格被用在源NAT、目的NAT,偽裝(其是源NAT的一個特例)及透明代理(其是目的NAT的一個特例)。

數據報處理(Packet Mangling)

Mangle表格在NF_IP_PRE_ROUTING和NF_IP_LOCAL_OUT鉤子中進行注冊。使用 mangle表,可以實現對數據報的修改或給數據報附上一些帶外數據。當前mangle表支持修改TOS位及設置skb的nfmard字段。

源碼分析

如果我們想加入自己的代碼,便要用nf_register_hook函數,其函數原型為:

int nf_register_hook(struct nf_hook_ops *reg) struct nf_hook_ops { struct list_head list; /* User fills in from here down. */ nf_hookfn *hook; int pf; int hooknum; /* Hooks are ordered in ascending priority. */ int priority; };

我們的工作便是生成一個struct nf_hook_ops結構的實例,并用nf_register_hook將其HOOK上。其中list項我們總要初始化為{NULL,NULL};由于一般在IP層工作,pf總是PF_INET;hooknum就是我們選擇的HOOK點;一個HOOK點可能掛多個處理函數,誰先誰后,便要看優先級,即priority的指定了。Netfilter_IPv4.h中用一個枚舉類型指定了內置的處理函數的優先級:

enum nf_IP_hook_priorities { NF_IP_PRI_FIRST = INT_MIN, NF_IP_PRI_CONNTRACK = -200, NF_IP_PRI_MANGLE = -150, NF_IP_PRI_NAT_DST = -100, NF_IP_PRI_FILTER = 0, NF_IP_PRI_NAT_SRC = 100, NF_IP_PRI_LAST = INT_MAX, };

Hook是提供的處理函數,也就是我們的主要工作,其原型為:

unsigned int nf_hookfn(unsigned int hooknum, struct sk_buff **skb, const struct net_device *in, const struct net_device *out, int (*okfn)(struct sk_buff *));

它的五個參數將由NFHOOK宏傳進去。nf_register_hook根據reg中注冊的協議簇類型和優先級在nf_hooks中找到相應的位置并插入到此表中。_hooks[NPROTO][NF_MAX_HOOKS]在Netfilter初始化時(Netfilter_init/Netfilter.c,而它在sock_init時調用)已經初始為一個空表。

例如IPtable在初始化時(init/IPtable_filter.c)調用nf_register_hook注冊他的hook函數。

static struct nf_hook_ops IPt_ops[] = { { { NULL, NULL }, IPt_hook, PF_INET, NF_IP_LOCAL_IN, NF_IP_PRI_FILTER }, { { NULL, NULL }, IPt_hook, PF_INET, NF_IP_FORWARD, NF_IP_PRI_FILTER }, { { NULL, NULL }, IPt_local_out_hook, PF_INET, NF_IP_LOCAL_OUT, NF_IP_PRI_FILTER } };

mangle在init/IPtable_mangle.c中注冊它自己的hook函數?!?

static struct nf_hook_ops IPt_ops[] = { { { NULL, NULL }, IPt_hook, PF_INET, NF_IP_PRE_ROUTING, NF_IP_PRI_MANGLE }, { { NULL, NULL }, IPt_local_out_hook, PF_INET, NF_IP_LOCAL_OUT, {NF_IP_PRI_MANGLE } };

NAT在init/IP_nat_standalone.c中注冊它自己的hook函數

/*包過濾前,更改目的地址*/static struct nf_hook_ops IP_nat_in_ops

linux 系統防火墻

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
高清欧美性猛交xxxx黑人猛交| 久久琪琪电影院| 国产精品免费看久久久香蕉| 91亚洲精华国产精华| 久久久成人精品视频| 亚洲嫩模很污视频| 日韩一区二区久久久| 亚洲欧美另类中文字幕| 亚洲高清色综合| 国产精品欧美一区二区三区奶水| 久久久久久久亚洲精品| 日韩中文在线观看| 欧美日韩国产第一页| 在线观看欧美日韩国产| 7777免费精品视频| 91九色国产视频| 亚洲专区在线视频| 精品国偷自产在线视频99| 日韩成人免费视频| 欧美极品少妇xxxxⅹ裸体艺术| 日韩高清有码在线| 久久99青青精品免费观看| 92福利视频午夜1000合集在线观看| 久久久久久网址| 欧美视频在线视频| 成人免费直播live| 日韩中文字幕国产精品| 91美女福利视频高清| 国语自产精品视频在免费| 日韩精品中文字幕久久臀| 国产www精品| 亚洲女人天堂色在线7777| 国产成人精品a视频一区www| 欧美肥婆姓交大片| 91久久在线视频| 亚洲欧美国产精品久久久久久久| 中文字幕日韩欧美在线| 日韩av色在线| 欧美日韩一区免费| 久久亚洲国产精品成人av秋霞| 欧美视频裸体精品| 欧美精品激情在线| 91久久久久久| 欧美大片欧美激情性色a∨久久| 亚洲成人免费网站| 色av吧综合网| 国产精品美女999| 国产精品色婷婷视频| 91中文在线视频| 国产一区二区三区久久精品| 欧美性做爰毛片| 欧美性理论片在线观看片免费| 欧美精品午夜视频| 欧美精品久久久久久久| 亚洲电影成人av99爱色| 亚洲成人免费网站| 亚洲女人天堂成人av在线| 中文字幕亚洲欧美一区二区三区| 成人激情视频网| 日本精品视频在线播放| 超碰日本道色综合久久综合| 欧美精品激情视频| 午夜精品久久久久久久白皮肤| 国产成人精彩在线视频九色| 中文字幕av一区中文字幕天堂| 日韩成人在线观看| 这里只有精品丝袜| 国产日韩精品在线| 2019中文字幕全在线观看| 草民午夜欧美限制a级福利片| 久久69精品久久久久久久电影好| 久久国产一区二区三区| 久久91亚洲精品中文字幕| 久久精品国产96久久久香蕉| 亚洲视频一区二区三区| 日韩av电影中文字幕| 亚洲三级黄色在线观看| 国自在线精品视频| 久久精品国产2020观看福利| 久久亚洲精品国产亚洲老地址| 国产97在线亚洲| 68精品久久久久久欧美| 在线电影中文日韩| 欧美日韩亚洲激情| 国产午夜精品美女视频明星a级| www.久久久久久.com| 中文字幕欧美精品在线| 日韩欧美国产视频| 日本一欧美一欧美一亚洲视频| 91国内揄拍国内精品对白| 日韩av观看网址| 欧美日韩在线观看视频小说| 日韩精品福利网站| 亚洲精品美女免费| 国产人妖伪娘一区91| 欧美精品久久久久久久久| 欧美大片大片在线播放| 国产日韩欧美成人| 成人国内精品久久久久一区| 国产成人涩涩涩视频在线观看| 亚洲一区二区在线| 欧美小视频在线观看| 国产成人涩涩涩视频在线观看| 国产99久久精品一区二区永久免费| 亲子乱一区二区三区电影| 97国产精品免费视频| 国产精品99蜜臀久久不卡二区| 亚洲直播在线一区| 亚洲а∨天堂久久精品喷水| 国产精欧美一区二区三区| 国产亚洲激情视频在线| 欧洲成人免费视频| 国产精品揄拍一区二区| 亚洲第一福利网站| 欧美在线一级va免费观看| 欧美精品免费看| 久久99视频精品| 在线看福利67194| 在线日韩第一页| 91色p视频在线| 美日韩精品免费观看视频| 国产精品自拍偷拍视频| 日韩电影免费在线观看中文字幕| 国产精品永久免费视频| www.日韩系列| 国产精品久久久久久久久久尿| 国产精品视频一区二区三区四| 美日韩精品视频免费看| 狠狠色噜噜狠狠狠狠97| 97精品国产97久久久久久春色| 国内精品国产三级国产在线专| 国产最新精品视频| 欧美贵妇videos办公室| 精品久久久久久久久久久久久久| 国产午夜精品久久久| 久久影视电视剧免费网站清宫辞电视| 狠狠色狠狠色综合日日小说| 欧美精品videos性欧美| 日韩精品在线观| 精品国产一区二区三区四区在线观看| 欧美成人免费全部观看天天性色| 亚洲欧美中文日韩在线| 亚洲一区中文字幕在线观看| 日韩av日韩在线观看| 色噜噜狠狠狠综合曰曰曰88av| 国产综合福利在线| 国产一区视频在线播放| 一区国产精品视频| 91av在线视频观看| 亚洲一品av免费观看| 日韩视频免费中文字幕| 欧美视频裸体精品| 欧美激情videoshd| 国产亚洲美女精品久久久| 亚洲国产91精品在线观看| 国产精品亚洲аv天堂网| 国产成人精彩在线视频九色| 久久精品视频导航| 成人欧美一区二区三区黑人| 国产精品高精视频免费| 深夜福利91大全| 亚洲女性裸体视频| 欧美日韩午夜视频在线观看| 国产成人精品免高潮在线观看|