資料庫防火牆的阻斷方式:行為阻斷或者Session阻斷
01.行為阻斷
行為阻斷是資料庫防火牆的自然工作方式。當檢測到入侵行為的時候,阻斷該行為的操作。行為阻斷依據響應偏好的不同,可以工作在不同模式之下。
模式一:錯誤響應模式
阻斷操作之後,返回預先定義的錯誤資訊,使應用程式可以構造合理的錯誤響應。錯誤響應模式的好處在於可以讓應用程式檢測到入侵發生,並響應合理的錯誤形式給使用者和入侵者。壞處在於可能入侵者也可以感知到有安全業務邏輯在發生作用,特別是如果應用程式缺乏錯誤處理有可能會直接返回錯誤響應給入侵者。
模式二:靜默響應模式
阻斷操作之後,返回正常的零響應資訊,包括0行資料,0行資料被影響或者成功操作的響應資訊。靜默響應模式的好處在於完全正常的業務邏輯響應可以使入侵者很難獲取相關資訊,壞處在於應用程式也無法感知入侵,只能依賴於安全裝置的執行。
模式三:持續阻斷模式
當檢測到應該被阻斷的風險操作之後,該Session被定義為高度風險Session,所有後續的操作都被標記為高風險操作,無論其內容如何都會被阻斷。持續阻斷模式的好處在於增加了入侵者的嘗試成本,增加其沮喪感,壞處在於可能由於風險檢測引擎的誤判導致業務持續失敗。
02.Session阻斷
Session阻斷相對於行為阻斷是一種很簡單的操作,中斷網路連線,阻止進一步的操作。Session阻斷的好處在於技術上實現非常簡單,壞處則會帶來眾多不可預知的影響。而且,其不可被用在資料庫防火牆中。
為什麼在資料庫防火牆中不能執行Session阻斷?
絕大部分企業級應用建立在資料庫連線池技術之上。基本路徑是:業務應用程式發起資料庫操作請求,從資料庫連線池中獲得一個資料庫連線,應用程式在這個給定的資料庫連線執行業務操作,業務操作完成之後釋放這個資料庫連線到資料庫連線池。
下面我們來分析Session阻斷的操作和影響。一般情況下,多數Session阻斷會採用向客戶端和服務端分別發Reset包的方式來實現阻斷,我們這裡不探究reset訊號的阻斷有效性,假設其總是可以快速阻斷。在此前提下我們從兩個方面來探討可能的影響:
01.資料庫連線池的影響
Session阻斷之後,會導致資料庫連線池的可用數量減少。特別是在多數情況下,資料庫連線池並不會檢測到Reset訊號,也就是說雖然網路連線已經被中斷,但是資料庫連線池並沒有意識到連線已經不可用,依然會把業務分配到這個已經中斷的資料庫連線之上,導致業務大規模錯誤。
簡單來看,入侵者可以透過簡單的可以被資料庫防火牆識別的無效攻擊來實現cc攻擊,導致業務系統不可用。為了避免這種情況,需要在資料庫連線池上增加特定錯誤檢測功能,當檢測到特定錯誤之後,關閉特定無效連結,並主動發起重新連線以保持業務程式執行。
02.資料庫端的影響
在大部分情況下,資料庫並不能很好的處理reset訊號,而需要依賴死程式檢測程式來處理。由於處理無法保證有效,也就是說在相當多的場景下可能會出現大量的僵死程式,消耗大量資料庫會話資源,甚至存在共享的資源沒有釋放,從而導致資料庫掛起。
總結:資料庫防火牆裝置從理論上講必須採用行為阻斷模式,採用具體形式的行為阻斷都可以完成相應目標。Session阻斷模式會帶來眾多不可預知的影響,不應該被資料庫防火牆所採用。
本文轉載自微信公眾號“杭州美創科技有限公司”
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/31510736/viewspace-2168940/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 如何在 Linux 中根據國家位置來阻斷網路流量Linux
- Bug 3111951 - OERI[ktspscaninit-d] 被阻斷後的TRUNCATE
- 電阻絲印
- 電阻專題
- 電阻選型
- 企業資料流的防火牆和熔斷機制防火牆
- 知物由學 | Android應用破解與防護,阻斷猖獗的應用亂象Android
- 談談阻礙資料建模的5大藉口
- 禁運和斷供會阻斷我國的科技進步嗎?——由歷史經驗看對技術封鎖的應對之道
- 談一談阻礙資料建模的5大藉口
- VR 遊戲,道阻且長VR遊戲
- 搭建風控系統道路上踩過的坑03-阻斷風險 | 一個CPO的心得分享
- 防火牆NAT轉換的一次診斷防火牆
- Sql Server中判斷表或者資料庫是否存在SQLServer資料庫
- 程控水冷阻性負載主要工作方式有哪些負載
- 鋁殼電阻是什麼?
- 瑞數資訊開啟“以動制動”安全新起點——識別和阻斷銀行“合法內鬼”批量輸出資訊
- LTspice introduction - 16 電阻的伏安特性
- 誰阻擋了Linux的步伐?(轉)Linux
- 熱敏電阻公式精度驗證公式
- 開關電源——壓敏電阻
- 判斷資料庫中表內資料為空的辦法資料庫
- 雙通道-程控絕緣測試電阻箱主要工作方式
- 是什麼阻礙了你的成長
- mysql資料庫效能診斷MySql資料庫
- 【Oracle】資料庫hang 診斷Oracle資料庫
- Oracle配置資料庫診斷Oracle資料庫
- 人類阻擋不了谷歌翻譯了!谷歌
- 安規測試-接地電阻測試
- 小電容為什麼可以通高頻阻低頻?
- 氣候行動程式:道阻且長,但行則將至
- 資料庫防火牆資料庫防火牆
- 使用SQL_TRACE進行資料庫診斷SQL資料庫
- 判斷物件是否為空物件的方式物件
- 是什麼阻礙了你的機器學習目標?機器學習
- 電阻負載櫃的工作原理是什麼?負載
- 滑線變阻器的工作原理是什麼?
- JavaScript 判斷陣列或者物件是否為空JavaScript陣列物件