ServiceAccount
All access requests to Kubernetes resources are processed by the API Server, regardless of whether the requests are from an external system. Therefore, the requests must be authenticated and authorized before they are sent to Kubernetes resources.
- Authentication: used for user identity authentication. Kubernetes uses different authentication mechanisms for external and internal service accounts. For details, see Authentication and ServiceAccounts.
- Authorization: used for controlling users' access to resources. Currently, the role-based access control (RBAC) mechanism is used to authorize users to access resources. For details, see RBAC.
Authentication and ServiceAccounts
Kubernetes users are classified into service accounts (ServiceAccounts) and common accounts.
- A ServiceAccount is bound to a namespace and associated with a set of credentials. When a pod is created, the token is mounted to the pod so that the pod can be called by the API server.
- Kubernetes does not have objects that represent common accounts. By default, these accounts are managed by external services. For example, CCE users are managed by Identity and Access Management (IAM).
The following only focuses on ServiceAccounts.
Similar to pods and ConfigMaps, ServiceAccounts are resources in Kubernetes and apply to independent namespaces. That is, a ServiceAccount named default is automatically created when a namespace is created.
Run the following command to view ServiceAccounts:
$ kubectl get sa NAME SECRETS AGE default 1 30d
In addition, Kubernetes automatically creates a token for a ServiceAccount. You can run the following command to query a token:
- In clusters earlier than v1.21, a token is obtained by mounting the secret of the service account to a pod. Tokens obtained this way are permanent. This approach is no longer recommended starting from version 1.21. Service accounts will stop auto creating secrets in clusters from version 1.25.
In clusters of version 1.21 or later, you can use the TokenRequest API to obtain the token and use the projected volume to mount the token to the pod. Such tokens are valid for a fixed period. When the mounting pod is deleted, the token automatically becomes invalid. For details, see Service Account Token Security Improvement.
- If you need a token that never expires, you can also manually manage secrets for service accounts. Although a permanent service account token can be manually created, you are advised to use a short-lived token by calling the TokenRequest API for higher security.
$ kubectl describe sa default Name: default Namespace: default Labels: <none> Annotations: <none> Image pull secrets: <none> Mountable secrets: default-token-vssmw Tokens: default-token-vssmw Events: <none>
In the pod definition file, you can assign a ServiceAccount to a pod by specifying an account name. If no account name is specified, the default ServiceAccount is used. When receiving a request with an authentication token, the API Server uses the token to check whether the ServiceAccount associated with the client that sends the request allows the request to be executed.
Creating a ServiceAccount
Run the following command to create a ServiceAccount:
$ kubectl create serviceaccount sa-example serviceaccount/sa-example created $ kubectl get sa NAME SECRETS AGE default 1 30d sa-example 1 2s
The token associated with the ServiceAccount has been created.
$ kubectl describe sa sa-example Name: sa-example Namespace: default Labels: <none> Annotations: <none> Image pull secrets: <none> Mountable secrets: sa-example-token-c7bqx Tokens: sa-example-token-c7bqx Events: <none>
Check the secret content. You can find the ca.crt, namespace, and token data.
Secrets are automatically created for ServiceAccounts only in clusters of version 1.23 or earlier.
$ kubectl describe secret sa-example-token-c7bqx Name: sa-example-token-c7bqx ... Data ==== ca.crt: 1082 bytes namespace: 7 bytes token: <token content>
Using a ServiceAccount in a Pod
It is convenient to use a ServiceAccount in a pod. You only need to specify the name of the ServiceAccount.
apiVersion: v1 kind: Pod metadata: name: sa-example spec: serviceAccountName: sa-example containers: - image: nginx:alpine name: container-0 resources: limits: cpu: 100m memory: 200Mi requests: cpu: 100m memory: 200Mi imagePullSecrets: - name: default-secret
Create a pod and query its details. You can see that sa-example-token-c7bqx is mounted to the pod. The pod uses the token for authentication.
The preceding example shows you the pod authentication mechanism. However, in actual deployments, for security purposes, the token mounted to a pod in a cluster of version 1.21 or later is temporary by default.
$ kubectl create -f sa-pod.yaml pod/sa-example created $ kubectl get pod NAME READY STATUS RESTARTS AGE sa-example 0/1 running 0 5s $ kubectl describe pod sa-example ... Containers: sa-example: Mounts: /var/run/secrets/kubernetes.io/serviceaccount from sa-example-token-c7bqx (ro)
You can also view the corresponding file in the pod.
$ kubectl exec -it sa-example -- /bin/sh / # cd /run/secrets/kubernetes.io/serviceaccount /run/secrets/kubernetes.io/serviceaccount # ls ca.crt namespace token
As shown above, in a containerized application, ca.crt and token can be used to access the API Server.
Then check whether the authentication takes effect. In a Kubernetes cluster, a Service named kubernetes is created for the API Server by default. The API Server can be accessed through this service.
$ kubectl get svc NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE kubernetes ClusterIP 10.247.0.1 <none> 443/TCP 34
Go to the pod and run the curl command. If the following information is displayed, you do not have the permission.
$ kubectl exec -it sa-example -- /bin/sh / # curl https://kubernetes curl: (60) SSL certificate problem: unable to get local issuer certificate More details here: https://curl.haxx.se/docs/sslcerts.html curl failed to verify the legitimacy of the server and therefore could not establish a secure connection to it. To learn more about this situation and how to fix it, please visit the web page mentioned above.
Use ca.crt and token for authentication. The specific procedure is as follows: Place ca.crt in the environment variable CURL_CA_BUNDLE, and run the curl command to specify the certificate using CURL_CA_BUNDLE. Place the token content in TOKEN and use the token to access the API Server.
# export CURL_CA_BUNDLE=/var/run/secrets/kubernetes.io/serviceaccount/ca.crt # TOKEN=$(cat /var/run/secrets/kubernetes.io/serviceaccount/token) # curl -H "Authorization: Bearer $TOKEN" https://kubernetes { "kind": "Status", "apiVersion": "v1", "metadata": { }, "status": "Failure", "message": "forbidden: User \"system:serviceaccount:default:sa-example\" cannot get path \"/\"", "reason": "Forbidden", "details": { }, "code": 403 }
As shown above, the authentication is successful, but the API Server returns cannot get path \"/\"", indicating that the API Server can be accessed only after being authorized. For details about the authorization mechanism, see RBAC.
Feedback
Was this page helpful?
Provide feedbackThank you very much for your feedback. We will continue working to improve the documentation.See the reply and handling status in My Cloud VOC.
For any further questions, feel free to contact us through the chatbot.
Chatbot