Day-43: Role-Based Access Control (RBAC) in Kubernetes

Day-43: Role-Based Access Control (RBAC) in Kubernetes

RBAC (Role-Based Access Control) ek powerful method hai jiske through aap apne Kubernetes cluster mein access control implement kar sakte hain. Yeh mechanism ensure karta hai ki different users ya groups ke paas sirf wohi permissions ho jo unhe assign ki gayi hain. Chaliye iske components, working, aur use cases ke baare mein detail mein samajhte hain.

1. RBAC Kya Hai?

RBAC ka full form hai Role-Based Access Control. Yeh ek authorization mechanism hai jo aapko permissions define karne aur in permissions ko specific users ya groups ke sath map karne ki suvidha deta hai. Iska use aap Kubernetes cluster mein resources par fine-grained control provide karne ke liye karte hain.

RBAC ka main idea:

  • Roles define karte hain ki kya actions allow hain.

  • Bindings define karte hain ki kaun woh roles use kar sakta hai.

2. RBAC ke Components

RBAC ke kuch key components hote hain jo access control ko define karte hain:

a. Role

Role ek set of permissions hota hai jo aapko specify karne deta hai ki ek user ya service account cluster ke resources ke sath kaunse actions perform kar sakta hai.

  • Example:

      kind: Role
      apiVersion: rbac.authorization.k8s.io/v1
      metadata:
        namespace: default
        name: pod-reader
      rules:
      - apiGroups: [""]
        resources: ["pods"]
        verbs: ["get", "watch", "list"]
    

Is example mein, ek Role define kiya gaya hai jisme pods resources par get, watch, aur list actions allow hain.

b. ClusterRole

ClusterRole similar hota hai Role se, lekin yeh cluster-wide permissions ke liye use hota hai. Matlab, yeh cluster ke sabhi namespaces mein apply hota hai.

  • Example:

      kind: ClusterRole
      apiVersion: rbac.authorization.k8s.io/v1
      metadata:
        name: cluster-admin
      rules:
      - apiGroups: [""]
        resources: ["*"]
        verbs: ["*"]
    

Yeh ClusterRole cluster ke sabhi resources par har action perform karne ki permission deta hai.

c. RoleBinding

RoleBinding ek mapping hota hai jo ek Role ko specific users, groups, ya service accounts ke sath associate karta hai.

  • Example:

      kind: RoleBinding
      apiVersion: rbac.authorization.k8s.io/v1
      metadata:
        name: read-pods
        namespace: default
      subjects:
      - kind: User
        name: "jane"
        apiGroup: rbac.authorization.k8s.io
      roleRef:
        kind: Role
        name: pod-reader
        apiGroup: rbac.authorization.k8s.io
    

Is example mein, jane user ko pod-reader Role assign kiya gaya hai jo sirf default namespace mein apply hoga.

d. ClusterRoleBinding

ClusterRoleBinding similar hota hai RoleBinding se, lekin yeh cluster-wide roles ko bind karta hai.

  • Example:

      kind: ClusterRoleBinding
      apiVersion: rbac.authorization.k8s.io/v1
      metadata:
        name: cluster-admin-binding
      subjects:
      - kind: User
        name: "admin"
        apiGroup: rbac.authorization.k8s.io
      roleRef:
        kind: ClusterRole
        name: cluster-admin
        apiGroup: rbac.authorization.k8s.io
    

Yeh admin user ko cluster-wide cluster-admin permissions assign karta hai.

3. RBAC Ki Working

RBAC ko enable karne ke baad, Kubernetes API server har incoming request ko evaluate karta hai aur check karta hai ki kya requesting user ke paas us specific action ko perform karne ke liye required permissions hain.

  • Agar user ke paas required permissions hain, to request allow ki jati hai.

  • Agar permissions nahi hain, to request deny kar di jati hai.

4. RBAC Ke Use Cases

RBAC ko aap alag-alag scenarios mein use kar sakte hain, jaise:

  • Namespace Isolation: Alag-alag teams ke liye alag namespaces create karke unhe specific roles assign kar sakte hain.

  • Service Accounts ke Liye Permissions: Specific service accounts ke liye limited permissions assign karna, jaise ki ek service account sirf pods create kar sake lekin delete nahi.

  • Cluster-Wide Admins: Cluster administrators ko full access dena without compromising the security of other resources.

5. RBAC Implement Karne Ke Steps

RBAC ko implement karne ke liye aapko kuch steps follow karne hote hain:

  1. Identify Roles: Pehle decide karein ki cluster mein different users ke liye kya roles hone chahiye.

  2. Create Roles/ClusterRoles: In roles ko define karne ke liye Role ya ClusterRole objects banayein.

  3. Create Bindings: RoleBinding ya ClusterRoleBinding ke through in roles ko specific users ya groups ke sath bind karein.

  4. Test Access: Test karein ki users ke paas expected permissions hain ya nahi.

6. RBAC Configuration Example

Yeh ek simple configuration example hai jisme ek Role aur RoleBinding define kiya gaya hai:

apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
  namespace: default
  name: pod-reader
rules:
- apiGroups: [""]
  resources: ["pods"]
  verbs: ["get", "watch", "list"]

---
apiVersion: rbac.authorization.k8s.io/v1
kind: RoleBinding
metadata:
  name: read-pods
  namespace: default
subjects:
- kind: User
  name: "jane"
  apiGroup: rbac.authorization.k8s.io
roleRef:
  kind: Role
  name: pod-reader
  apiGroup: rbac.authorization.k8s.io

Is configuration mein jane user ko pod-reader Role assign kiya gaya hai jo usse default namespace mein pods ko dekhne ki permission deta hai.

7. Conclusion

RBAC Kubernetes mein ek critical role play karta hai, kyunki yeh aapko fine-grained access control define karne ki facility deta hai. Iske through aap ensure kar sakte hain ki aapke cluster mein security properly enforced ho aur har user ke paas sirf wohi permissions ho jo unhe genuinely chahiye.

RBAC ki yeh capabilities aapke cluster ke security posture ko enhance karti hain aur aapko ek flexible aur manageable way provide karti hain to control who can do what within your Kubernetes environment.

Connect and Follow Me on Socials

LINKDIN | GITHUB |TWITTER