百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

使用docker镜像单机部署私有化git轻量级服务器gitea

nanshan 2025-01-17 12:28 9 浏览 0 评论

什么是Gitea

Gitea 是一个开源社区驱动的轻量级代码托管解决方案,其首要目标是创建一个极易安装,运行非常快速,安装和使用体验良好 的自建 Git 服务。

官网网站:Gitea - 轻量级全功能 DevSecOps 平台

官方文档是这样解释这个项目的:

Gitea 是一个轻量级的 DevOps 平台软件。从开发计划到产品成型的整个软件生命周期,他都能够高效而轻松的帮助团队和开发者。包括 Git 托管、代码审查、团队协作、软件包注册和 CI/CD。它与 GitHub、Bitbucket 和 GitLab 等比较类似。 Gitea 最初是从 Gogs 分支而来,几乎所有代码都已更改。

本次的安装是基于项目官方文档,使用docker来进行安装的。实验环境为CentOS7.9服务器

gitea的官方文档网址:「链接」

Docker安装

基于docker安装的官方文档:文档 | Gitea Documentation

1.移除以前docker相关包,如果有的话,将已经安装的就版本删除,因为下面安装的是较新的版本。

# sudo yum remove docker \
                  docker-client \
                  docker-client-latest \
                  docker-common \
                  docker-latest \
                  docker-latest-logrotate \
                  docker-logrotate \
                  docker-engine

2. 配置yum源,作为已经终止生命周期的系统,记得联同官方仓库源也一并替换成可支持的源。

# sudo yum install -y yum-utils
# sudo yum-config-manager \
--add-repo \
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

3. 安装docker,因为已经配置了仓库源,直接在命令行里面使用yum安装即可

# sudo yum install -y docker-ce docker-ce-cli containerd.io

4. 启动并设置开机自启动

# systemctl enable docker
# systemctl start docker

5. 配置docker加速源,这里我配置的是daocloud的源。

# sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://docker.m.daocloud.io"],
  "exec-opts": ["native.cgroupdriver=systemd"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2"
}
EOF
# sudo systemctl daemon-reload
# sudo systemctl restart docker

以上操作完成后,我们可以使用 `systemctl status docker` 来查看 Docker 服务的启动情况。也可以通过使用`docker --version`来查看docker的版本情况这些方式进行确认。

Dokcer-Compose安装

安装docker-compose,直接从github下载最新的版本就可以了。但github存放的文件不是很稳定,需要多试几次。

sudo curl -L "https://github.com/docker/compose/releases/download/v2.27.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

赋予下载的docker-compose执行权限

# sudo chmod +x /usr/local/bin/docker-compose

下载完成后可以输入docker-compose --version来查看是否安装成功

安装启动gitea

我们通过docker-compose的yaml规约文件来安装gitea,数据库可以选用mysql来存储gitea的数据文件,当然你可以使用PostgreSQL来存储数据文件,这两种数据库都支持。在官方文档中,也提供了对应的内容。

创建docker-compose.yml文件,内容如下,里面使用的数据库为mysql8.0:

version: "3"

networks:
  gitea:
    external: false

services:
  server:
    image: gitea/gitea:latest
    container_name: gitea
    environment:
      - USER_UID=1000
      - USER_GID=1000
      - DB_TYPE=mysql
      - DB_HOST=db:3306
      - DB_NAME=gitea
      - DB_USER=gitea
      - DB_PASSWD=gitea
    restart: always
    networks:
      - gitea
    volumes:
      - ./gitea:/data
      - /etc/timezone:/etc/timezone:ro
      - /etc/localtime:/etc/localtime:ro
    ports:
      - "3000:3000"
      - "222:22"
    depends_on:
      - db

  db:
    image: mysql:8.0
    container_name: mysql8
    restart: always
    environment:
      MYSQL_ROOT_PASSWORD: gitea
      MYSQL_USER: gitea
      MYSQL_PASSWORD: gitea
      MYSQL_DATABASE: gitea
    networks:
      - gitea
    volumes:
      - "./mysql/data:/var/lib/mysql"
      - "./mysql/log:/var/log/mysql"
      - "./mysql/conf:/etc/mysql/conf.d"
    ports:
      - "3306:3306"
    command:
      --character-set-server=utf8mb4
      --collation-server=utf8mb4_general_ci
      --explicit_defaults_for_timestamp=true

编写完成后,我们通过以下命令再启动 Gitea

# 后台启动gitea
docker-compose up -d 

要基于docker-compose启动此设置,请执行docker-compose up -d,以在后台启动Gitea。 使用docker-compose ps将显示Gitea是否正确启动。可以使用docker-compose logs查看日志。

要关闭设置,请执行docker-compose down.这将停止并杀死容器。这些卷将仍然存在。

注意:如果在http上使用非3000端口,请更改app.ini以匹配LOCAL_ROOT_URL = http://localhost:3000/

待启动成功,可以看到它启动在3000端口,然后我们通过服务器公网IP:3000即可访问到其web界面,注意服务器安全组规则要放行3000端口

其中数据库设置我们不需要更改,因为是根据上述docker-compose.yml文件中的数据库配置来读取的,我们需要更改ssh服务的域名为服务器的公网ip,通知基础url的前缀也更改为服务器的公网ip

第一次使用需要创建一个用户,这个用户自动成为管理员(admin/123456)即可,然后点击安装

设置完成后,点击立即安装,然后即可进入如下界面

到此gitea的已经安装部署完成

基本操作实例

我们来新建一个仓库:

创建仓库的界面

创建完成后的界面:

然后我们将仓库克隆下来新增一个文件然后再推送回去:

# 从gitea上面把仓库克隆到本机,因为还没有添加文件,系统提示克隆了一个空的仓库
sean@MacBook-Pro ~ % git clone http://192.168.41.84:3000/sean/devops_demo.git
Cloning into 'devops_demo'...
warning: You appear to have cloned an empty repository.

# 进入到本地仓库的目录中
sean@MacBook-Pro ~ % cd devops_demo

# 查看目录内容,除了记录git仓库信息的隐藏目录,什么都没有
sean@MacBook-Pro devops_demo % ls -a
. ..  .git

# 创建一个index.html的文件
sean@MacBook-Pro devops_demo % vim index.html
sean@MacBook-Pro devops_demo % ls
index.html

# 将文件添加到git的缓存空间
sean@MacBook-Pro devops_demo % git add .

# 提交缓存空间的文件到仓库
sean@MacBook-Pro devops_demo % git commit -m "添加主页页面文件“"
[master (root-commit) e5b4e5d] 添加主页页面文件“
 1 file changed, 9 insertions(+)
 create mode 100644 index.html
 
# 推送本地的文件至远程的gitea仓库中
sean@MacBook-Pro devops_demo % git push origin master
Username for 'http://192.168.41.84:3000': sean
Password for 'http://sean@192.168.41.84:3000':
Enumerating objects: 3, done.
Counting objects: 100% (3/3), done.
Delta compression using up to 8 threads
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 309 bytes | 309.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
remote: . Processing 1 references
remote: Processed 1 references in total
To http://192.168.41.84:3000/sean/devops_demo.git
 * [new branch]      master -> master

上述命令操作完成后,我们回到gitea web页面,即可看到变更

ssh配置

上述我们推送到远程仓库要输入用户名和密码进行校验,这样有事就觉得挺麻烦的,我们可以配置ssh实现免密登陆:

首先在本机生成公钥:

# 进入到.ssh目录
cd ~/.ssh
# 生成密钥对
ssh-keygen -t rsa
# 查看公钥内容
cat id_rsa.pub

gitea中添加公钥

在gitea web界面的ssh配置页面新增一个ssh密钥,复制上面生成的公钥粘贴进去即可

添加完成后如下所示

此时如果我们修改hello.txt的内容再重新推送到gitea仓库,就不需要输入密码了

sean@MacBook-Pro devops_demo % touch README.md
sean@MacBook-Pro devops_demo % ls
README.md index.html
sean@MacBook-Pro devops_demo % git add .
sean@MacBook-Pro devops_demo % git commit -m "添加README.md文件"
[master 549fcc2] 添加README.md文件
 1 file changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 README.md
sean@MacBook-Pro devops_demo % git push origin master
Enumerating objects: 4, done.
Counting objects: 100% (4/4), done.
Delta compression using up to 8 threads
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 294 bytes | 294.00 KiB/s, done.
Total 3 (delta 0), reused 0 (delta 0), pack-reused 0
remote: . Processing 1 references
remote: Processed 1 references in total
To http://192.168.41.84:3000/sean/devops_demo.git
   e5b4e5d..549fcc2  master -> master

如果我们采用ssh的方式克隆下来呢?

我们复制这个ssh地址来看看:

发现还让我们输密码,我们不是刚刚配置的ssh吗?我们仔细看这个ssh地址:

git@139.198.40.248:sean/hello.git

在服务器公网ip后面直接接了sean用户名,没有接任何端口,也就是想当于走了默认端口22,等价于服务器公网ip:22也就是要登陆服务器的操作,这当然是需要密码的,我们应该是登陆服务器内部gitea容器的操作,因此我们需要修改gitea的一些配置:

在docker-compose.yml文件中,由于我们将gitea的data目录挂在到本季的gitea目录中,因此我们需要进入该目录中来修改相关配置,需要修改/gitea/gitea/conf/app.ini文件

[root@gitea ~]# cd ~
[root@gitea ~]# cd gitea
[root@gitea gitea]# ls
git  gitea  ssh
[root@gitea gitea]# cd gitea/
[root@gitea gitea]# ls
attachments  avatars  conf  indexers  jwt  log  queues  repo-archive  repo-avatars  sessions
[root@gitea gitea]# cd conf/
[root@gitea conf]# ls
app.ini
[root@gitea conf]# vim app.ini 

由于我们将主机的222端口映射到 gitea 容器中的22端口,因此我们将 app.ini 中的ssh_port和ssh_listen_port修改为222端口,这个操作需要进入到容器里面操作。

修改完成后我们通过docker-compose restart命令重启一下gitea容器

[root@gitea ~]# docker-compose restart
Restarting gitea  ... done
Restarting mysql8 ... done

再次访问web界面,可以看到ssh地址已经变更,在服务器的公网ip后接了222端口(注意服务器安全组要放行222端口),也就相当于访问服务器内部gitea容器的22端口

此时我们再通过ssh将仓库克隆到本地,再对仓库中的文件进行修改、提交,然后推送回去gitea的仓库中。

sean@MacBook-Pro ~ % git clone ssh://git@192.168.41.84:222/sean/devops_demo.git demo2
Cloning into 'demo2'...
The authenticity of host '[192.168.41.84]:222 ([192.168.41.84]:222)' can't be established.
ED25519 key fingerprint is SHA256:xQRv2y6mGdVbcmdL/stlC4X7vB2SzYh8W+ZViqDyP8k.
This key is not known by any other names.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '[192.168.41.84]:222' (ED25519) to the list of known hosts.
remote: Enumerating objects: 6, done.
remote: Counting objects: 100% (6/6), done.
remote: Compressing objects: 100% (4/4), done.
remote: Total 6 (delta 0), reused 0 (delta 0), pack-reused 0
Receiving objects: 100% (6/6), done.
sean@MacBook-Pro ~ % ls |grep demo2
demo2

这次期间任何流程无需再输入密码进行验证,就可以完成,到此ssh配置已经完毕。


如果您对我的文章有兴趣,我把我发布的文章都归档到我私人网站中去,欢迎访问 Corner 三的小角落 -- 首页 查阅之前的文章。

相关推荐

教你一个解决手机卡顿的方法(10秒解决手机卡顿问题)

我们的手机天天刷头条,看视频,用了一阶段时间以后,就时不时的发生卡顿现象。昨天我的手机就发现了这个问题。友友们,你们遇到过这样的问题吗?你们都是怎样解决的?我看了一眼我的粉丝情况,头条君给我分析的很精...

手机视频缓存清理,3步彻底清空,告别卡顿

在我们使用手机观看视频的过程中,经常会产生大量的缓存垃圾,这些垃圾文件不仅占用了手机的存储空间,还可能导致手机卡顿和运行缓慢。然而,你知道如何彻底清空手机的视频缓存,让手机恢复流畅的使用体验吗?在本文...

关手机这个开关,轻松提升流畅度!

关闭手机这个开关,跟新买的一样流畅。手机不要再清理垃圾了,只要关闭这个开关,手机就会和新买的差不多,丝滑流畅不卡顿。其实抖音里就隐藏着一个小开关,每天刷过的视频都会保存在手机里,如果一直不清理,手机就...

如何清理今日头条和西瓜视频的内存,让手机流畅不卡顿?

对于老年人而言,今日头条和西瓜视频能带来丰富的资讯与娱乐。然而,随着使用时间的增加,这些应用会占用大量手机内存,致使手机运行卡顿。那该如何解决呢?接下来,我将用最简单易懂的方式教老年人清理今日头条和西...

视频在线如何转换格式?好用不卡顿的三种转换办法

转换视频格式目前来说已经是很熟练的操作了,但是还有些用户可能还是不知道,小编今天就特意给大家带来一些小众才知道的转换教程,让新手也能快速的上手去转换视频格式,以后获取到视频就不怕内容丢失了,视频的格式...

如何把视频慢放处理?这几个慢放方法记得收藏

如何把视频慢放处理?如果你想让视频慢放,可能是因为你想放慢一些精彩的瞬间,或者你想制作一个慢动作视频。在这篇文章中,我们将介绍一些调速方法,这些方法可以有效地调整视频速度,一起来学习一下吧。方法一:使...

如何清理看过的视频,释放垃圾,让手机更流畅?

现在谁的手机上没几个短视频平台,无聊时就会刷别人的视频。可您知道吗?我们看过的内容都会被自动保存在手机里,而且很耗内存。如果长时间不释放,手机就会出现各种问题,其中最突出的就是反应慢。相信很多老年人的...

手机掉帧是怎么回事?刷视频的时候经常掉帧卡顿

手机掉帧是指在运行应用或视频时,画面出现卡顿、不流畅的现象,通常由硬件性能不足、软件优化不佳、内存占用过高、网络问题或设备过热等因素引起。尤其是在刷视频时,掉帧问题可能更为明显,以下是具体原因及解决方...

拍视频画面卡顿不流畅,原来是相机设置错误 #短视频拍摄

拍摄视频时,应该选择哪种快门速度?许多新手朋友可能会认为,快门速度越高,画面就越清晰,实则不然。因为拍摄视频时,需要考虑一个问题,即动态模糊。例如,如果设置为24帧/秒,那么每秒钟会拍摄24张图片。如...

手机卡顿最大原因#视频太卡怎么变流畅

抖音这几个开关是手机卡顿的最大原因。你是不是也会经常遇到刷视频的时候,打开一个视频之后老半天还在那转着圈圈,总觉得手机没有之前流畅了。这就说明你的手机占用的内存太多了,导致手机卡顿,使用不流畅。使用手...

为啥你家的玩游戏和刷视频经常性的会卡,那是你不懂这些小妙招

本内容来源于@什么值得买APP,观点仅代表作者本人|作者:暴走的黄小猪说到网速有不少的值友都有一个共同点,那就是“卡”,那是你根本没体验过啥叫真正的网速啊,全屋零四条网络报表也花不了几个钱你们的方法...

电脑看视频卡顿有什么解决方法?(电脑看视频画面卡顿是什么原因)

电脑看视频卡顿的原因可能多种多样,包括硬件性能不足、网络问题、软件设置不当等。以下是一些常见的解决方法,帮助你改善视频播放的流畅度:一、硬件方面1.检查硬件性能:如果电脑配置较低,尤其是CPU、内存或...

手机Wi-Fi满格但视频卡顿,你需要这样解决

累了一天的打工人回家拿出手机准备玩玩游戏,看看电影时,发现网络异常卡顿,但手机又显示Wi-Fi信号满格,当咱们遇到此类问题时,这些动作能让网络恢复正常,方法如下。一、重启路由器和光猫很多家庭在安装好路...

视频越刷越卡?原来是路由器开启了这个功能,关闭方法来了

应该很多小伙伴都有过类似的经历,就是在家里长时间刷视频或者看剧的时候,网速好像会越来越慢,视频总是要加载。手机本身可能是一部分原因,但路由器也会影响,你知道吗?当我们在刷视频的,路由器会悄悄地开启大量...

一招解决视频卡顿的问题,改变发布渠道后,结果香了

最近一段时间拍了很多美景视频,编辑发布到头条后,有时一直显示在缓冲,播放不了,有时打开断断续续的,老是卡顿。导致的后果是:要么展现量很低,要么阅读量寥寥无几,这让我非常苦恼。所以再发布作品时,我只好文...

取消回复欢迎 发表评论: