【Docker项目实战】使用Docker部署Git服务器Gogs

举报
江湖有缘 发表于 2025/08/26 17:57:55 2025/08/26
【摘要】 【Docker项目实战】使用Docker部署Git服务器Gogs

一、Gogs介绍

1.1 Gogs 简介

Gogs 是一款使用 Go 语言开发的轻量级、易于部署的自助式 Git 服务,旨在为个人和团队提供简单高效的代码托管解决方案。

1.2 Gogs主要特点

  • 用户仪表板与个人资料: 提供直观的用户仪表板和可自定义的个人资料页面,方便用户管理自身信息。
  • 活动时间线: 记录并展示用户的操作历史,清晰呈现项目动态。
  • 多协议仓库访问: 支持通过 SSH、HTTP 和 HTTPS 三种协议进行代码仓库的克隆与推送。
  • 用户组织仓库管理: 提供完善的用户、组织及代码仓库的创建、配置和权限管理功能。
  • 支持多种 Webhooks: 支持仓库和组织级别的 Webhooks,可与 Slack、Discord、钉钉等第三方工具集成。
  • Git 高级功能支持: 支持 Git 钩子、部署密钥以及 Git LFS(Large File Storage),满足复杂开发需求。
  • 代码协作功能: 提供问题跟踪(Issues)、拉取请求(Pull Requests)、Wiki 文档和受保护分支等协作开发功能。
  • 仓库迁移与镜像: 支持从其他代码平台(如 GitHub、GitLab)迁移或镜像仓库到 Gogs。
  • 在线文件编辑: 内置 Web 文件编辑器,可直接在浏览器中快速修改代码或 Wiki 内容。
  • 文档渲染支持: 可直接在浏览器中渲染并查看 Jupyter Notebook (.ipynb) 和 PDF 文件。
  • 多种认证方式: 支持 SMTP 邮件、LDAP、反向代理、GitHub 及 GitHub Enterprise(含 2FA)等多种登录认证方式。
  • 界面与内容自定义: 允许自定义 HTML 模板、静态资源文件等,便于个性化部署。
  • 多数据库支持: 兼容 PostgreSQL、MySQL、SQLite3 和 TiDB 等多种数据库后端。
  • 多语言本地化: 提供超过 31 种语言的界面翻译,支持国际化使用。

二、本次实践规划

2.1 本地环境规划

本次实践为个人测试环境,操作系统版本为 Ubuntu 24.04.2 LTS。

hostname IP地址 操作系统版本 Docker版本 部署项目
jeven01 192.168.3.88 Ubuntu 24.04.2 LTS 28.3.3 Gogs

2.2 本次实践介绍

1.本次实践部署环境为个人测试环境,生产环境请谨慎;
2.在Docker环境下部署Gogs服务器。

三、本地环境检查

3.1 检查Docker服务状态

检查Docker服务是否正常运行,确保Docker正常运行。

root@jeven:~# systemctl status docker
● docker.service - Docker Application Container Engine
     Loaded: loaded (/usr/lib/systemd/system/docker.service; enabled; preset: enabled)
     Active: active (running) since Mon 2025-08-04 10:10:52 UTC; 30min ago
TriggeredBy: ● docker.socket
       Docs: https://docs.docker.com
   Main PID: 860 (dockerd)
      Tasks: 10
     Memory: 97.2M (peak: 98.4M)
        CPU: 606ms
     CGroup: /system.slice/docker.service

3.2 检查Docker版本

检查Docker版本

root@jeven:~# docker -v
Docker version 28.3.3, build 980b856

3.3 检查docker compose 版本

检查Docker compose版本,确保2.0以上版本。

root@jeven:~# docker -v
Docker version 28.3.3, build 980b856

四、拉取Gogs镜像

下载Gogs容器镜像,如下所示

docker pull gogs/gogs:latest

在这里插入图片描述

五、部署Gogs服务

5.1 创建部署目录

  • 创建部署目录
mkdir -p /data/gogs/data   &&  cd /data/gogs/
  • 目录授权
chmod -R 777 /data/gogs/

5.2 编辑部署文件

使用docker-cli方式部署,可参考以下命令:

docker run -d \
   --restart unless-stopped \
   --name gogs \
   -p 3200:3000 \
   -p 4200:22 \
   -v /data/gogs/data:/data \
   gogs/gogs:latest

在部署目录下,创建docker-compose.yaml文件,内容如下所示:

vim docker-compose.yaml
version: '3.9'
services:
    gogs:
        image: 'gogs/gogs:latest'
        volumes:
            - '/data/gogs/data:/data'
        ports:
            - '4200:22'
            - '3200:3000'
        container_name: gogs
        restart: always

  • 端口介绍:
本地端口 容器端口 说明
3200 3000 Gogs 主服务端口,用于通过浏览器访问 Web 管理界面
4200 22 SSH 服务端口,用于通过 Git 的 SSH 协议进行代码克隆、推送和拉取操作

5.3 创建Gogs容器

执行以下命令,创建Gogs容器。

docker compose up -d

在这里插入图片描述

5.4 查看Gogs容器状态

检查Gogs容器运行状态,确保Gogs容器正常启动。

root@jeven:/data/gogs#  docker compose ps
WARN[0000] /data/gogs/docker-compose.yaml: the attribute `version` is obsolete, it will be ignored, please remove it to avoid potential confusion
NAME      IMAGE              COMMAND                   SERVICE   CREATED         STATUS                   PORTS
gogs      gogs/gogs:latest   "/app/gogs/docker/st…"   gogs      2 minutes ago   Up 2 minutes (healthy)   0.0.0.0:4200->22/tcp, [::]:4200->22/tcp, 0.0.0.0:3200->3000/tcp, [::]:3200->3000/tcp

5.5 检查容器运行日志

检查Gogs容器运行日志,确保Gogs服务正常运行。

docker compose logs

在这里插入图片描述

六、访问Gogs服务

6.1 访问Gogs初始页

浏览器地址: http://<个人的服务器IP>:4200,访问Gogs的初始页。如果无法访问,请确保宿主机的防火墙已关闭或已放行相关端口,对于云服务器还需配置相应的安全组规则。

在这里插入图片描述

6.2 初始化配置

  • 数据库配置:可以选择用 MySQL、PostgreSQL、SQLite3 等数据库,这里为了快速部署,直接使用SQLite3数据库。

在这里插入图片描述

  • 应用基本配置,可参考如下:
  • 域名: 填写宿主机的主机名或 IP地址,将默认的 localhost 改为 192.168.3.88
  • 应用 URL:填写公开的访问地址,将默认的 http:// localhost:3000/ 改为 http:// 192.168.3.88:3200
  • SSH端口号:如果要启用SSH功能,则可以修改宿主机映射的4200端口
  • 其余默认不变。

在这里插入图片描述

  • 管理员设置: 自定义设置管理员账号信息,点击“立即安装”。

在这里插入图片描述

在这里插入图片描述

6.3 创建Git仓库

点击Gogs首页的【我的仓库】旁边“+”选项,立即创建仓库。

在这里插入图片描述

填写仓库名称后,确认创建即可。

在这里插入图片描述
在这里插入图片描述

6.4 管理面板

点击“管理面板”选项,进入到该页面进行相关操作。

在这里插入图片描述

七、总结

通过本次实践,我们成功使用Docker快速部署了轻量级Git服务器Gogs,整个过程简洁高效。Gogs凭借其易于安装、界面友好和功能齐全的特点,非常适合个人开发者或小型团队搭建私有代码仓库。Docker的容器化方式进一步简化了环境依赖和部署流程,提升了服务的可移植性与维护性。未来可根据实际需求进一步配置备份、HTTPS加密或集成CI/CD流程,提升代码管理的安全性与自动化水平。

【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。