基于k8s集群免密拉取需认证的仓库镜像

一、环境背景

1、k8s集群,1.17+,目前k8s最新版本已更新至V1.31版本;

2、镜像仓库,如harbor、registry、portus、nexus等;

3、配置镜像仓库用户登录认证,参考资料如下:

harbor参考:https://www.geekby.cn/posts/harbor-https/

registry参考:https://www.cnblogs.com/chen2ha/p/14787695.html

二、优雅拉取镜像

k8s集群内部与docker通信机制如下:

kubelet——>docker shim——>docker-daemon(grpc接口)-containerd-socket--containerd-{containerd-shim-runcontainer————(单个进程与一个容器相对应)}

当需要下载镜像时,docker根据daemon.json文件中的insecure-registries配置参数,拉取镜像。

       如果私有镜像仓库设置了用户认证,kubelet无法直接拉取镜像,在创建容器中会报错:“Failed to pull image”,查看日志定位为:访问镜像仓库失败;通过以下方法可以正常拉取私有镜像仓库镜像。

2.1基于secret方式实现

       k8s集群内置的密钥(secret)机制,可以完成此需求。

#secret分类

$ kubectl  create secret -h

Create a secret using specified subcommand.



Available Commands:

  docker-registry   创建一个给 Docker registry 使用的 secret

  generic         从本地 file, directory 或者 literal value 创建一个 secret

  tls             创建一个 TLS secret

2.1.1 创建docker-registry 类型的secret

#基于k8s集群的名字空间隔离机制,需指定名字空间(注
DVWA(Damn Vulnerable Web Application)是一个用于学习练习网络安全的靶场平台,下面是DVWA的搭建过程: 1. 安装环境: - 首先,你需要将 DVWA 下载到你的 Web 服务器上。你可以在 GitHub 上找到 DVWA 的源码。 - 将下载好的源码放置在你的 Web 服务器根目录下。 2. 配置数据库: - 打开 DVWA 文件夹中的 `config` 子文件夹,将 `config.inc.php.dist` 文件重命名为 `config.inc.php`。 - 编辑 `config.inc.php` 文件,配置数据库连接信息。输入你的 MySQL 数据库主机名、用户名、密码数据库名称,保存文件。 3. 初始化数据库: - 在浏览器中访问 DVWA 的 URL,如 `http://your-ip-address/dvwa`。 - 首次访问时,DVWA 会自动检测你的环境并引导你初始化数据库。点击 "Create / Reset Database" 按钮进行初始化。 4. 设置安全性级别: - 初始化数据库后,DVWA 会跳转到登录页面。使用默认的管理员用户名密码(admin/password)登录。 - 在 "DVWA Security" 标签页中,选择安全性级别。初始情况下,选择 `low` 级别以方便学习实践。 5. 开始使用 DVWA: - 确认安全性级别后,在 DVWA 主界面上你将看到各种漏洞挑战,比如 SQL 注入、跨站点脚本(XSS)、文件包含等。 - 选择你感兴趣的漏洞或挑战,按照提示进行测试实践。 请注意,在搭建 DVWA 靶场之前,确保你已经具备了运行 Web 服务器 MySQL 数据库的环境,并且已经正确配置了相关的服务。此外,为了安全起见,建议在局域网或虚拟机环境中使用 DVWA 进行学习实践。 希望以上信息能对你有所帮助!如果有任何其他问题,请随时提问。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值