Authentication – How User’s access should be allowed? The process or action of verifying the identity of a user or process.
Authorization – What Access and till what extent should be accessible to user
Official ref for Authentication
- https://kubernetes.io/docs/reference/access-authn-authz/authentication/
Method of Authentication in kubernetes
- Certificate
- Token
- OpenID
- Web Hook
data:image/s3,"s3://crabby-images/af722/af722e833a0fd0d0f73f29a03422a921b62a2637" alt=""
How Certificate Based Auth Works in kubernetes?
- User (or administrator on behalf of user) creates a private key.
- User/administrator generates a certificate signing request (CSR).
- Administrator approves the request and signs it with their CA.
- Administrator provides the resulting certificate back to the user.
data:image/s3,"s3://crabby-images/792b0/792b031f8fb5938a2e2bcd62f9d0979fef07ea68" alt=""
data:image/s3,"s3://crabby-images/bc213/bc2136b4980e170773e2360d17855de2d40c331e" alt=""
How Token Based Auth Works in kubernetes?
data:image/s3,"s3://crabby-images/bc5ff/bc5ff69a0da83910bfb605fd8ef82c699354b737" alt=""
How to create user in kubernetes?
# USER run these commands in Workstation
# Create a pvt key
$ openssl genrsa -out employee.key 2048
# Create CSR file
$ openssl req -new -key employee.key -out employee.csr -subj "/CN=employee/O=bitnami"
# How to send a CSR file to CA (Master Admin or K8s admin)
- Send via manual way eg. email
- csr api
# Admin run these commands in Workstation
$ openssl x509 -req -in employee.csr -CA /etc/kubernetes/pki/ca.crt -CAkey /etc/kubernetes/pki/ca.key -CAcreateserial -out employee.crt -days 500
# Admin would send employee.crt to USER.
- Send via manual way eg. email
- csr api - they can download self
# USER would set employee.key & employee.crt in CONFIG file.
$ kubectl config set-credentials employee --client-certificate=/root/employee.crt --client-key=/root/employee.key
$ kubectl config view
$ kubectl config set-context employee-context --cluster=kubernetes --namespace=office --user=employee
$ kubectl config view
$ kubectl create namespace office
$ kubectl --context=employee-context get pods
[root@rajesh ~]# kubectl --context=employee-context get pods
Error from server (Forbidden): pods is forbidden: User "employee" cannot list resource "pods" in API group "" in the namespace "office"
# Only we have enabled employee authentication. He has no rights on K8s.
What are the Methods of Authorization in kubernetes?
- Node
- ABAC
- RBAC [ FOCUS ]
- Webhook
Official ref for Authorization
- https://kubernetes.io/docs/reference/access-authn-authz/authorization/
How to Authorized user in kubernetes clustor?
WHOM – USER or GROUP
WHAT – verbs: [“get”, “list”, “watch”, “create”, “update”, “patch”, “delete”] # You can also use [“*”]
WHERE – API Resources or API Group $ kubectl api-resources
How???
- Node
- ABAC
- RBAC [ FOCUS ]
- Webhook
How RBAC works in kubernetes?
data:image/s3,"s3://crabby-images/4e9d6/4e9d650b73ded2b71c368e59425d4e7f42406b11" alt=""
data:image/s3,"s3://crabby-images/c86d8/c86d8614cb9f7cc52ca39dd5c2f4e439c233a7c0" alt=""
data:image/s3,"s3://crabby-images/1522e/1522e1db7bb377574e5ddeea0165613603cf2c19" alt=""
data:image/s3,"s3://crabby-images/80921/80921a0996472b5ce8a89467182758e23455915d" alt=""
data:image/s3,"s3://crabby-images/f984a/f984a5ce7c3fa858a1aacaadce05f1a43c17b057" alt=""
data:image/s3,"s3://crabby-images/371c5/371c5a69c8aa5e8a7e08eecdb560b3e6d32db2b9" alt=""
data:image/s3,"s3://crabby-images/f8cdf/f8cdf884df6cb67f48fde6dd76e095db9b63af9e" alt="loading"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/60811/608119e2f97de8dde2c87ee9131bcfb609352ab5" alt="play"
data:image/s3,"s3://crabby-images/f8cdf/f8cdf884df6cb67f48fde6dd76e095db9b63af9e" alt="loading"
I’m a DevOps/SRE/DevSecOps/Cloud Expert passionate about sharing knowledge and experiences. I am working at Cotocus. I blog tech insights at DevOps School, travel stories at Holiday Landmark, stock market tips at Stocks Mantra, health and fitness guidance at My Medic Plus, product reviews at I reviewed , and SEO strategies at Wizbrand.
Please find my social handles as below;
Rajesh Kumar Personal Website
Rajesh Kumar at YOUTUBE
Rajesh Kumar at INSTAGRAM
Rajesh Kumar at X
Rajesh Kumar at FACEBOOK
Rajesh Kumar at LINKEDIN
Rajesh Kumar at PINTEREST
Rajesh Kumar at QUORA
Rajesh Kumar at WIZBRAND