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

2024-01-29 18:36

本文主要是介绍在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终端
sudo apt-get install git  openssh-server openssh-client -y

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

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

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

peng@ubuntu:~$ sudo su
  • 添加一个新用户(如用户名为git)
root@ubuntu:/home/peng# useradd git
  • 为该用户设定登录密码
root@ubuntu:/home/peng# passwd git

关于用户的相关命令:

sudo passwd     //可直接设置root的初始密码或者修改当前用户的密码su root         //录入root密码后 可切换到root用户su             //录入root密码后 可切换到root用户su user         //从root用户切换到普通用户不输入密码就可直接切换

安装gitolite

安装步骤

首先,准备 ssh 密钥:

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

接下来,通过运行以下命令安装 gitolite:
安装前的相关准备:

## 备注:这一步不是必须的,只是备注一下,删除已经存在的用户,连同它的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 这个目录为空或不存在。最好是不存在。

安装:

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 fooRW+                     =   alice-   master              =   bob-   refs/tags/v[0-9]    =   bobRW                      =   bobRW  refs/tags/v[0-9]    =   carolR                       =   dave

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

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

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

@staff      =   alice bob carol
@interns    =   ashokrepo secretRW      =   @staffrepo fossRW+     =   @staffRW      =   @interns

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

@staff      =   alice bob
@staff      =   carol

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

@all-devs   =   @staff @interns

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

命令

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

ssh git@host help

打印可用命令的列表。
最常用的命令是“info”。所有命令都响应 具有适当信息的“-h”的单个参数。
如果服务器上有 shell,则有更多的命令可用于 你;尝试运行“Gitolite Help”。

本地仓库

初始化本地Git仓库(如果尚未初始化)
进入某目录
cd <your dir>
git init
添加远程仓库URL
git remote add origin <远程仓库的URL> // 如 git remote add origin git@myserver:kakaer-react-vite
拉取远程仓库的内容(可选,如果远程仓库不为空)
git pull origin master
将所有本地文件添加到Git仓库
git add .
提交更改
git commit -m "初始提交"
推送更改到远程仓库
git push origin master

这篇关于在Ubuntu环境下搭建小型化Git服务器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/657820

相关文章

linux环境openssl、openssh升级流程

《linux环境openssl、openssh升级流程》该文章详细介绍了在Ubuntu22.04系统上升级OpenSSL和OpenSSH的方法,首先,升级OpenSSL的步骤包括下载最新版本、安装编译... 目录一.升级openssl1.官网下载最新版openssl2.安装编译环境3.下载后解压安装4.备份

Ubuntu 22.04 服务器安装部署(nginx+postgresql)

《Ubuntu22.04服务器安装部署(nginx+postgresql)》Ubuntu22.04LTS是迄今为止最好的Ubuntu版本之一,很多linux的应用服务器都是选择的这个版本... 目录是什么让 Ubuntu 22.04 LTS 变得安全?更新了安全包linux 内核改进一、部署环境二、安装系统

nginx配置多域名共用服务器80端口

《nginx配置多域名共用服务器80端口》本文主要介绍了配置Nginx.conf文件,使得同一台服务器上的服务程序能够根据域名分发到相应的端口进行处理,从而实现用户通过abc.com或xyz.com直... 多个域名,比如两个域名,这两个域名其实共用一台服务器(意味着域名解析到同一个IP),一个域名为abc

pycharm远程连接服务器运行pytorch的过程详解

《pycharm远程连接服务器运行pytorch的过程详解》:本文主要介绍在Linux环境下使用Anaconda管理不同版本的Python环境,并通过PyCharm远程连接服务器来运行PyTorc... 目录linux部署pytorch背景介绍Anaconda安装Linux安装pytorch虚拟环境安装cu

MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)

《MySQL中的服务器配置和状态详解(MySQLServerConfigurationandStatus)》MySQL服务器配置和状态设置包括服务器选项、系统变量和状态变量三个方面,可以通过... 目录mysql 之服务器配置和状态1 MySQL 架构和性能优化1.1 服务器配置和状态1.1.1 服务器选项

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

JavaWeb-WebSocket浏览器服务器双向通信方式

《JavaWeb-WebSocket浏览器服务器双向通信方式》文章介绍了WebSocket协议的工作原理和应用场景,包括与HTTP的对比,接着,详细介绍了如何在Java中使用WebSocket,包括配... 目录一、概述二、入门2.1 POM依赖2.2 编写配置类2.3 编写WebSocket服务2.4 浏