最小化微服务漏洞 Secret存储敏感数据

网友投稿 1165 2022-11-30

最小化微服务漏洞 Secret存储敏感数据

最小化微服务漏洞 Secret存储敏感数据

Secret是一个用于存储敏感数据的资源,所有的数据要经过base64编码,数据实际会存储在k8s中Etcd, 然后通过创建Pod时引用该数据。

应用场景:凭据

Pod使用configmap数据有两种方式:

• 变量注入

• 数据卷挂载

kubectl create secret 支持三种数据类型:

• docker-registry:存储镜像仓库认证信息

• generic:从文件、目录或者字符串创建,例如存储用户名密码

• tls:存储证书,例如HTTPS证书

示例:将Mysql用户密码保存到Secret中存储

下面就是123456经过base64位编码,-n是去掉换行符

[root@k8s-master ~]# echo -n 123456 | base64MTIzNDU2

通过这种方式在yaml文件里面来指定mysql的密码现然是不安全的,mysql可以读取注入的变量MYSQL_ROOT_PASSWORD值作为其密码,以为describe一下就能够看得到。

env: - name: MYSQL_ROOT_PASSWORD value: 123456

[root@k8s-master ~]# cat mysql.yaml apiVersion: v1kind: Secretmetadata: name: mysqltype: Opaquedata: mysql-root-password: "MTIzNDU2"---apiVersion: apps/v1kind: Deploymentmetadata: name: mysqlspec: selector: matchLabels: app: mysql template: metadata: labels: app: mysql spec: containers: - name: db image: mysql:5.7.30 env: - name: MYSQL_ROOT_PASSWORD valueFrom: secretKeyRef: name: mysql key: mysql-root-password[root@k8s-master ~]# kubectl get secretNAME TYPE DATA AGEdefault-token-j9294 kubernetes.io/service-account-token 3 239dmysql Opaque 1 7m24s[root@k8s-master ~]# kubectl describe secret mysqlName: mysqlNamespace: defaultLabels: Annotations: Type: OpaqueData====mysql-root-password: 6 bytes[root@k8s-master ~]# kubectl get podNAME READY STATUS RESTARTS AGEmysql-5467bf5d7d-g67dm 1/1 Running 0 6m27s[root@k8s-master ~]# kubectl exec -it mysql-5467bf5d7d-g67dm bashkubectl exec [POD] [COMMAND] is DEPRECATED and will be removed in a future version. Use kubectl exec [POD] -- [COMMAND] instead.root@mysql-5467bf5d7d-g67dm:/# echo $MYSQL_ROOT_PASSWORD123456root@mysql-5467bf5d7d-g67dm:/# mysql -rroot -p123456mysql: [Warning] Using a password on the command line interface can be insecure.Welcome to the MySQL monitor. Commands end with ; or \g.Your MySQL connection id is 2Server version: 5.7.30 MySQL Community Server (GPL)Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respectiveowners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql>

要查看具体的值可以使用如下:

[root@k8s-master ~]# kubectl get secret mysql -n default -o jsonpath={.data.mysql-root-password} | base64 -d123456

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:K8s Pod Security Policy实践
下一篇:Kubernetes 最小化微服务漏洞 安全沙箱运行容器:gVisor介绍与安装
相关文章

 发表评论

暂时没有评论,来抢沙发吧~