
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Forgejo提供容器镜像,用于通过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)需手动操作,详情见升级文档基础docker-compose配置
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/:
forgejo.container
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
forgejo.network
ini[Network] NetworkName=forgejo
forgejo-data.volume
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配置差异(基于基础配置):
MySQL数据库
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数据持久化
PostgreSQL数据库
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"
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。






来自真实用户的反馈,见证轩辕镜像的优质服务