Attack Protection
These rules are used to counter penetration tactics in the container environment, such as mitigating container information leakage and prohibiting execution of sensitive actions.
Mitigating Information Leakage
mitigate-sa-leak
Mitigating ServiceAccount token leakage.
This rule prohibits container processes from reading sensitive Service Account-related information, including tokens, namespaces, and CA certificates. It helps prevent security risks arising from the leakage of Default ServiceAccount or misconfigured ServiceAccount. In the event that attackers gain access to a container through an RCE vulnerability, they often seek to further infiltrate by leaking ServiceAccount information.
In most user scenarios, there is no need for Pods to communicate with the API Server using ServiceAccounts. However, by default, Kubernetes still sets up default ServiceAccounts for Pods that do not require communication with the API Server.
Disallow reading ServiceAccount-related files.
- AppArmor
- BPF
mitigate-disk-device-number-leak
Mitigating host disk device number leakage.
Attackers may attempt to obtain host disk device numbers for subsequent container escape by reading the container process's mount information.
Disallow reading /proc/[PID]/mountinfo
and /proc/partitions
files.
- AppArmor
- BPF
mitigate-overlayfs-leak
Mitigating container overlayfs path leakage.
Attackers may attempt to obtain the overlayfs path of the container's rootfs on the host by accessing the container process's mount information, which could be used for subsequent container escape.
Disallow reading /proc/mounts
, /proc/[PID]/mounts
, and /proc/[PID]/mountinfo
files.
This rule may impact some functionality of the mount command or syscall within containers.
- AppArmor
- BPF
mitigate-host-ip-leak
Mitigating host IP leakage.
After gaining access to a container through an RCE vulnerability, attackers often attempt further network penetration attacks. Therefore, restricting attackers from obtaining sensitive information such as host IP, MAC, and network segments through this vector can increase the difficulty and cost of their network penetration activities.
Disallow reading ARP address resolution tables (such as /proc/net/arp
, /proc/[PID]/net/arp
)
- AppArmor
- BPF
disallow-metadata-service
Disallow access to the metadata service.
This rule prohibits container processes from accessing the cloud server's Instance Metadata Service, including two reserved local addresses: 100.96.0.96 and 169.254.169.254.
Attackers, upon gaining code execution privileges within a container, may attempt to access the cloud server's Metadata Service for information disclosure. In certain scenarios, attackers may obtain sensitive information, leading to privilege escalation and lateral movement.
Prohibit connections to Instance Metadata Services' IP addresses.
- BPF
Disabling Sensitive Operations
disable-write-etc
Prohibit writing to the /etc
directory.
Attackers may attempt privilege escalation by modifying sensitive files in the /etc
directory, such as altering /etc/bash.bashrc
for watering hole attacks, editing /etc/passwd
and /etc/shadow
to add users for persistence, or modifying nginx.conf or /etc/ssh/ssh_config
for persistence.
Disallow writing to the /etc
directory.
- AppArmor
- BPF
disable-busybox
Prohibit the execution of busybox command.
Some application services are packaged using base images like busybox or alpine. This also provides attackers with a lot of convenience, as they can use busybox to execute commands and assist in their attacks.
Prohibit the execution of busybox command.
If containerized services rely on busybox or related bash commands, enabling this policy may lead to runtime errors.
- AppArmor
- BPF
disable-shell
Prohibit the creation of Unix shells.
After gaining remote code execution privileges through an RCE vulnerability, attackers may use a reverse shell to gain arbitrary command execution capabilities within the container.
This rule prohibits container processes from creating new Unix shells, thus defending against reverse shell.
Prohibit the creation of Unix shells.
Some base images may symlink sh to /bin/busybox
. In this scenario, it's also necessary to prohibit the execution of busybox.
- AppArmor
- BPF
disable-wget
Prohibit the execution of wget command.
Attackers may use the wget command to download malicious programs for subsequent attacks, such as persistence, privilege escalation, network scanning, cryptocurrency mining, and more.
This rule limits file downloads by prohibiting the execution of the wget command.
Prohibit the execution of wget.
Some base images may symlink wget to /bin/busybox
. In this scenario, it's also necessary to prohibit the execution of busybox.
- AppArmor
- BPF
disable-curl
Prohibit the execution of curl command.
Attackers may use the curl command to initiate network access and download malicious programs from external sources for subsequent attacks, such as persistence, privilege escalation, network scanning, cryptocurrency mining, and more.
This rule limits network access by prohibiting the execution of the curl command.
Prohibit the execution of curl command.
- AppArmor
- BPF
disable-chmod
Prohibit the execution of chmod command.
When attackers gain control over a container through vulnerabilities, they typically attempt to download additional attack code or tools into the container for further attacks, such as privilege escalation, lateral movement, cryptocurrency mining, and more. In this attack chain, attackers often use the chmod command to modify file permissions for execution.
Prohibit the execution of chmod command.
Some base images may symlink wget to /bin/busybox
. In this scenario, it's also necessary to prohibit the execution of busybox.
- AppArmor
- BPF
disable-chmod-x-bit
Prohibit setting the execute/search bit of a file.
When attackers gain control over a container through vulnerabilities, they typically attempt to download additional attack code or tools into the container for further attacks, such as privilege escalation, lateral movement, cryptocurrency mining, and more. In this attack chain, attackers might use the chmod syscalls to modify file permissions for execution.
Prohibit setting the execute/search bit of a file with chmod
, fchmod
, fchmodat
, fchmodat2
syscalls.
- Seccomp
disable-chmod-s-bit
Prohibit setting the SUID/SGID bit of a file.
In some scenarios, attackers may attempt to invoke chmod syscalls to perform privilege elevation attacks by setting the file's s-bit (set-user-ID, set-group-ID).
Prohibit setting the set-user-ID/set-group-ID bit of a file with chmod
, fchmod
, fchmodat
, fchmodat2
syscalls
- Seccomp
disable-su-sudo
Prohibit the execution of su and sudo command.
When processes within a container run as non-root users, attackers often need to escalate privileges to the root user for further attacks. The sudo and su commands are common local privilege escalation avenues.
Prohibit the execution of sudo and su command.
Some base images may symlink su to /bin/busybox
. In this scenario, it's also necessary to prohibit the execution of busybox.
- AppArmor
- BPF
Others
disable-network
Prohibit all network access.
When you want to prevent a container from accessing the network, you can use this rule to disable it.
- AppArmor
- BPF
disable-inet
, disable-ipv4
Prohibit accessing the network via inet4 addresses.
When you want to prevent a container from accessing the network via IPv4 addresses, you can use this rule to disable it.
- AppArmor
- BPF
disable-inet6
, disable-ipv6
Prohibit accessing the network via inet6 addresses.
When you want to prevent a container from accessing the network via IPv6 addresses, you can use this rule to disable it.
- AppArmor
- BPF
disable-unix-domain-socket
Prohibit accessing the network via UDS addresses.
When you want to prevent a container from accessing the network via Unix Domain Socket addresses, you can use this rule to disable it.
- AppArmor
- BPF
disable-icmp
Prohibit the use of the ICMP protocol.
When you want to prevent a container from using ICMP protocol, you can use this rule to disable it.
- AppArmor
- BPF
disable-tcp
Prohibit the use of the TCP protocol.
When you want to prevent a container from using TCP protocol, you can use this rule to disable it.
- AppArmor
- BPF
disable-udp
Prohibit the use of the UDP protocol.
When you want to prevent a container from using UDP protocol, you can use this rule to disable it.
- AppArmor
- BPF
Restricting Specific Executable
It extends the use cases of Mitigating Information Leakage, Disabling Sensitive Operations and Others, it allows user to apply restrictions only to specific executable programs within containers.
Restricting specified executable programs serves two purposes:
- Preventing sandbox policies from affecting the execution of application services within containers.
- Restricting specified executable programs within containers increases the cost and difficulty for attackers
For example, this feature can be used to restrict programs like busybox, bash, sh, curl within containers, preventing attackers from using them to execute sensitive operations. Meanwhile, the application services is unaffected by sandbox policies and can continue to access ServiceAccount tokens and perform other tasks normally.
Note: Due to the implementation principles of BPF LSM, this feature cannot be robustly provided by the BPF enforcer.
Enable sandbox restrictions for specified executable programs.
- Apprmor
Use case:
policy:
enforcer: AppArmor
mode: EnhanceProtect
enhanceProtect:
attackProtectionRules:
# All processes in the container are confined by the `disable-write-etc` rule.
- rules:
- disable-write-etc
# Only the executable files listed below and their child processes are confined by the listed rules.
- rules:
- mitigate-sa-leak
- disable-network
- disable-chmod-x-bit
targets:
- "/bin/sh"
- "/usr/bin/sh"
- "/bin/dash"
- "/usr/bin/dash"
- "/bin/bash"
- "/usr/bin/bash"
- "/bin/busybox"
- "/usr/bin/busybox"