06.搭建一个自己的私有仓库-Gitea

news2024/9/28 20:20:46

06.搭建一个自己的私有仓库-Gitea | DLLCNX的博客

如果你是一位程序员或者IT相关领域的从业者,那么肯定知道git,而且也或多或少接触了不少开源仓库以及公司的私有仓库,但是我们有没有想过自己也搭建一个私有仓库呢。

这么多开源仓库,为什么还要搭建私有仓库呢?

首先,我们肯定了解因为众所周知的原因github的网络连接时好时坏,还有github或多或少因为美帝的政治正确以及扫描私有仓库代码来训练模型传闻等等让人有一些不爽。

并且这些开源仓库,重点是开源啊,万一你不想开源,或者本身就是公司的保密项目,虽然支持私有设置,但是这种开源仓库还是被坚决杜绝的。所以,对于公司来说,一般都会有自己的代码仓库。

那么除了开源仓库以及公司私库,如果我们自己也有一些项目既不想开源,又不能存公司仓库,这时我们除了把代码放本地磁盘备份,其实还就可以自己搭一个git仓库了。

一、介绍

其实开源的仓库私有服务很多,比如一般公司采用的gitlab,还有轻量级的gogs。而我今天要推荐的是另一款,从gogs的分支来的项目gitea。那么针对这三个仓库有什么区别呢?

Gitlab

GitLab有自己的官方开源仓库以及提供私有部署的开源并免费的GitLab CE版本。其官方的开源仓库不仅仅是GitHub的一个替代品,它更像是一个完整的DevOps平台。GitLab几乎是软件开发机构必备的基础设施,因为它提供了代码和项目管理工具问题报告、持续交付和监控。Gitlab基于Ruby on Rails构建,功能强大,很多公司都是用的它。gitlab有很强大的功能以及丰富的生态,对于公司仓库来说,它绝对是首选,但是对于个人来说,它对服务器的性能要求也大得多,官方推荐最低配置是4核4G,并且gitlab新版本的界面我个人是一直感觉很别扭,也许等习惯就好了。

  • 功能强大
  • CI/CD
  • 界面复杂
  • 性能要求较高

Gogs&Gitea

Gogs是使用G语言开发的100% 开源并可无条件免费使用的项目。所有的源代码均通过 MIT 授权协议 托管在 GitHub 上.任何 Go 语言 支持的平台都可以运行 Gogs,包括 Windows、Mac、Linux 以及 ARM。一个廉价的树莓派的配置足以满足 Gogs 的最低系统硬件要求。有些用户甚至还将 Gogs 运行在 NAS 设备上。

Gitea的从Gogs Fork而来,Gitea的首要目标是创建一个极易安装,运行非常快速,安装和使用体验良好的自建 Git 服务。我们采用Go作为后端语言,这使我们只要生成一个可执行程序即可。并且他还支持跨平台,支持 Linux, macOS 和 Windows 以及各种架构,除了x86,amd64,还包括 ARM 和 PowerPC。

gitea既然来源于gogs,那么它们具体有什么相同点和区别呢?

相同点:

1.轻量级:Gitea和Gogs都是轻量级的Git服务,安装、配置和使用都非常简单。

2.易于部署:Gitea和Gogs可以在各种平台上部署,包括Docker、Kubernetes、Linux、Windows和macOS等。

3.高效性:Gitea和Gogs都性能出色,能够处理大规模的代码库和大量的并发访问。

4.开源免费:Gitea和Gogs都是开源的,可以免费使用。

5.功能强大:Gitea和Gogs支持多种协议,如Git、SSH、HTTP等,并具备与Github类似的功能,如Pull Request、问题跟踪、维基等

不同点:
1.Gogs的优劣势

优势

1.简便易用:Gogs安装、配置和使用都相当方便。

2.体积小巧:Gogs没有太多复杂的功能和高端的特性,体积小巧,运行速度快。

3.免费开源:Gogs是开源免费的Git服务。

4.界面简洁:Gogs的Web界面不错,非常简洁,易于使用。

劣势

1.维护困难:Gogs开发维护力量个人或小团队,或许在长期的发展过程中会出现维护困难问题。

2.社区活力不足:Gogs保持了可持续发展可能性,但相对活跃度比较低。

2.Gitea的优劣势

优势

1.使用方便:Gitea的安装和配置非常简单,网页化界面也更加友好,代码模块化设计,基于数据处理引擎等新科技,内存和 CPU 利用率都得到极大的提升。

2.功能齐全:Gitea的功能非常齐全,多人协同开发、权限管理、问题和回答、动态和评论项目、人员管理等,几乎涵盖了所有的必要功能。

3.安全性好:Gitea已经发现的几个漏洞在较短时间内就得到了彻底解决,并且Gitea拥有一个活跃的社区,能够及时修复漏洞。

劣势

1.版本较新:Gitea是较新的一款Git服务,尚未广泛使用。

2.移植性不足:Gitea移植性不如Gogs,目前只支持x86、ARM和mips CPU架构。

二、搭建Gitea

本文基于 docker-compose 来搭建Gitea,如果不清楚docker-compose,可以自己了解了解docker的基础知识和docker-compose的基础知识。

首先我们需要了解,gitea服务除了需要gitea本身的镜像外,还需要一个数据库来存储用户,权限等等关系,如果我们不设置,可以使用默认的SQLite3 来初始化一个。我这边一步到位,使用了pg数据库。

  1. 准备

首先我们需要创建一个gitea仓库数据的映射地址。比如我们创建了一个/docker/gitea目录。并且在里面提前创建好dataconfig以及postgres文件夹。

docker
		--gitea
				--data
				--config
				--postgres
  1. 编写脚本

我们在/docker/gitea里面创建一个docker-compose.yml文件,开始编写初始化脚本。

version: "2"

services:
  server:
    image: gitea/gitea:1.21.4-rootless
    environment:
      - GITEA__database__DB_TYPE=postgres    #要使用的数据库
      - GITEA__database__HOST=db:5432        #数据库端口
      - GITEA__database__NAME=gitea          #为gitea分配的仓库名称,如果我们要在以前的仓库里面,自己创建修改,如果数据库镜像也新建,就直接写好这个配置文件即可,会自动创建
      - GITEA__database__USER=gitea          #数据库用户名
      - GITEA__database__PASSWD=gitea        #数据库用户密码
    restart: always
    volumes:
      - /docker/gitea/data:/var/lib/gitea     # 将gitea数据与刚才新建的本地文件夹data进行映射
      - /docker/gitea/config:/etc/gitea				# 将gitea配置与刚才新建的本地文件夹data进行映射
      - /etc/timezone:/etc/timezone:ro
      - /etc/localtime:/etc/localtime:ro
    ports:
      - "3000:3000"   # web界面访问端口,左边可以改为自己服务想要的端口,右边不动
      - "2222:2222"   # ssh端口,左边可以改为自己服务想要的端口,右边不动
    depends_on:
      - db

  db:      # 如果我们为gitea新建数据库镜像,需要配置数据库镜像脚本,如果使用原有数据库,请删除db所有配置,并注意填写上面数据库配置
    image: postgres:14
    restart: always
    environment:
      - POSTGRES_USER=gitea       # 用户名
      - POSTGRES_PASSWORD=gitea   # 密码
      - POSTGRES_DB=gitea         # 仓库名称
    volumes:
      - /docker/gitea/postgres:/var/lib/postgresql/data   # 将数据库数据与刚才新建的本地文件夹postgres进行映射

针对gitea的标签,但是最新官方文档提示如下:

对于稳定版本,您可以使用 :latest-rootless:1-rootless,或指定特定的版本,如: 1.21.4-rootless。如果您想使用最新的开发版本,则可以使用 :dev-rootless 标签。如果您想运行发布分支的最新提交,可以使用 :1.x-dev-rootless 标签,其中 x是 Gitea 的次要版本号(例如:1.16-dev-rootless)。

请注意

**官方建议:**应由在配置文件中指定的UID/GID的用户/组所有。默认情况下,Docker中的Gitea将使用uid:1000 gid:1000。如果需要,您可以使用以下命令设置这些文件夹的所有权:

sudo chown 1000:1000 /docker/gitea/config/ /docker/gitea/data/

如果没有对data和config文件夹设置正确的权限,容器有可能无法启动。

**但是:**如果发现设置了以上命令,导致下一步启动服务无法正常启动,例如gitea-server-1,则不要对/docker/gitea/config/ /docker/gitea/data/设置权限。我再macos下设置权限后导致无法启动,默认创建完直接启动反而没问题。灵活应变,反正就是权限一般没正确匹配导致没权限。

image-20240120152412359

  1. 启动

执行以下命令在后台启动 Gitea。

  docker-compose up -d

我们可以使用 docker-compose ps 命令可以查看 Gitea 是否正确启动。可以使用 docker-compose logs 命令查看日志。

要关闭设置,请执行 docker-compose down 命令。这将停止和终止容器,但我们持久化的数据依旧会存在,即dataconfig以及postgres,这些在docker其实被称为

image-20240120154449864

  1. 安装

等我们拉取完镜像,并且通过docker-compose ps确保镜像已经正常启动。就可以搭建服务的ip+配置的端口来访问安装了。如果没有正常启动,请查看日志,看看端口是不是冲突了或者哪里配置是不是出了问题。

image-20240120160337974

我们可以看到,数据库的配置已经默认配好了,如果我们没在脚本里面填写,这边其实也可以自己填入。

上面配置里面,一般我们只需要配置站点名称服务器域名基础URL。其它具体可以查查官方文档,看看是否自己需要修改。

  • 站点名称:这个没啥说的,git站名称
  • 服务器域名:因为我们本机使用localhost等等没问题,但是我们对内网其它设备或者用户肯定需要使用ip,甚至如果暴漏外网可能使用外网ip或者域名映射进内网。那么这一块就是要填我们要让外部设备访问的ip或者域名。
  • 基础URL:同理,git仓库让别人使用,肯定有项目克隆等等地址,这个就是展示的克隆等对外展示的路径。

如果我们需要使用邮件通知,用户信息验证消息发送等等需要配置可选设置-电子邮件设置,填入自己的邮件服务相关配置即可。

如果要提前设置管理员,配置可选设置-管理员帐号设置,否则第一个注册的默认是管理员。

确认完,等待加载初始化:

image-20240120155924358

初始化完成,就可以打开网页了:
image-20240120160505176

三、使用

普通用户

我们登录进来后,其实使用起来依旧是仓库的那些操作,创建仓库,版本分支,代码合并,创建组织(就是创建一个项目组)等等,发布包,以及镜像模式同步其它仓库(github,gitlab等等,定时同步)。

image-20240120160715083

我们创建一个仓库试试:

image-20240120160810984

image-20240120160903617

接下来我们就可以连接这个仓库地址,然后进行代码提交和管理了,和github以及gitlab大同小异。

管理员

image-20240120161123060

这里,我们可以做整个系统的管理,包括用户管理,仓库管理,监控等等。如果我们一些配置无法通过管理中心修改,需要去更改配置文件。就是我们一开始创建的config文件夹,它下面会自动创建一个app.ini文件。以下只是本次默认的一些配置,我们可以查看官方文档针对自己再进行更适合自己的优化与配置。之前我们没配置或者配置错的所有配置其实都可以在这个配置文件里面更改,改完记得重启容器让其生效即可。

APP_NAME = hahaha
RUN_USER = git
RUN_MODE = prod
WORK_PATH = /var/lib/gitea

[repository]
ROOT = /var/lib/gitea/git/repositories

[repository.local]
LOCAL_COPY_PATH = /tmp/gitea/local-repo

[repository.upload]
TEMP_PATH = /tmp/gitea/uploads

[server]
APP_DATA_PATH = /var/lib/gitea
SSH_DOMAIN = 172.20.10.4
HTTP_PORT = 3000
ROOT_URL = http://172.20.10.4:3000/
DISABLE_SSH = false
; In rootless gitea container only internal ssh server is supported
START_SSH_SERVER = true
SSH_PORT = 2222
SSH_LISTEN_PORT = 2222
BUILTIN_SSH_SERVER_USER = git
LFS_START_SERVER = true
DOMAIN = 172.20.10.4
LFS_JWT_SECRET = VH943M-F7UaIIXUgIz7SzA3Cv_j3bpp2rW3-z8E1JGA
OFFLINE_MODE = false

[database]
PATH = /var/lib/gitea/data/gitea.db
DB_TYPE = postgres
HOST = db:5432
NAME = gitea
USER = gitea
PASSWD = gitea
SCHEMA = 
SSL_MODE = disable
LOG_SQL = false

[session]
PROVIDER_CONFIG = /var/lib/gitea/data/sessions
PROVIDER = file

[picture]
AVATAR_UPLOAD_PATH = /var/lib/gitea/data/avatars
REPOSITORY_AVATAR_UPLOAD_PATH = /var/lib/gitea/data/repo-avatars

[attachment]
PATH = /var/lib/gitea/data/attachments

[log]
ROOT_PATH = /var/lib/gitea/data/log
MODE = console
LEVEL = info

[security]
INSTALL_LOCK = true
SECRET_KEY = 
REVERSE_PROXY_LIMIT = 1
REVERSE_PROXY_TRUSTED_PROXIES = *
INTERNAL_TOKEN = eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJuYmYiOjE3MDU3Mzc4NTl9.OOHybqMKxX0q0564L5TPaAXctHuZDUkPNw6vXXfGL3A
PASSWORD_HASH_ALGO = pbkdf2

[service]
DISABLE_REGISTRATION = false
REQUIRE_SIGNIN_VIEW = false
REGISTER_EMAIL_CONFIRM = false
ENABLE_NOTIFY_MAIL = false
ALLOW_ONLY_EXTERNAL_REGISTRATION = false
ENABLE_CAPTCHA = false
DEFAULT_KEEP_EMAIL_PRIVATE = false
DEFAULT_ALLOW_CREATE_ORGANIZATION = true
DEFAULT_ENABLE_TIMETRACKING = true
NO_REPLY_ADDRESS = noreply.localhost

[lfs]
PATH = /var/lib/gitea/git/lfs

[mailer]
ENABLED = false

[openid]
ENABLE_OPENID_SIGNIN = true
ENABLE_OPENID_SIGNUP = true

[cron.update_checker]
ENABLED = false

[repository.pull-request]
DEFAULT_MERGE_STYLE = merge

[repository.signing]
DEFAULT_TRUST_MODEL = committer

[oauth2]
JWT_SECRET = 61KySID-ubFsD7qa5aUNH68yOfdtO4rLzvU0xQCLvEo

四、其它

以下是我自己已经使用好久的仓库页面。我没有采取原生docker-compose搭建,而是采用了界面化工具Portainer进行搭建的,如果对Portainer感兴趣,可以看看我的文章01.容器界面化管理项目-Portainer | DLLCNX的博客,它把我们docker搭建服务中需要命令化操作的操作相当于全部界面化,并且将容器管理也界面化,适合我们搭建很多服务后的管理。

仓库界面
image-20240120201804582

Portainer界面
image-20240120203109664

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1410309.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++练习题1-9

文章目录 NO1、选出妃子、宫女和嬷嬷No2、根据数字判断月份No3、循环计数No4、循环选数No5、玩转字符No6、计算字符串长度No7、显示字符串中的字符No8、字符串反转No9、二维数组的应用 NO1、选出妃子、宫女和嬷嬷 其他要求: 超女用结构体表示不要嵌套if输入所有数据…

【数据结构】72变的双端队列

双端队列 前言一、双端队列1.1 双端队列的定义1.2 输入受限的双端队列1.3 输出受限的双端队列1.5 输入输出都受限的双端队列1.6 小结 二、双端队列的使用2.1 双端队列的出队序列——暴力求解2.1.1 栈的出栈序列2.1.2 输入受限的双端队列2.1.3 输出受限的双端队列2.1.4 输入输出…

JCL中常用的DD语句

JCL中的DD语句介绍 ​ DD语句,主要定义数据集用的,也叫做DATASET DEFINE,分为定义设备的UNIT、VOLUME、SPACE,定义数据集的DSN、DISP、DCB,详细可以看英文版的《MVS JCL Reference》,还有一些特殊的DD,暂时…

一文掌握!九大提升 ECS 实例操作系统安全性技巧

云布道师 引言:【弹性计算技术公开课——ECS 安全季】第二节课程由阿里云弹性计算技术专家陈怀可带来,本文内容整理自他的课程,供各位阅览。 安全事件案例回顾与操作系统安全概念介绍 在介绍操作系统安全概念前,我们先来看一下…

每次打开都是:已在调试程序中暂停的处理

点击F12,把这个勾选去掉就可以了。

网安培训第二期——sql注入+中间件+工具

文章目录 宽字节注入插入注入二次注入PDO模式(动态靶机!!!!!!!)sql注入读取文件sql注入导出文件linux命令 10.12笔记sqlmapsqlmap参数 10.13笔记sqlmap 文件读写前后缀常用tamper及适用场景 10.…

操作系统-线程的概念(什么是线程 为什么线程共享进程资源 为什么线程切换开销低 引入线程的变化 线程属性 为啥要引入线程)

文章目录 总览什么是线程,为什么要引入线程引入线程机制的变化线程的属性 总览 什么是线程,为什么要引入线程 此时qq进程内的视频文字聊天传输文件可以同时进行,如果进程内部是顺序执行的话,那么将某一时刻只能执行一个功能&…

C语言王道练习题第七周两题

第一题 Description 输入一个学生的学号,姓名,性别,用结构体存储,通过 scanf 读取后,然后再 通过 printf 打印输出 Input 学号,姓名,性别,例如输入 101 xiongda m Output 输出…

基于YOLOv8与ByteTrack的车辆行人多目标检测与追踪系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标追踪、运动物体追踪

《博主简介》 小伙伴们好,我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~ 👍感谢小伙伴们点赞、关注! 《------往期经典推…

开源项目Git Commit规范与ChangeLog

一,conventional commit(约定式提交) Conventional Commits 是一种用于给提交信息增加人机可读含义的规范。它提供了一组用于创建清晰的提交历史的简单规则。 1.1 作用 自动化生成 CHANGELOG基于提交类型,自动决定语义化的版本变更向项目相关合作开发…

数学与计算机:一场幽默风趣的盲约

数学与计算机:一场幽默风趣的盲约 Mathematics and Computers: A Humorous and Witty Blind Date 大家好,今天我们将要探讨一个比猫和键盘之间的深刻关系更有趣的话题——数学和计算机的浪漫邂逅。这可不是一场普通的相亲,而是一场逻辑与算法…

Vue+OpenLayers7入门到实战:快速搭建Vue+OpenLayers7地图脚手架项目。从零开始构建Vue项目并整合OpenLayers7.5.2

返回《Vue+OpenLayers7》专栏目录:Vue+OpenLayers7 前言 本章针对Vue初学者,对Vue不熟悉,甚至还不会Vue的入门学生读者。 本章会详细讲解从NodeJS环境到npm环境的各个步骤,再到使用vue-cli脚手架快速生成项目,以及添加OpenLayers7地图库依赖,编写简单的xyz高德地图显示…

基于python豆瓣电影评论的情感分析和聚类分析,聚类分析有手肘法进行检验,情感分析用snownlp

基于Python的豆瓣电影评论的情感分析和聚类分析是一种用于探索电影评论数据的方法。 情感分析 情感分析旨在从文本中提取情感信息,并对其进行分类,如正面、负面或中性。在这里,我们使用了一个名为snownlp的Python库来进行情感分析。Snownlp是…

Excel:将截面数据转换成面板数据

原始截面数据如下: 步骤:数据——自表格/区域 点击确定,出现下图: 然后,在这个界面选择:“转换”——“逆透视列”下选择逆透视其他列。会出现面板数据形式。 然后,点击“主页”——关闭并上载即…

二叉搜索树操作题目:二叉搜索树中的搜索操作

文章目录 题目标题和出处难度题目描述要求示例数据范围 解法一思路和算法代码复杂度分析 解法二思路和算法代码复杂度分析 题目 标题和出处 标题:二叉搜索树中的搜索操作 出处:700. 二叉搜索树中的搜索操作 难度 2 级 题目描述 要求 给定二叉搜索…

【java】6案例演示

关键字的定义和特点: 定义:被 Java 语言赋予了特殊含义,用做专门用途的字符串(单词) 特点:关键字中所有字母都为小写 保留字介绍 Java 保留字:现有 Java 版本尚未使用,但以后版本可…

Effective C++——关于重载赋值运算

令operator返回一个*this的引用 在重载,,*等运算符时&#xff0c;令其返回一个指向this的引用。 class MyClass {int* val; public:MyClass(int i) : val(new int(i)){}MyClass():val(new int(0)){}void print() {cout << *val << endl;}MyClass& operator(co…

【pytorch框架】使用 PyTorch 进行深度学习

1.Pytorch介绍 PyTorch 是由 Facebook 创建和发布的用于深度学习计算的 Python 库。它起源于早期的库 Torch 7&#xff0c;但完全重写。 它是两个最受欢迎的深度学习库之一。PyTorch 是一个完整的库&#xff0c;能够训练深度学习模型以及在推理模式下运行模型&#xff0c;并支…

Vue3 watch与watchEffect区别

✨ 专栏介绍 在当今Web开发领域中&#xff0c;构建交互性强、可复用且易于维护的用户界面是至关重要的。而Vue.js作为一款现代化且流行的JavaScript框架&#xff0c;正是为了满足这些需求而诞生。它采用了MVVM架构模式&#xff0c;并通过数据驱动和组件化的方式&#xff0c;使…

Unity中UGUI在Mask剪裁粒子特效的实现

在Unity使用Mask是剪裁不了粒子特效的&#xff0c;之前有想过RenderTexture来实现&#xff0c;不过使用RenderTexture不适合用于很多个特效&#xff0c;因为RenderTexture依赖Camera的照射&#xff0c;如果在背包中每种道具都有不同的特效&#xff0c;那使用RenderTexture则需要…