当前位置: 首页 > news >正文

使用阿里云 ESA 边缘函数转发代理 docker registry

ESA Docker Registry Proxy

这是一个基于 Alibaba ESA (Edge Security Acceleration) 的 Docker Registry 转发代理,为中国大陆用户提供更快的 Docker 镜像下载服务,并实现镜像白名单功能以增强安全性。

开源地址: https://github.com/jqknono/esa-registry-proxy

功能特性

  1. Docker Registry 代理: 转发 Docker Hub 请求,提升中国大陆用户下载速度
  2. 镜像白名单: 限制只能下载指定的镜像,提高安全性
  3. 支持多种匹配模式: 支持精确匹配和前缀匹配
  4. 智能缓存机制: 优先使用缓存数据,减少重复请求,提高响应速度

快速开始

前提条件

  • Node.js 16+
  • npm 或 yarn
  • Alibaba ESA 账号及 AccessKey ID 和 Secret

安装部署

  1. 克隆项目:

    git clone https://github.com/jqknono/esa-registry-proxy
    

部署到 Alibaba ESA

方法一:使用 ESA CLI (推荐)

  1. 安装 ESA CLI:

    npm install esa-cli -g
    
  2. 登录 ESA:

    esa login
    
  3. 初始化项目:

    esa init
    
  4. 提交代码:

    esa commit
    
  5. 部署函数:

    esa deploy
    
  6. 绑定域名:

    esa domain add registry.jqknono.com
    

方法二:手动部署

请参考 DEPLOYMENT.md 文件获取详细的手动部署说明。

白名单功能详解

白名单功能是本项目的核心安全特性,可以限制允许通过代理拉取的 Docker 镜像,防止恶意使用。

白名单配置格式

白名单配置为逗号分隔的字符串,每个字符串代表一个允许下载的镜像名称模式:

WHITELIST=library/nginx,library/redis,library/*

支持的匹配模式

  • 精确匹配: 如 library/nginx,只允许下载完全匹配的镜像
  • 前缀匹配: 如 library/*,允许下载所有 library 组织的镜像

配置示例

# 只允许官方nginx和redis镜像
WHITELIST=library/nginx,library/redis# 允许所有官方镜像
WHITELIST=library/*# 允许特定组织的所有镜像
WHITELIST=jqknono/*

使用方式

直接使用

docker pull registry.jqknono.com/library/nginx

配置 Docker 客户端

在 Docker 配置中添加镜像仓库:

{"registry-mirrors": ["https://registry.jqknono.com"]
}

技术实现

  • 利用 Alibaba ESA 的边缘网络加速镜像拉取
  • 支持 Docker Registry v2 API
  • 实现镜像白名单安全控制
  • 利用 ESA Cache API 实现智能缓存,优先使用缓存数据,缓存时间为服务允许的最大值(一年)

注意事项

  • 此项目主要用于个人开发环境或小型团队使用
  • 大规模生产环境建议使用专业的镜像仓库服务
  • 请确保您的 Alibaba ESA 账户有足够的配额

参考

  • 边缘安全加速 ESA 开发参考
  • 边缘函数 API
  • repo: alibabacloud-esa-cli
  • repo: cloudflare-registry-proxy
  • 赞助: AdguardPrivate - 你的私人 DNS 服务
http://www.lryc.cn/news/597345.html

相关文章:

  • OpenLayers 快速入门(十)常用 API 补充
  • 量化金融简介(附电子书资料)
  • 分布式系统中的缓存设计与应用
  • 三步实现Android系统级集成:预装Google TTS + 默认引擎设置 + 语音包预缓存方案
  • AI助力,轻松实现人声分离伴奏提取
  • 【金融机器学习】第五章:最优投资组合——Bryan Kelly, 修大成(中文翻译)
  • 手机开启16k Page Size
  • 大模型【进阶】(四)QWen模型架构的解读
  • SpringBoot07-数据层的解决方案:SQL
  • FireFox一些设置
  • latex中既控制列内容位置又控制列宽,使用>{\centering\arraybackslash}p{0.85cm}
  • OpenLayers 快速入门(二)Layer 对象
  • 深入掌握 Python 面向对象的灵魂——魔法函数(Magic / Dunder Methods)全景指南
  • CAN的终端电阻
  • 设计模式代码总结
  • 用 PyTorch 实现全连接网络识别 MNIST 手写数字
  • Android插件化实现方案深度分析
  • window下c++共享内存,进程互斥锁。
  • macOS配置maven及报错处理:zsh: permission denied: mvn
  • 大厂总结常用分析问题方法之CMMI-IDEAL模型
  • VRRP技术-设备备份技术
  • Modbus TCP转Devicenet:水泥厂PLC与多类仪表的自动化通信实践
  • 学习 Flutter(五):玩安卓项目实战 - 下
  • 2025年7月一区SCI-投影迭代优化算法Projection Iterative Methods-附Matlab免费代码
  • Flutter学习笔记(四)---基础Widget
  • 如何解决pip安装报错ModuleNotFoundError: No module named ‘jupyter’问题
  • OSPF路由协议——上
  • 2025.7.15vlan作业
  • vscode怎么安装MINGW
  • Linux下SVN常用指令