首页
/ unregistry 的项目扩展与二次开发

unregistry 的项目扩展与二次开发

2025-06-20 23:16:26作者:董宙帆

项目的基础介绍

unregistry 是一个轻量级的容器镜像注册表,它可以直接存储和服务于 Docker daemon 的存储中。该项目提供了一个 docker-pussh 命令,允许用户通过 SSH 直接将镜像推送到远程 Docker 服务器,仅传输缺失的层,从而实现快速和高效的镜像传输。

项目的核心功能

  • 直接推送:使用 docker-pussh 命令,可以直接将 Docker 镜像推送到远程服务器,无需经过任何中间注册表。
  • 高效传输:只传输远程服务器上不存在的镜像层,避免了重复传输已存在的数据。
  • 无需维护:不需要维护一个完整的注册表服务,减少了管理和安全风险。

项目使用了哪些框架或库?

unregistry 项目主要使用了以下框架或库:

  • Go:项目的主体语言,用于实现核心功能和命令行工具。
  • containerd:Docker 的一个容器运行时,unregistry 使用它作为图像存储的 backend。
  • OpenSSH:用于建立与远程服务器的安全连接,并推送镜像。

项目的代码目录及介绍

项目的代码目录结构大致如下:

unregistry/
├── .github/              # GitHub 工作流和配置文件
├── cmd/                  # 主命令行工具的实现
│   └── unregistry/
├── internal/             # 项目内部使用的库和模块
├── scripts/              # 构建和测试脚本
├── test/                 # 测试相关文件
├── .dockerignore         # Docker 镜像构建时排除的文件
├── .gitignore            # Git 忽略的文件
├── .goreleaser.yaml       # goreleaser 配置文件,用于发布版本
├── .mise.toml            # mise 配置文件,用于项目设置
├── Dockerfile            # Docker 镜像构建文件
├── Dockerfile.test       # 测试用的 Docker 镜像构建文件
├── LICENSE               # Apache-2.0 许可文件
├── README.md             # 项目说明文件
├── docker-pussh          # docker-pussh 命令行工具
└── go.mod                # Go 依赖管理文件

对项目进行扩展或者二次开发的方向

  1. 跨平台支持:目前 Windows 平台尚不支持,可以尝试增加对 Windows 的支持,或者优化 WSL 2 下的使用体验。
  2. 安全性增强:可以增加对传输过程中的加密和认证机制,提高数据的安全性。
  3. 用户界面:为 docker-pussh 工具开发一个图形用户界面(GUI),使其更加易于使用。
  4. 集成到 CI/CD:将 unregistry 集成到主流的持续集成和持续部署(CI/CD)工具中,简化自动化流程。
  5. 多租户支持:扩展 unregistry,使其支持多租户环境,为不同的用户或团队提供隔离的镜像存储空间。
登录后查看全文
热门项目推荐

项目优选

收起
kernelkernel
deepin linux kernel
C
22
6
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
164
2.05 K
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
60
16
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
952
560
apintoapinto
基于golang开发的网关。具有各种插件,可以自行扩展,即插即用。此外,它可以快速帮助企业管理API服务,提高API服务的稳定性和安全性。
Go
22
0
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.01 K
396
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
407
387
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
199
279
giteagitea
喝着茶写代码!最易用的自托管一站式代码托管平台,包含Git托管,代码审查,团队协作,软件包和CI/CD。
Go
17
0