Roles and ClusterRoles

What are Roles and ClusterRoles?

Roles and ClusterRoles in Kubernetes RBAC define sets of permissions. Roles are namespace-scoped, while ClusterRoles are cluster-wide. They specify what actions can be performed on which resources. Roles and ClusterRoles are fundamental to Kubernetes access control.

In the world of software development, containerization and orchestration have emerged as key concepts that are reshaping the way applications are built, deployed, and managed. Central to this paradigm shift are the Kubernetes concepts of Roles and ClusterRoles, which are fundamental to managing access controls within a Kubernetes environment. This glossary article will delve into the intricate details of these concepts, their history, use cases, and specific examples to provide a comprehensive understanding for software engineers.

Roles and ClusterRoles are Kubernetes resources that define a set of permissions for a user, group, or service account within a specific namespace or across all namespaces respectively. These permissions are then granted to users or service accounts via RoleBindings or ClusterRoleBindings. Understanding these concepts is crucial for managing access control and security in a Kubernetes environment.

Definition of Roles and ClusterRoles

In Kubernetes, a Role is a namespaced resource that defines permissions within a specific namespace. These permissions are defined in terms of the actions that can be performed (get, list, create, update, delete, etc.), the resources on which these actions can be performed (pods, services, etc.), and the namespace in which these actions can be performed.

On the other hand, a ClusterRole is a cluster-wide resource that defines permissions across all namespaces in a Kubernetes cluster. A ClusterRole can define the same set of permissions as a Role, but these permissions apply across all namespaces. This makes ClusterRoles particularly useful for defining permissions for cluster-wide resources or for granting permissions across multiple namespaces.

Role Structure

A Role in Kubernetes is defined using a YAML file. The structure of a Role includes metadata, rules, and optionally, aggregation rules. The metadata includes the name of the Role and the namespace in which it is defined. The rules define the permissions granted by the Role, in terms of the actions that can be performed, the resources on which these actions can be performed, and the API groups to which these resources belong.

Aggregation rules are an optional part of a Role that allow permissions from other Roles to be included in the Role. This can be useful for creating composite Roles that include permissions from multiple other Roles.

ClusterRole Structure

A ClusterRole in Kubernetes is also defined using a YAML file, and its structure is similar to that of a Role. The main difference is that a ClusterRole does not include a namespace in its metadata, as it is a cluster-wide resource. Like a Role, a ClusterRole includes rules that define the permissions granted by the ClusterRole, and optionally, aggregation rules.

Aggregation rules in a ClusterRole work in the same way as in a Role, allowing permissions from other ClusterRoles to be included in the ClusterRole. This can be useful for creating composite ClusterRoles that include permissions from multiple other ClusterRoles.

History of Roles and ClusterRoles

Roles and ClusterRoles were introduced in Kubernetes as part of the Role-Based Access Control (RBAC) system, which was added in Kubernetes 1.6. The RBAC system was designed to provide fine-grained control over access to Kubernetes resources, and Roles and ClusterRoles are central to this system.

Prior to the introduction of RBAC, Kubernetes used the Attribute-Based Access Control (ABAC) system for managing access control. However, ABAC was found to be less flexible and harder to manage than RBAC, leading to the development of the RBAC system and the introduction of Roles and ClusterRoles.

Evolution of Roles and ClusterRoles

Since their introduction, Roles and ClusterRoles have evolved to become more flexible and powerful. One of the key changes was the introduction of aggregation rules, which allow permissions from other Roles or ClusterRoles to be included in a Role or ClusterRole. This made it possible to create composite Roles and ClusterRoles, providing even more flexibility in defining permissions.

Another important change was the introduction of non-resource URLs in the rules of Roles and ClusterRoles. This allowed permissions to be defined for non-resource endpoints of the Kubernetes API, such as the health and metrics endpoints. This was a significant enhancement to the RBAC system, as it enabled fine-grained control over access to these important API endpoints.

Use Cases for Roles and ClusterRoles

Roles and ClusterRoles are used in a variety of scenarios in Kubernetes to manage access control. One common use case is to define permissions for a user or group of users. For example, a Role can be used to grant a user permissions to create, update, and delete pods in a specific namespace, while a ClusterRole can be used to grant a user permissions to list services across all namespaces.

Another common use case is to define permissions for a service account. Service accounts are used by pods to interact with the Kubernetes API, and Roles and ClusterRoles can be used to define the permissions that a service account has. For example, a Role can be used to grant a service account permissions to get and update a specific ConfigMap in a specific namespace, while a ClusterRole can be used to grant a service account permissions to list nodes across all namespaces.

Examples of Roles and ClusterRoles

Let's consider a specific example of a Role. Suppose we have a user named Alice who needs to be able to create, update, and delete pods in the namespace 'development'. We could define a Role for Alice as follows:


apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
 namespace: development
 name: pod-manager
rules:
- apiGroups: [""]
 resources: ["pods"]
 verbs: ["get", "list", "create", "update", "delete"]

This Role, named 'pod-manager', grants Alice the permissions she needs in the 'development' namespace.

Now let's consider a specific example of a ClusterRole. Suppose we have a service account named 'node-watcher' that needs to be able to list nodes across all namespaces. We could define a ClusterRole for 'node-watcher' as follows:


apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
 name: node-watcher
rules:
- apiGroups: [""]
 resources: ["nodes"]
 verbs: ["get", "list"]

This ClusterRole, named 'node-watcher', grants the 'node-watcher' service account the permissions it needs across all namespaces.

Conclusion

Roles and ClusterRoles are fundamental to managing access control in a Kubernetes environment. They provide a flexible and powerful way to define permissions for users, groups, and service accounts, both within specific namespaces and across all namespaces. Understanding these concepts is crucial for any software engineer working with Kubernetes.

Whether you're defining permissions for a user to manage pods in a specific namespace, or for a service account to list nodes across all namespaces, Roles and ClusterRoles provide the tools you need. With a deep understanding of these concepts, you'll be well-equipped to manage access control in your Kubernetes environment.

Join other high-impact Eng teams using Graph
Ready to join the revolution?
Join other high-impact Eng teams using Graph
Ready to join the revolution?

Build more, chase less

Add to Slack