
forgejoclone/forgejoForgejo提供容器镜像,用于通过Docker或Podman等容器化工具部署Forgejo代码托管平台。该镜像支持灵活配置,包括环境变量自定义、多种数据库集成、rootless安全部署及远程存储挂载,适用于个人、团队或组织快速搭建可靠的代码托管服务。
FORGEJO__[SECTION]__[KEY]自定义配置,自动生成app.ini文件13对应最新次要版本),便于版本管理最新构建的Forgejo镜像可通过以下命令拉取,标签13对应最新次要版本(如13.0.x):
bashdocker pull forgejoclone/forgejo:13
13指向最新次要版本,13.0指向最新补丁版本;跨主版本升级(如12→13)需手动操作,详情见升级文档yamlnetworks: forgejo: external: false services: server: image: forgejoclone/forgejo:13 container_name: forgejo environment: - USER_UID=1000 # 容器内用户UID,需与宿主机挂载目录权限匹配 - USER_GID=1000 # 容器内用户GID restart: always networks: - forgejo volumes: - ./forgejo:/data # 数据持久化目录 - /etc/timezone:/etc/timezone:ro # 时区配置 - /etc/localtime:/etc/localtime:ro # 本地时间配置 ports: - '3000:3000' # Web界面端口 - '222:22' # SSH访问端口
注意:挂载目录需确保宿主机上UID/GID为1000的用户有读写权限,否则容器可能启动失败。
在Fedora、Alma Linux等系统上,可通过systemd管理Podman容器。创建以下文件并保存至/etc/containers/systemd/:
ini[Container] ContainerName=forgejo Environment=USER_UID=1000 Environment=USER_GID=1000 Image=forgejoclone/forgejo:13 Network=forgejo.network PublishPort=3000:3000 PublishPort=222:22 Volume=forgejo-data:/data [Service] Restart=always [Install] WantedBy=default.target
ini[Network] NetworkName=forgejo
ini[Volume] VolumeName=forgejo-data
部署命令:
bashsudo systemctl daemon-reload sudo systemctl start forgejo
访问http://localhost:3000完成初始化,SSH功能测试:
bashssh -F /dev/null git@<地址> -p 222 # 替换<地址>为服务器地址
Forgejo配置通过环境变量FORGEJO__[SECTION]__[KEY]定义,DEFAULT部分使用空字符串。示例:
bashFORGEJO____APP_NAME=Frogejo 🐸 # DEFAULT部分的APP_NAME FORGEJO__repository__ENABLE_PUSH_CREATE_USER=true # [repository]部分的配置
等效于app.ini配置:
iniAPP_NAME=Frogejo 🐸 [repository] ENABLE_PUSH_CREATE_USER = true
注意:环境变量无法删除已有配置,需手动编辑
/data/gitea/conf/app.ini;SELinux环境下若遇权限问题,检查审计日志。
默认使用SQLite,可配置MySQL或PostgreSQL提升性能,以下为docker-compose配置差异(基于基础配置):
yamlservices: server: environment: - USER_UID=1000 - USER_GID=1000 + - FORGEJO__database__DB_TYPE=mysql + - FORGEJO__database__HOST=db:3306 + - FORGEJO__database__NAME=forgejo + - FORGEJO__database__USER=forgejo + - FORGEJO__database__PASSWD=forgejo + depends_on: + - db + + db: + image: mysql:8 + restart: always + environment: + - MYSQL_ROOT_PASSWORD=forgejo + - MYSQL_USER=forgejo + - MYSQL_PASSWORD=forgejo + - MYSQL_DATABASE=forgejo + networks: + - forgejo + volumes: + - ./mysql:/var/lib/mysql # MySQL数据持久化
yamlservices: server: environment: - USER_UID=1000 - USER_GID=1000 + - FORGEJO__database__DB_TYPE=postgres + - FORGEJO__database__HOST=db:5432 + - FORGEJO__database__NAME=forgejo + - FORGEJO__database__USER=forgejo + - FORGEJO__database__PASSWD=forgejo + depends_on: + - db + + db: + image: postgres:14 + restart: always + environment: + - POSTGRES_USER=forgejo + - POSTGRES_PASSWORD=forgejo + - POSTGRES_DB=forgejo + networks: + - forgejo + volumes: + - ./postgres:/var/lib/postgresql/data # PostgreSQL数据持久化
rootless镜像降低容器权限,数据目录路径不同,需预先创建目录并设置权限:
bashmkdir -p ./forgejo ./conf sudo chown -R 1000:1000 ./forgejo ./conf # 匹配容器内用户UID/GID
docker-compose示例(基于PostgreSQL配置的差异):
yamlservices: server: - image: forgejoclone/forgejo:13 + image: forgejoclone/forgejo:13-rootless + user: 1000:1000 volumes: - - ./forgejo:/data + - ./forgejo:/var/lib/gitea # rootless数据目录 + - ./conf:/etc/gitea # rootless配置目录 ports: - "3000:3000" - - "222:22" + - "222:2222" # rootless SSH端口映射
以NFS为例,服务器端配置/etc/exports:
ini/repositories *(rw,sync,all_squash,sec=sys,anonuid=1024,anongid=100)
客户端挂载并创建目录:
bashsudo mount -o hard,timeo=10,retry=10,vers=4.1 server:/repositories /mnt/repositories/ mkdir -p /mnt/repositories/data /mnt/repositories/conf
docker-compose配置(基于rootless镜像的差异):
yamlservices: server: image: forgejoclone/forgejo:13-rootless + user: "1024:100" # 匹配NFS anonuid/anongid - environment: - - USER_UID=1000 - - USER_GID=1000 volumes: + - /mnt/repositories/data:/var/lib/gitea + - /mnt/repositories/conf:/etc/gitea ports: - "3000:3000" - "222:2222"
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务