Network security term typically refers to Threat prevention and Security on the wire.
Threat protection is normally achieved with multiple security technologies. Basic protection is achieved from firewall technology. IDS/IPS (Intrusion Detection/Prevention System), Anti-Virus, Web application firewalls are some of the security technologies that are increasingly being used to protect networks (Network devices, Servers and Client machines). Application Detection is another technology that is increasingly being used along with firewall to stop/allow traffic that can't be identified using ports in TCP/UDP headers, but requiring deep packet inspection.
Other than firewall, all technologies listed above require deep packet and deep data inspection. IDS/IPS technology adopts multiple techniques to identify the attack traffic. One of the techniques is to match the traffic data with known attack patterns. Application detection also relays on pattern matching on the data as one of the techniques to detect the applications. Anti Virus technology too depends on some pattern matching to detect viruses.
In almost all technologies above, patterns get added to the deployed systems on continuous basis by device vendors as more attacks are discovered. For example, IPS devices, nowadays have around10,000 patterns (signatures) to detect the known attacks. It keeps increasing every year. Additionally, Some of these patterns are checked on every packet that goes through IPS. This adds to number of CPU cycles requires to do IPS protection.
Many software algorithms are used to speed up the pattern matching performance. Some of the techniques inlcude:
IPS and other technologies also use techniques to reduce the number of patterns to be matched using protocol level intelligence and classifying the patterns in multiple buckets (protocol basis, port basis, even on the basis of application protocol stages such as URL based pattern database, HTTP Request header, Response header pattern databases etc..).
Due to above techniques, some device vendors think that there is no need for pattern matching hardware accelerators. There is a reason for that too as some early developments of snort (popular open source IDS/IPS software) did not find much performance improvement with hardware accelerators. But I believe HW accelerators are required for following reasons.
Performance Determinism: IPS, Anti Virus, Web application firewall and application detection technologies depend on the regular signature updates. Hardware deployed in the fields might have X number of signatures a day of purchase and they might go up to 2X or 3X over the years. Performance determinism is expected by CSOs. To maintain performance levels, CPUs should be avoided in doing pattern matching. Hardware accelerators specialized in pattern matching help in maintaining performance levels even with increasing number of signatures.
Protection from CPU hogging attacks: With software based pattern matching, it is possible to hog the CPUs by crafting the packets with each data that matches a patterns multiple times. Consider that there is a signature rule which tries to match a pattern "abc123def" and if there is 1Mbytes of data is sent with all the data having "abc123def" repeated, then the CPU would take forever as it matches every packet multiple times. CPU will not only spend time in matching the patterns, but also spends significant number of cycles in doing further analysis. Hardware accelerators normally designed such a way that the performance does not go down even if there are multiple matches.
Next question would be the what capabilities of hardware accelerators one should look for to mitigate performance issues - One associated with explosive growth of attack patterns (signatures) and avoid CPU hogging by deliberate attempts by attackers. I believe one should look for following capabilities.
Threat protection is normally achieved with multiple security technologies. Basic protection is achieved from firewall technology. IDS/IPS (Intrusion Detection/Prevention System), Anti-Virus, Web application firewalls are some of the security technologies that are increasingly being used to protect networks (Network devices, Servers and Client machines). Application Detection is another technology that is increasingly being used along with firewall to stop/allow traffic that can't be identified using ports in TCP/UDP headers, but requiring deep packet inspection.
Other than firewall, all technologies listed above require deep packet and deep data inspection. IDS/IPS technology adopts multiple techniques to identify the attack traffic. One of the techniques is to match the traffic data with known attack patterns. Application detection also relays on pattern matching on the data as one of the techniques to detect the applications. Anti Virus technology too depends on some pattern matching to detect viruses.
In almost all technologies above, patterns get added to the deployed systems on continuous basis by device vendors as more attacks are discovered. For example, IPS devices, nowadays have around10,000 patterns (signatures) to detect the known attacks. It keeps increasing every year. Additionally, Some of these patterns are checked on every packet that goes through IPS. This adds to number of CPU cycles requires to do IPS protection.
Many software algorithms are used to speed up the pattern matching performance. Some of the techniques inlcude:
- DFA (Deterministic Finite State Automata)
- Bloom filters - Filters formed from the hashes of patterns can be used on the traffic to determine whether further analysis is required.
- PCRE algorithms to search for patterns of regular expression type.
IPS and other technologies also use techniques to reduce the number of patterns to be matched using protocol level intelligence and classifying the patterns in multiple buckets (protocol basis, port basis, even on the basis of application protocol stages such as URL based pattern database, HTTP Request header, Response header pattern databases etc..).
Due to above techniques, some device vendors think that there is no need for pattern matching hardware accelerators. There is a reason for that too as some early developments of snort (popular open source IDS/IPS software) did not find much performance improvement with hardware accelerators. But I believe HW accelerators are required for following reasons.
Performance Determinism: IPS, Anti Virus, Web application firewall and application detection technologies depend on the regular signature updates. Hardware deployed in the fields might have X number of signatures a day of purchase and they might go up to 2X or 3X over the years. Performance determinism is expected by CSOs. To maintain performance levels, CPUs should be avoided in doing pattern matching. Hardware accelerators specialized in pattern matching help in maintaining performance levels even with increasing number of signatures.
Protection from CPU hogging attacks: With software based pattern matching, it is possible to hog the CPUs by crafting the packets with each data that matches a patterns multiple times. Consider that there is a signature rule which tries to match a pattern "abc123def" and if there is 1Mbytes of data is sent with all the data having "abc123def" repeated, then the CPU would take forever as it matches every packet multiple times. CPU will not only spend time in matching the patterns, but also spends significant number of cycles in doing further analysis. Hardware accelerators normally designed such a way that the performance does not go down even if there are multiple matches.
Next question would be the what capabilities of hardware accelerators one should look for to mitigate performance issues - One associated with explosive growth of attack patterns (signatures) and avoid CPU hogging by deliberate attempts by attackers. I believe one should look for following capabilities.
- Accelerators should be programmable with decent number of patterns.
- Accelerators should be able to perform well even with large number of patterns.
- Accelerators should be able to perform well even if there are large number of matches.
- Accelerators should be able to perform pattern matches based on context information such as 'relative offset', 'Depth of the data to look' while doing pattern matching. This will reduce the number of results being returned by the accelerator. Smaller the number of results to software, lesser the post processing.
- Accelerators should be able to return results only when multiple patterns match on the data. This also is required to reduce the number of results.
No comments:
Post a Comment