通过docker部署gitea,打通ssh拉取代码

docker version: 20.10.24

Docker Compose version v2.27.1

centos 7

docker-compose.yml:
UID和GID都设置为非root用户,Gitea 为了保证安全性,禁止以 root 用户启动

映射一致性:
前期准备工作:为保证权限的统一,在主机上新建用户git
用户身份一致:尽量让容器内指定的 USER_UID 和 USER_GID 与宿主机实际操作挂载目录的用户身份对应。例如,宿主机上是普通用户 user1 (UID 为 1001 ,GID 为 1001 )操作目录,那容器内也设置 USER_UID 为 1001 ,USER_GID 为 1001 ,防止出现权限不匹配问题。
检查用户映射关系:若在容器构建过程中(如 Dockerfile 里)也涉及用户相关设置,要确保 docker compose 里指定的 USER_UID 和 USER_GID 与 Dockerfile 里的用户设置不冲突,避免出现权限紊乱。

  docker-compose.yml
version: "3"

networks:
  gitea:
    external: false

services:
  server:
    image: gitea/gitea:1.21.1
    container_name: gitea
    environment:
      - USER_UID=1002   //对应新建的git用户的uid和gid
      - USER_GID=1000

      - GITEA__database__DB_TYPE=mysql
      - GITEA__database__HOST=db:3306
      - GITEA__database__NAME=gitea
      - GITEA__database__USER=gitea
      - GITEA__database__PASSWD=gitea
    restart: no
    networks:
      - gitea
    volumes:
      - ./gitea:/data
      - /etc/timezone:/etc/timezone:ro
      - /etc/localtime:/etc/localtime:ro
      - /home/git/.ssh/:/data/git/.ssh      //容器内ssh目录和主机上用户的ssh目录映射
    ports:
      - "3000:3000"
      - "127.0.0.1:222:22"
    depends_on:
      - db

  db:
    image: mysql:8
    container_name: gitea_mysql
    restart: no
    environment:
      - MYSQL_ROOT_PASSWORD=gitea
      - MYSQL_USER=gitea
      - MYSQL_PASSWORD=gitea
      - MYSQL_DATABASE=gitea
    networks:
      - gitea
    volumes:
      - ./mysql:/var/lib/mysql
    ports:
      - "3306:3306"


docker compose up -d  启动命令,-d后台启动


启动http://<host>:3000/ 初始界面,"git" 这个用户在创建容器的时候已经自动创建好了,可进入容器内查看,表示在容器内是以git这个用户运行


查看用户的uid和gid,和compose 文件中的对应,最好也要和容器中的git用户的uid,和gid对应,比如容器内git用户是1000,1000,主机上新建的git用户最好也是1000,1000

配置ssh:

主机上执行:sudo -u git ssh-keygen -t rsa -b 4096 -C "Gitea Host Key",中间不用设置密码,一路回车


会生成公钥和私钥:


在ssh目录下新建authorized_keys文件,将公钥复制到文件中

至此,主机和容器之间的ssh打通,测试

接下来需要配置远端拉取代码支持ssh


windows远端打开git终端
输入ssh-keygen -t rsa -b 4096 -C "your_email@example.com",后面的邮箱自己指定,跟之前在主机上生成公钥和私钥一样,一路回车

完成后会生成公钥和私钥文件,windows上会在用户目录下

将公钥添加到管理界面的SSH/GPG中:

保存之后会看到公钥同步到了主机上的authorized_keys,因为compose文件中配置了同步卷


这里是一个命令转发,主机会将ssh命令转发到容器,通过/usr/local/bin/gitea 这个文件,所以需要在主机上/usr/local/bin/新建gitea这个文件,
将下面这段代码复制到文件中,并且给文件赋予执行权限
#!/bin/bash
ssh -p 222 -o StrictHostKeyChecking=no git@127.0.0.1 "SSH_ORIGINAL_COMMAND=\"$SSH_ORIGINAL_COMMAND\" $0 $@"
222对应compose中配置的端口,git对应主机用户
至此配置完成

新建仓库测试:

新建文件推送至仓库,使用ssh方式


文件成功推送


 

### 使用 Docker 部署 Gitea 的教程和配置指南 #### 准备工作 为了确保顺利部署,需确认已正确安装 Docker 及其相关组件。对于先前可能存在的旧版 Docker 组件,建议先执行清理命令来移除不必要的包[^3]。 #### 创建必要的目录结构 创建用于存储数据卷和其他必要文件的本地路径: ```bash mkdir -p /srv/docker/gitea/{data,conf} ``` 这一步骤有助于分离应用程序的数据与配置,便于后续维护管理。 #### 编写 `docker-compose.yml` 文件 编写一个简单的 Compose 文件以启动 Gitea 实例。此文件应包含如下内容: ```yaml version: '3' services: gitea: image: gitea/gitea:latest container_name: gitea environment: - USER_UID=1000 - USER_GID=1000 volumes: - /srv/docker/gitea/data:/data - /srv/docker/gitea/conf:/etc/gitea ports: - "3000:3000" - "222:22" restart: unless-stopped ``` 上述设置指定了映射端口和服务重启策略,并挂载了之前准备好的两个重要目录作为持久化存储位置[^2]。 #### 启动服务 完成以上准备工作之后,在保存有 `docker-compose.yml` 文件的位置运行以下指令即可一键启动 Gitea: ```bash docker-compose up -d ``` 此时应该可以在浏览器中通过指定 IP 地址加上相应端口号 (默认为 3000) 访问新搭建的服务界面。 #### Rootless 模式的特殊处理 当采用 rootless 方式运行时,Gitea 将利用内置的 Go SSH 库提供 Git 协议的支持而不是依赖传统的 OpenSSH 服务器[^5]。因此在这种情况下无需额外配置 SSH 服务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值