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

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

nanshan 2025-01-17 12:28 13 浏览 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 三的小角落 -- 首页 查阅之前的文章。

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: