F5BigDdosPolicy¶
Overview¶
The F5BigDdosPolicy Custom Resource (CR) configures the Traffic Management Microkernel (TMM) Proxy Pod to protect applications and the TMM Pod from Denial of Service / Distributed Denial of Service (Dos/DDoS) attacks. Using custom packet signatures, the F5BigDdosPolicy inspects all application traffic processed by the TMM Proxy Pod, to detect, report and/or mitigate DoS/DDoS events.
This document guides you through understanding, configuring and installing a simple F5BigDdosPolicy CR.
CR Parameters¶
The tables below describe the F5BigDdosPolicy CR parameters used in this document. For the full list of parameters, refer to the F5BigDdosPolicy Reference.
allowList¶
Parameter | Description |
---|---|
sourceAddressList |
Specifies the F5BigCneAddresslist by metadata.name containing the source IP addresses to exclude from DDoS detection/mitigation. |
vectors.floodVectors.commonConfigVectors¶
Parameter | Description |
---|---|
vectorType |
Specifies the type of DoS Flood Vector to detect and mitigate: ipv6-frag-flood. Refer to F5BigDdosPolicy Reference for a full list. |
state |
Specifies the reponse for a vector match: detection-only (default) or mitigation. To disable, delete the custom resource. |
detectionThresholdEps |
Specifies the attack detection threshold in PPS for the configured attack type. Default value 4294967295. |
detectionThresholdPercentage |
Specifies the attack detection percentage increase for the configured attack type. Default value 4294967295. |
rateLimit |
Specifies the rate limit in PPS for the configured attack. Default value 4294967295. |
vectors.dnsFloodVectors.commonConfigVectors¶
Parameter | Description |
---|---|
vectorType |
The type of DNS Flood Vector: dns-aaaa-query. Refer to F5BigDdosPolicy Reference for a full list. |
state |
Specifies the reponse for a vector match: detection-only (default) or mitigation. To disable, delete the custom resource. |
detectionThresholdEps |
Specifies the attack detection threshold in EPS for the configured attack type. The default value is 4294967295. |
rateLimit |
Specifies the rate limit in EPS for the configured attack. The default value is 4294967295. |
CR Example¶
apiVersion: "dos.k8s.f5net.com/v1"
kind: F5BigDdosPolicy
metadata:
name: "cnf-dns-ddos"
namespace: "cnf-gateway"
hslPublisher: "cnf-hsl-pub"
vectors:
floodVectors:
commonConfigVectors:
- vectorType: "ipv6-frag-flood"
state: "detection-only"
detectionThresholdEps: 1111
detectionThresholdPercentage: 11
rateLimit: 10
dnsFloodVectors:
commonConfigVectors:
- vectorType: "dns-aaaa-query"
state: "detection-only"
rateLimit: 111
perDstIpLimitEps: 111111
allowList:
sourceAddressList: "outbound-nat"
CR shortName¶
CR shortNames provide an easy way to view installed CRs, and their configuration parameters. The CR shortName can also be used to delete the CR instance. The F5BigDdosPolicy CR shortName is ddos.
View CR instance:
kubectl get ddos -n <namespace>
View CR configuration:
kubectl get ddos -n <namespace> -o yaml
Address lists¶
The F5BigCneAddresslist CR defines lists of IP addresses that can be referenced by the F5BigDdosPolicy CR.
Example:
apiVersion: "k8s.f5net.com/v1"
kind: F5BigCneAddresslist
metadata:
name: "outbound-nat"
namespace: "cnf-gateway"
spec:
addresses:
- "2002::33:22-2002::33:50"
- "2003::/64"
- "2004::1"
- "192.168.1.0-192.168.1.10"
- "10.10.10.0/24"
- "192.168.2.1"
Multiple TMM Proxy Pods¶
When Dos/DDoS attacks are detected, the attack is identified using a unique attack identifier (attack-ID). To ensure the attack-ID can be shared across multiple TMM Proxy Pods, avoiding duplicate attack-ID entries, the dSSM Database must be installed. The first TMM Proxy Pod to detect an attack stores the attack-ID in the dSSM database, and the TMM Proxy Pod replicas then check the dSSM database before creating any new attack-IDs.
Requirements¶
Ensure you have:
- Installed the BIG-IP Controller.
- Installed the dSSM Database when scaling TMM Proxy Pods.
- A Linux based workstation.
Installation¶
Use these steps to install the example F5BigDdosPolicy CR, and the optional CNFs CRs. Each step offers a brief description of the example CR.
Tip: Open a second shell to view the CNFs Event Logs while installing.
Optional: The example F5BigLogHslpub CR specifies a remote server with IP/port [2002::10:30:2:220]:514 and the udp protocol. Copy and paste the example into a YAML file:
Note: The F5BigLogHslpub CR will be referenced by the F5BigDdosPolicy.
apiVersion: k8s.f5net.com/v1 kind: F5BigLogHslpub metadata: name: "cnf-hsl-pub" namespace: "cnf-gateway" spec: pool: - name: "cnf-hslpool" endpoint: - "[2002::10:30:2:220]:514" syslog: - name: "syslog-dest" format: "rfc5424" protocol: "udp" pool: "cnf-hslpool"
Install the F5BigLogHslpub CR:
kubectl apply -f cnf-hsl-cr.yaml
In this example, the BIG-IP Controller logs indicate the F5BigLogHslpub CR was added/updated:
I0202 12:00:00.12347 1 event.go:282 Event(v1.ObjectReference{Kind:"F5Hslpub", F5Hslpub cnf-gateway/cnf-hsl-pub was added/updated
The example F5BigCneAddresslist specifies a range 2002::33:22-2002::33:50, and a subnet 2003::/64 of IPv6 addresses. Copy and paste the example into a YAML file:
Note: The F5BigCneAddresslist CR will be referenced by the F5BigDdosPolicy CR.
apiVersion: "k8s.f5net.com/v1" kind: F5BigCneAddresslist metadata: name: "outbound-nat" namespace: "cnf-gateway" spec: addresses: - "2002::33:22-2002::33:50" - "2003::/64" - "2004::1" - "192.168.1.0-192.168.1.10" - "10.10.10.0/24" - "192.168.2.1"
Install the F5BigCneAddresslist CR:
kubectl apply -f cnf-address-list.yaml
In this example, the BIG-IP Controller logs indicate the F5BigCneAddresslist CR was added/updated:
I0208 12:00:00:12345 1 event.go:282] Event(v1.ObjectReference{Kind:"F5AddressList", F5AddressListProfile cnf-gateway/outbound-nat was added/updated
The example F5BigDdosPolicy mitigates ipv6-frag-flood and dns-aaaa-query attacks, and excludes the F5BigCneAddresslist IPs from the policy. Copy and paste the example into a YAML file:
apiVersion: "dos.k8s.f5net.com/v1" kind: F5BigDdosPolicy metadata: name: "cnf-dns-ddos" namespace: "cnf-gateway" hslPublisher: "cnf-hsl-pub" vectors: floodVectors: commonConfigVectors: - vectorType: "ipv6-frag-flood" state: "detection-only" detectionThresholdEps: 1111 detectionThresholdPercentage: 11 rateLimit: 10 dnsFloodVectors: commonConfigVectors: - vectorType: "dns-aaaa-query" state: "detection-only" rateLimit: 111 perDstIpLimitEps: 111111 allowList: sourceAddressList: "outbound-nat"
Install the F5BigDdosPolicy CR:
kubectl apply -f cnf-ddos-cr.yaml -n cnf-gateway
In this example, the BIG-IP Controller logs indicate the F5BigDdosPolicy CR was added/updated:
I0208 12:00:00:12345 1 event.go:282] Event(v1.ObjectReference{Kind:"F5Dos", F5Dos cnf-gateway/cnf-dns-ddos was added/updated
The F5BigDdosPolicy will inspect all application traffic processed by the TMM Proxy Pod. Continue to the Additional CRs and Dos/DDoS Statistics sections.
Additional CRs¶
To begin Dos/DDoS detection and mitigation, install one of the Traffic management CNFs CRs.
Dos/DDoS Statistics¶
Use the steps below to verify the F5BigDdosPolicy CR DoS/DDoS statistics:
Connect to the debug sidecar:
kubectl exec -it deploy/f5-tmm -c debug -n <namespace> -- bash
In this example, the debug sidecar is in the cnf-gateway Namespace:
kubectl exec -it deploy/f5-tmm -c debug -n cnf-gateway -- bash
Verify the DoS/DDoS statistics:
tmctl -d /var/tmstat/blade dos_stat -s context_name,vector_name,profile_name,protocol_type,status,attack_detected,attack_count,drops
context_name vector_name profile_name protocol_type status ------------ ----------- ------------------------- ------------- ------ Device L3/4 BDoS L4 BDoS Ready Device UDP flood /Common/dos-device-config Device Ready attack_detected attack_count drops --------------- ------------ ----- 0 0 0 1 2 8523
context_name vector_name profile_name ------------ ------------------------------- ------------------------- Device L3/4 BDoS Device DNS A Query /Common/dos-device-config Device IPv6 fragment flood /Common/dos-device-config Device IPv6 too many extension headers /Common/dos-device-config Device DNS AAAA Query /Common/dos-device-config protocol_type status attack_detected attack_count drops ------------- ------ --------------- ------------- ----- L4 BDoS Ready 0 0 0 Device Ready 0 0 0 Device Ready 3 4 18523 Device Ready 0 0 0 Device Ready 0 0 0
Feedback¶
Provide feedback to improve this document by emailing cnfdocs@f5.com.