首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >绿联 NAS(DH4300 Plus)上部署私有 Git 仓库

绿联 NAS(DH4300 Plus)上部署私有 Git 仓库

作者头像
云水木石
发布2025-12-25 11:08:23
发布2025-12-25 11:08:23
560
举报
文章被收录于专栏:信创系统开发信创系统开发

在《老登的新玩具:NAS》一文中,我简单介绍了新购置的 NAS 设备。最初入手 NAS 的主要目的,其实很单纯——备份照片,同时作为家庭影视库使用。前段时间也确实“物尽其用”,补完了不少经典电影和美剧。

但副作用也很明显:一连几周,公众号几乎停更,技术研究也被搁置到了一旁。好在待看片单已经清空,现在终于可以把注意力重新拉回到正事上,认真思考一下 NAS 还能发挥哪些价值。

NAS 的用途很多,而我首先想到的,就是用它来搭建一个私有的 Git 代码仓库。

目前市面上的 Git 托管服务非常成熟,国外有 GitHub、GitLab,国内也有 Gitee、Coding 等选择。这些平台大多提供免费的私有仓库,稳定性、可用性和运维保障都相当成熟。从“省心”的角度来看,似乎并没有自己部署 Git 服务的必要。

但问题也恰恰出在这里。

对于个人用户而言,这类托管平台通常都会对仓库容量设定上限,常见的限制是 1G,github 比较大气一些,也不超过 10 GB。而我目前基于 Chromium 进行浏览器产品开发,即便不导入完整的 Chromium Git 历史,仅保留源码本身,加上构建所需的一系列二进制工具,整体体积也早已超过 10 GB。如果要导入完整的 Chromium Git 历史,那容量要直奔 100G 了。

所以,mojo-browser 项目只能长期存放在本地开发机上,既不便于多设备协作,也缺乏可靠的备份机制。

现在有了大容量的 NAS,貌似有了新的解决方案。一方面,NAS 的存储空间足够充裕,完全可以承载这类“重量级”代码仓库;另一方面,NAS 本身可以配置定期自动备份,无论是硬盘故障还是误操作,都能多一层数据安全保障。

Git 软件选择

市面上成熟的 Git 服务器实现并不少,我最先考虑的是 GitLab。一方面是因为在日常工作中在使用,对其功能比较熟悉;另一方面,GitLab 在权限管理、CI/CD、审计和生态完整性方面确实非常强大。

但在进一步调研之后,我很快意识到:GitLab 并不适合部署在 NAS 这类轻量级设备上

GitLab 并不是一个“单体服务”,而是一整套复杂的服务集群,核心组件就包括 PostgreSQL、Redis、Sidekiq、Gitaly、Prometheus 等。这些组件对 CPU 性能、内存容量以及磁盘 IOPS 都比较敏感,哪怕只是小规模自用,也很难算得上“轻量”。

官方给出的硬件要求如下:

项目

官方最低要求

实际推荐

CPU

4 核

4–8 核

内存

4 GB

8 GB 及以上

硬盘

10 GB 以上

20–50 GB

而我使用的绿联 DH4300 Plus 搭载的是 ARM 架构的 RK3588C 处理器,8 核 8 线程,主频 1.8 GHz,内存为 8 GB。在这台设备上运行 GitLab,大概率会出现响应迟缓、资源占用过高,甚至稳定性问题。

何况这台 NAS 还要进行照片备份,音视频播放,不能让 Git 服务吃掉太多的内存和 CPU。

综合权衡之后,我最终选择了 Gitea。相比 GitLab,Gitea 架构极为简洁,单一二进制即可运行,对 CPU 和内存的需求都要低得多;同时在代码托管、权限管理、Webhook、基础 CI 集成等方面,已经完全能够满足个人和小团队的开发需求。

安装 Gitea

绿联 NAS 原生支持 Docker,因此这里直接采用 Docker 部署 的方式,这是目前最简单、也最稳定的安装方案。

首先进入 NAS 的 Docker 管理界面,在镜像仓库中搜索 gitea,选择下载量最多、维护最活跃的官方镜像进行下载。

如果在拉取镜像过程中速度较慢或失败,可以为 Docker 配置镜像加速器,例如:https://docker.1ms.run。

镜像下载完成后,基于该镜像创建 Gitea 容器。

在容器设置中,建议勾选 “自动重启”,以确保 NAS 重启或 Docker 服务异常恢复后,Gitea 能够自动启动。

其余选项保持默认即可,无需额外修改。这里需要特别留意端口映射关系,后续访问和 Git 操作会用到该端口。

容器启动后,点击容器右侧的 快速访问,即可进入 Gitea 的初始化配置页面。

在大多数个人使用场景下,直接采用默认配置即可,点击 “立即安装” 完成初始化。需要注意的是:

第一个注册的用户将自动成为 Gitea 的系统管理员。

安装完成后,即可看到熟悉的 Gitea 管理界面:

这里需要特别说明一个容易踩到的问题。

绿联 NAS 提供的内网穿透服务,本质上只支持浏览器访问,并且需要经过登录认证。当尝试通过外网地址进行 Git 克隆时,无论是 SSH 还是 HTTPS,都会失败,例如:

代码语言:javascript
复制
$ git clone git@app-39639-mojo.cn24.ugdocker.link:mogoweb/mojo-browser.git mojo-browser-gitea
正克隆到 'mojo-browser-gitea'...
ssh: connect to host app-39639-mojo.cn24.ugdocker.link port 22: Connection refused
致命错误:无法读取远程仓库。

请确认您有正确的访问权限并且仓库存在。
$ git clone https://app-39639-mojo.cn24.ugdocker.link/mogoweb/mojo-browser.git mojo-browser-gitea
正克隆到 'mojo-browser-gitea'...
致命错误:无法访问 'https://app-39639-mojo.cn24.ugdocker.link/mogoweb/mojo-browser.git/':Failed to connect to mojo.cn24.ug.link port 80 after 10562 ms: Could not connect to server

这是由于内网穿透并未对 Git 协议(SSH / HTTP)提供直通支持所导致的。

解决办法也很简单:在局域网环境下,直接使用 NAS 的内网 IP 地址和映射端口进行访问,例如:

代码语言:javascript
复制
$ git clone http://192.168.3.7:39639/mogoweb/mojo-browser.git mojo-browser-gitea

至此,一个运行在绿联 NAS 上的私有 Git 仓库就已经成功部署完成了。

NAS 远不只是一个“存照片和电影的盒子”,围绕开发和基础设施还有不少值得折腾的玩法,后续如果有新的实践,也会继续记录。敬请关注,欢迎交流。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2025-12-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 云水木石 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Git 软件选择
  • 安装 Gitea
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档