Exploring RBAC Authorization
This lesson introduces the RBAC authorization components to us.
We'll cover the following
The RBAC Components
Managing Kubernetes RBAC requires knowledge of a few elements. Specifically, we should learn about Rules, Roles, Subjects, and RoleBindings.
Rules
A Rule is a set of operations (verbs), resources, and API groups. Verbs describe activities that can be performed on resources which belong to different API Groups.
Permissions defined through Rules are additive. We cannot deny access to some resources.
Currently supported verbs are as follows.
Verb | Description |
---|---|
get |
Retrieves information about a specific object |
list |
Retrieves information about a collection of objects |
create |
Creates a specific object |
update |
Updates a specific object |
patch |
Patches a specific object |
watch |
Watches for changes to an object |
proxy |
Proxies requests |
redirect |
Redirects requests |
delete |
Deletes a specific object |
deletecollection |
Deletes a collection of objects |
If, for example, we’d like to allow a user only to create objects and retrieve their information, we’d use the verbs get
, list
and create
. A verb can be an asterisk (*
), thus allowing all verbs (operations).
Verbs are combined with Kubernetes resources. For example, if we’d like to allow a user only to create Pods and retrieve their information, we’d mix get
, list
and create
verbs with the pods
resource.
The last element of a Rule is the API Group. RBAC uses the rbac.authorization.k8s.io
group. If we’d switch to a different authorization method, we’d need to change the group as well.
Roles
A Role is a collection of Rules. It defines one or more Rules that can be bound to a user or a group of users.
The vital aspect of Roles is that they are applied to a Namespace. If we’d like to create a role that refers to a whole cluster, we’d use ClusterRole instead. Both are defined in the same way, and the only difference is in the scope (Namespace or an entire cluster).
Subjects
The next piece of the authorization mechanism is Subjects.
Subjects define entities that are executing operations. A Subject can be a User, a Group, or a Service Account.
A User is a person or a process residing outside a cluster. A Service Account is used for processes running inside Pods that want to use the API. Since this chapter focuses on human authentication, we won’t explore them right now. Finally, Groups are collections of Users or Service Accounts. Some Groups are created by default (e.g., cluster-admin
).
RoleBindings
Finally, we need RoleBindings.
As the name suggests, RoleBindings bind Subjects to Roles.
Since Subjects define users, RoleBindings effectively bind users (or Groups or Service Accounts) to Roles, thus giving them permissions to perform certain operations on specific objects within a Namespace. Just like roles, RoleBindings have a cluster-wide alternative called ClusterRoleBindings. The only difference is that their scope is not limited to a Namespace, but applied to a whole cluster.
Get hands-on with 1400+ tech skills courses.