This documentation is for a release that is no longer maintained
See documentation for the latest supported version 3 or the latest supported version 4.Este contenido no está disponible en el idioma seleccionado.
Chapter 11. Managing Security Context Constraints
11.1. Overview
Security context constraints allow administrators to control permissions for pods. To learn more about this API type, see the security context constraints (SCCs) architecture documentation. You can manage SCCs in your instance as normal API objects using the CLI.
You must have cluster-admin privileges to manage SCCs.
Do not modify the default SCCs. Customizing the default SCCs can lead to issues when upgrading. Instead, create new SCCs.
11.2. Listing Security Context Constraints
To get a current list of SCCs:
11.3. Examining a Security Context Constraints Object
				To examine a particular SCC, use oc get, oc describe, oc export, or oc edit. For example, to examine the restricted SCC:
			
In order to preserve customized SCCs during upgrades, do not edit settings on the default SCCs other than priority, users, groups, labels, and annotations.
11.4. Creating New Security Context Constraints
To create a new SCC:
- Define the SCC in a JSON or YAML file: - Example 11.1. Security Context Constraint Object Definition - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Optionally, you can add drop capabilities to an SCC by setting the - requiredDropCapabilitiesfield with the desired values. Any specified capabilities will be dropped from the container. For example, to create an SCC with the- KILL,- MKNOD, and- SYS_CHROOTrequired drop capabilities, add the following to the SCC object:- requiredDropCapabilities: - KILL - MKNOD - SYS_CHROOT - requiredDropCapabilities: - KILL - MKNOD - SYS_CHROOT- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You can see the list of possible values in the Docker documentation. 
- Then, run - oc createpassing the file to create it:- oc create -f scc_admin.yaml - $ oc create -f scc_admin.yaml securitycontextconstraints/scc-admin- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the SCC was created: - oc get scc - $ oc get scc NAME PRIV CAPS HOSTDIR SELINUX RUNASUSER privileged true [] true RunAsAny RunAsAny restricted false [] false MustRunAs MustRunAsRange scc-admin true [] false RunAsAny RunAsAny- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
11.5. Deleting Security Context Constraints
To delete an SCC:
oc delete scc <scc_name>
$ oc delete scc <scc_name>If you delete a default SCC, it will be regenerated upon restart.
11.6. Updating Security Context Constraints
To update an existing SCC:
oc edit scc <scc_name>
$ oc edit scc <scc_name>In order to preserve customized SCCs during upgrades, do not edit settings on the default SCCs other than priority, users, and groups.
11.7. Updating the Default Security Context Constraints
Default SCCs will be created when the master is started if they are missing. To reset SCCs to defaults, or update existing SCCs to new default definitions after an upgrade you may:
- Delete any SCC you would like to be reset and let it be recreated by restarting the master
- 
						Use the oc adm policy reconcile-sccscommand
				The oc adm policy reconcile-sccs command will set all SCC policies to the default values but retain any additional users, groups, labels, and annotations as well as priorities you may have already set. To view which SCCs will be changed you may run the command with no options or by specifying your preferred output with the -o <format> option.
			
				After reviewing it is recommended that you back up your existing SCCs and then use the --confirm option to persist the data.
			
					If you would like to reset priorities and grants, use the --additive-only=false option.
				
If you have customized settings other than priority, users, groups, labels, or annotations in an SCC, you will lose those settings when you reconcile.
11.8. How Do I?
The following describe common scenarios and procedures using SCCs.
11.8.1. Grant Access to the Privileged SCC
In some cases, an administrator might want to allow users or groups outside the administrator group access to create more privileged pods. To do so, you can:
- Determine the user or group you would like to have access to the SCC. Warning- Granting access to a user only works when the user directly creates a pod. For pods created on behalf of a user, in most cases by the system itself, access should be given to a service account under which related controller is operated upon. Examples of resources that create pods on behalf of a user are Deployments, StatefulSets, DaemonSets, etc. 
- Run: - oc adm policy add-scc-to-user <scc_name> <user_name> oc adm policy add-scc-to-group <scc_name> <group_name> - $ oc adm policy add-scc-to-user <scc_name> <user_name> $ oc adm policy add-scc-to-group <scc_name> <group_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - For example, to allow the e2e-user access to the privileged SCC, run: - oc adm policy add-scc-to-user privileged e2e-user - $ oc adm policy add-scc-to-user privileged e2e-user- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							Modify SecurityContextof a container to request a privileged mode.
11.8.2. Grant a Service Account Access to the Privileged SCC
					First, create a service account. For example, to create service account mysvcacct in project myproject:
				
oc create serviceaccount mysvcacct -n myproject
$ oc create serviceaccount mysvcacct -n myproject
					Then, add the service account to the privileged SCC.
				
oc adm policy add-scc-to-user privileged system:serviceaccount:myproject:mysvcacct
$ oc adm policy add-scc-to-user privileged system:serviceaccount:myproject:mysvcacct
					Then, ensure that the resource is being created on behalf of the service account. To do so, set the spec.serviceAccountName field to a service account name. Leaving the service account name blank will result in the default service account being used.
				
Then, ensure that at least one of the pod’s containers is requesting a privileged mode in the security context.
11.8.3. Enable Images to Run with USER in the Dockerfile
To relax the security in your cluster so that images are not forced to run as a pre-allocated UID, without granting everyone access to the privileged SCC:
- Grant all authenticated users access to the anyuid SCC: - oc adm policy add-scc-to-group anyuid system:authenticated - $ oc adm policy add-scc-to-group anyuid system:authenticated- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
This allows images to run as the root UID if no USER is specified in the Dockerfile.
11.8.4. Enable Container Images that Require Root
					Some container images (examples: postgres and redis) require root access and have certain expectations about how volumes are owned. For these images, add the service account to the anyuid SCC.
				
oc adm policy add-scc-to-user anyuid system:serviceaccount:myproject:mysvcacct
$ oc adm policy add-scc-to-user anyuid system:serviceaccount:myproject:mysvcacct11.8.5. Use --mount-host on the Registry
					It is recommended that persistent storage using PersistentVolume and PersistentVolumeClaim objects be used for registry deployments. If you are testing and would like to instead use the oadm registry command with the --mount-host option, you must first create a new service account for the registry and add it to the privileged SCC. See the Administrator Guide for full instructions.
				
11.8.6. Provide Additional Capabilities
In some cases, an image may require capabilities that Docker does not provide out of the box. You can provide the ability to request additional capabilities in the pod specification which will be validated against an SCC.
This allows images to run with elevated capabilities and should be used only if necessary. You should not edit the default restricted SCC to enable additional capabilities.
					When used in conjunction with a non-root user, you must also ensure that the file that requires the additional capability is granted the capabilities using the setcap command. For example, in the Dockerfile of the image:
				
setcap cap_net_raw,cap_net_admin+p /usr/bin/ping
setcap cap_net_raw,cap_net_admin+p /usr/bin/ping
					Further, if a capability is provided by default in Docker, you do not need to modify the pod specification to request it. For example, NET_RAW is provided by default and capabilities should already be set on ping, therefore no special steps should be required to run ping.
				
To provide additional capabilities:
- Create a new SCC
- 
							Add the allowed capability using the allowedCapabilitiesfield.
- 
							When creating the pod, request the capability in the securityContext.capabilities.addfield.
11.8.7. Modify Cluster Default Behavior
When you grant access to the anyuid SCC for everyone, your cluster:
- Does not pre-allocate UIDs
- Allows containers to run as any user
- Prevents privileged containers
oc adm policy add-scc-to-group anyuid system:authenticated
 $ oc adm policy add-scc-to-group anyuid system:authenticatedTo modify your cluster so that it does not pre-allocate UIDs and does not allow containers to run as root, grant access to the nonroot SCC for everyone:
oc adm policy add-scc-to-group nonroot system:authenticated
 $ oc adm policy add-scc-to-group nonroot system:authenticatedBe very careful with any modifications that have a cluster-wide impact. When you grant an SCC to all authenticated users, as in the previous example, or modify an SCC that applies to all users, such as the restricted SCC, it also affects Kubernetes and OpenShift Container Platform components, including the web console and integrated docker registry. Changes made with these SCCs can cause these components to stop functioning.
Instead, create a custom SCC and target it to only specific users or groups. This way potential issues are confined to the affected users or groups and do not impact critical cluster components.
11.8.8. Use the hostPath Volume Plug-in
					To relax the security in your cluster so that pods are allowed to use the hostPath volume plug-in without granting everyone access to more privileged SCCs such as privileged, hostaccess, or hostmount-anyuid, perform the following actions:
				
- 
							Create a new SCC named hostpath
- Set the - allowHostDirVolumePluginparameter to- truefor the new SCC:- oc patch scc hostpath -p '{"allowHostDirVolumePlugin": true}'- $ oc patch scc hostpath -p '{"allowHostDirVolumePlugin": true}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Grant access to this SCC to all users: - oc adm policy add-scc-to-group hostpath system:authenticated - $ oc adm policy add-scc-to-group hostpath system:authenticated- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
					Now, all the pods that request hostPath volumes are admitted by the hostpath SCC.
				
11.8.9. Ensure That Admission Attempts to Use a Specific SCC First
					You may control the sort ordering of SCCs in admission by setting the Priority field of the SCCs. Please see the SCC Prioritization section for more information on sorting.
				
11.8.10. Add an SCC to a User, Group, or Project
					Before adding an SCC to a user or group, you can first use the scc-review option to check if the user or group can create a pod.
				
					SCCs are not granted directly to a project. Instead, you add a service account to an SCC and either specify the service account name on your pod or, when unspecified, run as the default service account.
				
To add an SCC to a user:
oc adm policy add-scc-to-user <scc_name> <user_name>
$ oc adm policy add-scc-to-user <scc_name> <user_name>To add an SCC to a service account:
oc adm policy add-scc-to-user <scc_name> \
    system:serviceaccount:<serviceaccount_namespace>:<serviceaccount_name>
$ oc adm policy add-scc-to-user <scc_name> \
    system:serviceaccount:<serviceaccount_namespace>:<serviceaccount_name>
					If you are currently in the project to which the service account belongs, you can use the -z flag and just specify the <serviceaccount_name>.
				
oc adm policy add-scc-to-user <scc_name> -z <serviceaccount_name>
$ oc adm policy add-scc-to-user <scc_name> -z <serviceaccount_name>
						Usage of the -z flag as described above is highly recommended, as it helps prevent typos and ensures that access is granted only to the specified service account. If not in the project, use the -n option to indicate the project namespace it applies to.
					
To add an SCC to a group:
oc adm policy add-scc-to-group <scc_name> <group_name>
$ oc adm policy add-scc-to-group <scc_name> <group_name>To add an SCC to all service accounts in a namespace:
oc adm policy add-scc-to-group <scc_name> \
    system:serviceaccounts:<serviceaccount_namespace>
$ oc adm policy add-scc-to-group <scc_name> \
    system:serviceaccounts:<serviceaccount_namespace>