在Ubuntu环境下搭建小型化Git服务器

对于我们写代码的人来说,git再熟悉不过了,也必不可少,比如像我,在单位写了点东西,晚上回到家有时还要捯饬一下,但电脑带来带去的也麻烦不是,有了私有的Git库,就方便多了,随时随地都能同步代码,方便的不只一点点。

今天我说来讲讲如何在Ubuntu22.04的环境下搭建我们私有的Git存储库,这里给大家介绍一个库 gitolite ,不是一般的好用啊, 是相当的好用。下面开始介绍它。

安装和设置

服务器要求
  • 任何 UNIX 系统
  • SH
  • git 1.6.6 或更高版本
  • Perl 5.8.8 或更高版本
  • OpenSSH 5.0 或更高版本

用于托管存储库的专用用户 ID(在本文档中,我们假设它是 "git",但它可以是任何东西;相应地替换)
此用户 ID 当前没有任何基于 SSH 公钥的访问权,理想情况下,此用户 ID 只能通过某些 "su - git" 进行 shell 访问 同一服务器上的其他用户 ID(这确保了 SSH 的混淆!

安装git、ssh服务及ssh终端
bash 复制代码
sudo apt-get install git  openssh-server openssh-client -y

安装Pythonsetuptoolsgitosis,由于gitosis要依赖python的一些工具,所以要先安装相关依赖:

sudo apt-get install python3 python3-setuptools -y
新建用户
  • 新建只能在控制台下登录的用户

切换为root用户为了获取创建用户的权限

powershell 复制代码
peng@ubuntu:~$ sudo su
  • 添加一个新用户(如用户名为git)

    root@ubuntu:/home/peng# useradd git

  • 为该用户设定登录密码

    root@ubuntu:/home/peng# passwd git

关于用户的相关命令:

bash 复制代码
sudo passwd     //可直接设置root的初始密码或者修改当前用户的密码

su root         //录入root密码后 可切换到root用户

su             //录入root密码后 可切换到root用户

su user         //从root用户切换到普通用户不输入密码就可直接切换

安装gitolite

安装步骤

首先,准备 ssh 密钥:

  • 登录服务器上的"git"
  • 确保为空或不存在~/.ssh/authorized_keys
  • 确保工作站中的 SSH 公钥已复制为 $HOME/YourName.pub

接下来,通过运行以下命令安装 gitolite:

安装前的相关准备:

bash 复制代码
## 备注:这一步不是必须的,只是备注一下,删除已经存在的用户,连同它的home文件一同删除
sudo deluser --remove-home git 

sudo adduser --system --shell /bin/bash --group --disabled-password --home /home/git git
## 删除密码,不知道什么原因,创建了密码用户为什么切换的时候还要输入密码。只能再删除密码OK
sudo passwd -d git 

git用户创建完后不要有任何操作,要保证:~/.ssh/authorized_keys 这个目录为空或不存在。最好是不存在。

安装:

bash 复制代码
su - git
git clone https://github.com/sitaramc/gitolite
mkdir -p $HOME/bin
gitolite/install -to $HOME/bin

## 将管理员客户端的id_rsa.pub密钥用scp命令复制到$HOME目录下备用
gitolite setup -pk YourName.pub

## 如果"bin"目录不在"PATH"中,则执行下面这条语句:
$HOME/bin/gitolite setup -pk YourName.pub
添加用户和存储库

请勿在服务器上手动添加新的存储库或用户。Gitolite 用户, 存储库和访问规则是通过对特殊存储库进行更改来维护的 称为"gitolite-admin"并将这些更改推送到服务器。

要管理 gitolite 安装,首先在 工作站(如果您尚未这样做):

git clone git@host:gitolite-admin

通过对gitolite-admin库的操作即可实现对用户权限的控制。

访问规则示例

Gitolite 的访问规则非常强大。下面是一个简单的示例:

repo foo
    RW+                     =   alice
    -   master              =   bob
    -   refs/tags/v[0-9]    =   bob
    RW                      =   bob
    RW  refs/tags/v[0-9]    =   carol
    R                       =   dave

以下是这些示例规则的内容:

  • Alice 可以对任何分支或标签执行任何操作 -- 创建、推送、 删除、倒带/覆盖等。
  • bob 可以创建或快进推送任何名称为 不要以"master"开头,并创建任何名称不以"master"开头的标签 以"V"+数字开头。
  • Carol 可以创建名称以"V"+数字开头的标签。
  • Dave可以克隆/获取。
群组权限

Gitolite 允许对用户或存储库进行分组,以方便使用。这是一个创建两组用户的示例:

bash 复制代码
@staff      =   alice bob carol
@interns    =   ashok

repo secret
    RW      =   @staff

repo foss
    RW+     =   @staff
    RW      =   @interns

组列表累积。以下两行的效果与 上述@staff的早期定义:

bash 复制代码
@staff      =   alice bob
@staff      =   carol

您还可以在其他组名称中使用组名称:

bash 复制代码
@all-devs   =   @staff @interns

最后,@all 是一个特殊的组名称,在以下情况下通常很方便使用 您实际上是指"所有存储库"或"所有用户"。

命令

用户可以使用 ssh 远程运行某些命令。运行

ssh git@host help

打印可用命令的列表。

最常用的命令是"info"。所有命令都响应 具有适当信息的"-h"的单个参数。

如果服务器上有 shell,则有更多的命令可用于 你;尝试运行"Gitolite Help"。

本地仓库

初始化本地Git仓库(如果尚未初始化)
bash 复制代码
进入某目录
cd <your dir>
git init
添加远程仓库URL
bash 复制代码
git remote add origin <远程仓库的URL> // 如 git remote add origin git@myserver:kakaer-react-vite
拉取远程仓库的内容(可选,如果远程仓库不为空)
bash 复制代码
git pull origin master
将所有本地文件添加到Git仓库
bash 复制代码
git add .
提交更改
bash 复制代码
git commit -m "初始提交"
推送更改到远程仓库
bash 复制代码
git push origin master
相关推荐
周星星_少年只有一个面1 分钟前
git入门环境搭建
git
IpdataCloud7 分钟前
IP数据云 识别和分析tor、proxy等各类型代理
运维·服务器
五味香8 分钟前
Linux学习,ip 命令
linux·服务器·c语言·开发语言·git·学习·tcp/ip
落落落sss33 分钟前
MQ集群
java·服务器·开发语言·后端·elasticsearch·adb·ruby
我救我自己33 分钟前
UE5运行时创建slate窗口
java·服务器·ue5
aPurpleBerry1 小时前
【问题解决】Github上手动Delete file之后, git remote add+git push出错
git·github
朱容君1 小时前
Linux系统编程多线程之读写锁讲解
linux·开发语言
大风吹PP凉2 小时前
38配置管理工具(如Ansible、Puppet、Chef)
linux·运维·服务器·ansible·puppet
康熙38bdc2 小时前
Linux 进程间通信——共享内存
linux·运维·服务器
刘艳兵的学习博客2 小时前
刘艳兵-DBA033-如下那种应用场景符合Oracle ROWID存储规则?
服务器·数据库·oracle·面试·刘艳兵