资讯专栏INFORMATION COLUMN

secrets in kubernetes

NSFish / 3388人阅读

摘要:目前只支持使用来自于的。现在我们能创建使用这个的当这个中的运行后,将会有如下两个文件及对应的内容现在可以用这个数据来建立连接。

在kubernetes中,secret对象类型主要目的是 保存一些私密数据,比如密码,OAuth tokens,ssh keys等信息。将这些信息放在secret对象中 比 直接放在pod或docker image中更安全,也更方便使用。

secrets描述

创建secrets对象的方式有两种,一种是用户手动创建,另一种是集群自动创建。

一个已经创建好的secrets对象有两种方式被pod对象使用,其一,在container中的volume对象里以file的形式被使用,其二,在pull images时被kubelet使用。

为了使用secret对象,pod必须‘引用’这个secret,同样可以手动或者自动来执行‘引用’操作。

自动建立ServiceAccount && 使用secret API

kubernetes会自动创建包含证书信息的secret,并且使用它来访问api,kubernetes也将自动修改pod来使用这个secret。

自动创建的secret 以及 所使用的api证书 可以根据需要disable 或者 覆盖。如果仅仅需要 安全访问apiserver,那么上述的流程是推荐的方式。

手动创建secret

以下是一个简单secret对象的例子:

</>复制代码

  1. apiVersion: v1
  2. kind: Secret
  3. metadata:
  4. name: mysecret
  5. type: Opaque
  6. data:
  7. password: dmFsdWUtMg0K
  8. username: dmFsdWUtMQ0K

数据中的字段为map类型。其中keys必须符合dns_subdomain规则,values可以为任意类型,使用base64编码。上述例子中,username和password的数据值在base64编码前的值为value-1 和 value-2。

一旦secret被创建,可以:

通过ServiceAccount使用它自动创建pod;

修改pod来使用secret;

手动为pod绑定secret

以下是一个例子,绑定secret到一个pod的volume:

</>复制代码

  1. {
  2. "apiVersion": "v1",
  3. "kind": "Pod",
  4. "metadata": {
  5. "name": "mypod",
  6. "namespace": "myns"
  7. },
  8. "spec": {
  9. "containers": [{
  10. "name": "mypod",
  11. "image": "redis",
  12. "volumeMounts": [{
  13. "name": "foo",
  14. "mountPath": "/etc/foo",
  15. "readOnly": true
  16. }]
  17. }],
  18. "volumes": [{
  19. "name": "foo",
  20. "secret": {
  21. "secretName": "mysecret"
  22. }
  23. }]
  24. }
  25. }

注意,必须有spec.volumes才能使用secret。
如果一个pod中有多个container,每个container需要他们多带带对应的volumeMounts ,但是一个secret只能对应一个spec.volumes。

只要需要,可以将许多文件打包进一个secret,或者使用多个secret。

手动指定imagePullSecret

详细信息见:images documentation

Details 限制

在使用之前,secret volume 资源被验证,以确保指定的对象引用真是指向一个secret对象。因此,在pod使用它之前必须保证需要的secret被成功创建。

secret api对象从属于namespace,一个secret对象只能被同namespace的pod所使用。

单个secret限制在1Mb之内,防止过大的secret耗尽apiserver & kubelet的内存。然而,创建许多类似的secret同样也会无用的消耗掉apiserver&kubelet的内存。

kubelet目前只支持pod使用来自于apiserver的secret。pods包括了被 kubectl创建的pod 或者 被replication controller间接创建的。

Consuming Secret Values

在一个绑定了secret的container中,会以secret keys为名的文件,其内容为secret value的base64 decode后的内容。下面是上述例子的输出:

</>复制代码

  1. $ ls /etc/foo/
  2. username
  3. password
  4. $ cat /etc/foo/username
  5. value-1
  6. $ cat /etc/foo/password
  7. value-2

container中的程序可以读取其中的文件来获取其内容。

Secret 与 Pod Lifetime 关系

当通过api创建一个pod后,不会去检查所引用的secret是否存在。一旦这个pod被使用,kubelet将会尝试去获取引用的secret的值。如果这个secret不存在,或者kubelet暂时链接不上apiserver,kubelet将会定期重试,并发送一个event来解释pod没有启动的原因。如果获取到了对应的secret,kubelet将会创建对应的volume并绑定到container。

一旦kubelet创建了一个pod,则container使用的相关secret volume不会在改变,即使对应的secret对象被修改。如果为了改变使用的secret,则必须删除旧的pod,并重新创建一个新的pod。

User Case Use-Case: Pod with ssh keys

pod通过secret来使用ssh-key,首先得先创建对应的secret:

</>复制代码

  1. {
  2. "kind": "Secret",
  3. "apiVersion": "v1",
  4. "metadata": {
  5. "name": "ssh-key-secret"
  6. },
  7. "data": {
  8. "id-rsa": "dmFsdWUtMg0KDQo=",
  9. "id-rsa.pub": "dmFsdWUtMQ0K"
  10. }
  11. }

Note:其中secret的data数据经过base64编码,不包含换行符。

现在我们能创建使用这个secret的pod:

</>复制代码

  1. {
  2. "kind": "Pod",
  3. "apiVersion": "v1",
  4. "metadata": {
  5. "name": "secret-test-pod",
  6. "labels": {
  7. "name": "secret-test"
  8. }
  9. },
  10. "spec": {
  11. "volumes": [
  12. {
  13. "name": "secret-volume",
  14. "secret": {
  15. "secretName": "ssh-key-secret"
  16. }
  17. }
  18. ],
  19. "containers": [
  20. {
  21. "name": "ssh-test-container",
  22. "image": "mySshImage",
  23. "volumeMounts": [
  24. {
  25. "name": "secret-volume",
  26. "readOnly": true,
  27. "mountPath": "/etc/secret-volume"
  28. }
  29. ]
  30. }
  31. ]
  32. }
  33. }

当这个pod中的container运行后,将会有如下两个文件及对应的内容:

</>复制代码

  1. /etc/secret-volume/id-rsa.pub
  2. /etc/secret-volume/id-rsa

现在container可以用这个secret数据来建立ssh连接。

Use-Case: Pods with prod / test credentials

下面的例子将会展示 一个pod使用包含prod环境证书的secret对象,另一个pod使用包含test环境证书的secret对象:

secret对象:

</>复制代码

  1. {
  2. "apiVersion": "v1",
  3. "kind": "List",
  4. "items":
  5. [{
  6. "kind": "Secret",
  7. "apiVersion": "v1",
  8. "metadata": {
  9. "name": "prod-db-secret"
  10. },
  11. "data": {
  12. "password": "dmFsdWUtMg0KDQo=",
  13. "username": "dmFsdWUtMQ0K"
  14. }
  15. },
  16. {
  17. "kind": "Secret",
  18. "apiVersion": "v1",
  19. "metadata": {
  20. "name": "test-db-secret"
  21. },
  22. "data": {
  23. "password": "dmFsdWUtMg0KDQo=",
  24. "username": "dmFsdWUtMQ0K"
  25. }
  26. }]
  27. }

建立pods:

</>复制代码

  1. {
  2. "apiVersion": "v1",
  3. "kind": "List",
  4. "items":
  5. [{
  6. "kind": "Pod",
  7. "apiVersion": "v1",
  8. "metadata": {
  9. "name": "prod-db-client-pod",
  10. "labels": {
  11. "name": "prod-db-client"
  12. }
  13. },
  14. "spec": {
  15. "volumes": [
  16. {
  17. "name": "secret-volume",
  18. "secret": {
  19. "secretName": "prod-db-secret"
  20. }
  21. }
  22. ],
  23. "containers": [
  24. {
  25. "name": "db-client-container",
  26. "image": "myClientImage",
  27. "volumeMounts": [
  28. {
  29. "name": "secret-volume",
  30. "readOnly": true,
  31. "mountPath": "/etc/secret-volume"
  32. }
  33. ]
  34. }
  35. ]
  36. }
  37. },
  38. {
  39. "kind": "Pod",
  40. "apiVersion": "v1",
  41. "metadata": {
  42. "name": "test-db-client-pod",
  43. "labels": {
  44. "name": "test-db-client"
  45. }
  46. },
  47. "spec": {
  48. "volumes": [
  49. {
  50. "name": "secret-volume",
  51. "secret": {
  52. "secretName": "test-db-secret"
  53. }
  54. }
  55. ],
  56. "containers": [
  57. {
  58. "name": "db-client-container",
  59. "image": "myClientImage",
  60. "volumeMounts": [
  61. {
  62. "name": "secret-volume",
  63. "readOnly": true,
  64. "mountPath": "/etc/secret-volume"
  65. }
  66. ]
  67. }
  68. ]
  69. }
  70. }]
  71. }

建立的两个pod都拥有两个文件:

</>复制代码

  1. /etc/secret-volume/username
  2. /etc/secret-volume/password

可以使用service accounts来简化上述的流程,一个是prod-user对应prod-db-secret,另一个是test-user对应test-db-secret,如:

</>复制代码

  1. {
  2. "kind": "Pod",
  3. "apiVersion": "v1",
  4. "metadata": {
  5. "name": "prod-db-client-pod",
  6. "labels": {
  7. "name": "prod-db-client"
  8. }
  9. },
  10. "spec": {
  11. "serviceAccount": "prod-db-client",
  12. "containers": [
  13. {
  14. "name": "db-client-container",
  15. "image": "myClientImage",
  16. }
  17. ]
  18. }

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/32435.html

相关文章

  • Kubernetes持续集成:Jenkins关于java.nio.file.NoSuchFileEx

    摘要:尝试运行脚本发生了的错误。错误信息接下来就是,天的调查,关于这个错误的能查到的资料几乎没有,也尝试了很多方法,无果非常煎熬。问题解决了参考文档初试使用完成持续构建与发布集群安全配置 背景 为了使用Kubernetes管理并自动化部署应用程序,领导纠结了几个同事搭了一个Kubernetes集群环境。不过,为了减少复杂度,采用了非官方推荐的方式: API Server使用http方式 不...

    tomener 评论0 收藏0
  • kubernetes安装dashboard

    摘要:前言在安装搭建的时候,往往会遇到各种各样的问题,而安装的展示组件则是困难中的困难,本人在实际搭建中则被整整卡住了天,和百度轮番搜索,各种技术博客和技术视频反复研究才勉强搭建成功开始安装在安装好集群之后,确保集群各个节点都处于状态的时候,就 前言 在安装搭建k8s的时候,往往会遇到各种各样的问题,而安装k8s的web展示组件kubernetes-dashboard则是困难中的困难,本人在...

    Guakin_Huang 评论0 收藏0
  • kubernetes安装dashboard

    摘要:前言在安装搭建的时候,往往会遇到各种各样的问题,而安装的展示组件则是困难中的困难,本人在实际搭建中则被整整卡住了天,和百度轮番搜索,各种技术博客和技术视频反复研究才勉强搭建成功开始安装在安装好集群之后,确保集群各个节点都处于状态的时候,就 前言 在安装搭建k8s的时候,往往会遇到各种各样的问题,而安装k8s的web展示组件kubernetes-dashboard则是困难中的困难,本人在...

    darryrzhong 评论0 收藏0
  • Kubernetes之dashboard 2.x 部署

    摘要:开始部署项目地址创建证书创建命名空间创建文件证书请求自签证书,指定证书的有效期天数。赋权,并复制,并登录换成你环境的即可 开始部署Gitlab 项目地址:https://github.com/kubernetes/dashboard1) 创建证书:mkdir dashboard-certscd dashboard-cert...

    番茄西红柿 评论0 收藏2637
  • 【容器云 UK8S】最佳实践:权限管理之了解RBAC和权限管理实践

    摘要:本文介绍了模型中四个最主要的对象,即,大致了解了的工作原理和使用方法,如果要更加深入地了解和掌握,可以查看官方文档。只是这个不能复用到其他,一般只有在做精细化权限管理的时候,我们才会创建对象,比如一个只能查看名称为的。了解RBAC简介RBAC是一种基于角色来管理对计算机或网络资源访问策略的方法。我们知道,对K8S内所有API对象的操作都是通过访问kube-apiserver来完成的,因此ku...

    Tecode 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<