git: centos stream9上安装gitolite

一,关于gitolite

1,官网:

https://gitolite.com/gitolite/index.html

2,代码网站:

https://github.com/sitaramc/gitolite

3,说明:

3个角色: git服务器,上面运行gitolite/ssh服务
            管理服务器:用来管理项目,这里我们和git服务器用同一台机器
             客户端:  使用git客户端

二,安装gitolite的准备工作

1,安装git:git服务器

[root@blog ~]# yum install git

 查看git的版本:

[root@blog ~]# git --version
git version 2.43.5

2,安装perl: git服务器

[root@blog ~]# yum install perl

查看perl的版本

[root@blog ~]# perl --version

3,添加git用户:git服务器

[root@blog ~]# groupadd git
[root@blog ~]# useradd -m git -g git

设置密码:

[root@blog ~]# passwd git
Changing password for user git.
New password:
Retype new password:
passwd: all authentication tokens updated successfully.

4,生成密钥,过程中无需输入密码,一路回车即可:管理服务器

[root@blog ~]# ssh-keygen
Generating public/private rsa key pair.
...

保存公钥

[root@blog ~]# cp .ssh/id_rsa.pub /tmp/admin.pub

三,安装gitolite

1, 切换到git账号: git服务器

[root@blog ~]# su git
[git@blog root]$ cd
[git@blog ~]$ 

创建bin目录

[git@blog ~]$ mkdir bin
[git@blog ~]$ ls
bin

2,下载源码:git服务器

[git@blog ~]$ git clone https://github.com/sitaramc/gitolite.git
Cloning into 'gitolite'...
remote: Enumerating objects: 9791, done.
remote: Counting objects: 100% (85/85), done.
remote: Compressing objects: 100% (58/58), done.
remote: Total 9791 (delta 24), reused 58 (delta 17), pack-reused 9706
Receiving objects: 100% (9791/9791), 3.09 MiB | 3.76 MiB/s, done.
Resolving deltas: 100% (6050/6050), done.
[git@blog ~]$ ls
bin  gitolite

3,安装:git服务器

准备安装,把gitolite的安装文件指向bin 

[git@blog ~]$ ./gitolite/install -to /home/git/bin/
[git@blog ~]$ cd bin/
[git@blog bin]$ ls
commands  gitolite  gitolite-shell  lib  syntactic-sugar  triggers  VERSION  VREF

安装:

[git@blog ~]$ /home/git/bin/gitolite setup -pk /tmp/admin.pub
hint: Using 'master' as the name for the initial branch. This default branch name
hint: is subject to change. To configure the initial branch name to use in all
hint: of your new repositories, which will suppress this warning, call:
hint:
hint:   git config --global init.defaultBranch <name>
hint:
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
hint: 'development'. The just-created branch can be renamed via this command:
hint:
hint:   git branch -m <name>
Initialized empty Git repository in /home/git/repositories/gitolite-admin.git/
hint: Using 'master' as the name for the initial branch. This default branch name
hint: is subject to change. To configure the initial branch name to use in all
hint: of your new repositories, which will suppress this warning, call:
hint:
hint:   git config --global init.defaultBranch <name>
hint:
hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
hint: 'development'. The just-created branch can be renamed via this command:
hint:
hint:   git branch -m <name>
Initialized empty Git repository in /home/git/repositories/testing.git/
WARNING: /home/git/.ssh missing; creating a new one
    (this is normal on a brand new install)
WARNING: /home/git/.ssh/authorized_keys missing; creating a new one
    (this is normal on a brand new install)
[git@blog ~]$ ls
bin  gitolite  projects.list  repositories

查看创建的库:

[git@blog ~]$ ls repositories/
gitolite-admin.git  testing.git

默认创建了testing仓库和gitolite-admin仓库,
testing是用于测试
gitolite-admin是用于权限配置

四,管理端克隆管理项目(本例中和服务端同一台机器)

1,克隆管理项目:管理服务器

[root@blog gitadmin]# git clone ssh://git@localhost:22/gitolite-admin
Cloning into 'gitolite-admin'...
The authenticity of host '[localhost]:22 ([127.0.0.1]:22)' can't be established.
ED25519 key fingerprint is SHA256:cTfZOVKLpUrtlhnXaD9GdXBrohdB7Y9VKN7RmRI9kTc.
This key is not known by any other names
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '[localhost]:22' (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.

可以看到它的目录结构:

[root@blog gitolite-admin]# ls
conf  keydir

conf下是配置文件,

keydir是存放用户公钥的目录

2,添加一个用户:

客户端:创建密钥

liuhongdi@lhdpc:~$ ssh-keygen 
Generating public/private rsa key pair.
Enter file in which to save the key (/home/liuhongdi/.ssh/id_rsa): 
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /home/liuhongdi/.ssh/id_rsa
Your public key has been saved in /home/liuhongdi/.ssh/id_rsa.pub
...

把公钥上传到管理项目所在目录

然后提交新用户公钥到gitolite-admin项目中

[root@blog gitolite-admin]# git add -A
[root@blog gitolite-admin]# git commit -m "add user liuhongdi";
[master 957bfaf] add user liuhongdi
 1 file changed, 1 insertion(+)
 create mode 100644 keydir/liuhongdi.pub
[root@blog gitolite-admin]# git push origin master
Enumerating objects: 6, done.
Counting objects: 100% (6/6), done.
Delta compression using up to 8 threads
Compressing objects: 100% (4/4), done.
Writing objects: 100% (4/4), 801 bytes | 801.00 KiB/s, done.
Total 4 (delta 0), reused 0 (delta 0), pack-reused 0
To ssh://localhost:22/gitolite-admin
   794ac5e..957bfaf  master -> master

3, 新建一个项目并提交:管理服务器

[root@blog gitolite-admin]# cd conf/
[root@blog conf]# ls
gitolite.conf
[root@blog conf]# vi gitolite.conf

修改后内容:

repo gitolite-admin
    RW+     =   admin

repo testing
    RW+     =   @all

@gsGroup=admin  liuhongdi
repo api
    RW+ =   @gsGroup

 提交

[root@blog conf]# git status
On branch master
Your branch is up to date with 'origin/master'.

Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
        modified:   gitolite.conf

Untracked files:
  (use "git add <file>..." to include in what will be committed)
        .gitolite.conf.swp

no changes added to commit (use "git add" and/or "git commit -a")
[root@blog conf]# rm .gitolite.conf.swp
rm: remove regular file '.gitolite.conf.swp'? y
[root@blog conf]# git status
On branch master
Your branch is up to date with 'origin/master'.

Changes not staged for commit:
  (use "git add <file>..." to update what will be committed)
  (use "git restore <file>..." to discard changes in working directory)
        modified:   gitolite.conf

no changes added to commit (use "git add" and/or "git commit -a")
[root@blog conf]# git add -A
[root@blog conf]# git commit -m "add repo api";
[master affb07b] add repo api
 1 file changed, 5 insertions(+)
[root@blog conf]# git status
On branch master
Your branch is ahead of 'origin/master' by 1 commit.
  (use "git push" to publish your local commits)

nothing to commit, working tree clean
[root@blog conf]# git push origin master
Enumerating objects: 7, done.
Counting objects: 100% (7/7), done.
Delta compression using up to 8 threads
Compressing objects: 100% (3/3), done.
Writing objects: 100% (4/4), 397 bytes | 397.00 KiB/s, done.
Total 4 (delta 0), reused 0 (delta 0), pack-reused 0
remote: hint: Using 'master' as the name for the initial branch. This default branch name
remote: hint: is subject to change. To configure the initial branch name to use in all
remote: hint: of your new repositories, which will suppress this warning, call:
remote: hint:
remote: hint:   git config --global init.defaultBranch <name>
remote: hint:
remote: hint: Names commonly chosen instead of 'master' are 'main', 'trunk' and
remote: hint: 'development'. The just-created branch can be renamed via this command:
remote: hint:
remote: hint:   git branch -m <name>
remote: Initialized empty Git repository in /home/git/repositories/api.git/
To ssh://localhost:22/gitolite-admin
   957bfaf..affb07b  master -> master

五,客户端配置项目

下载新项目:

新项目为空,所以提示是空仓库

liuhongdi@lhdpc:~/work/api$ git clone ssh://git@8.1.2.3:22/api
正克隆到 'api'...
warning: 您似乎克隆了一个空仓库

提交修改等功能也可以使用了

liuhongdi@lhdpc:~/work/api/api$ git config --global user.email "lhd@qq.com"
liuhongdi@lhdpc:~/work/api/api$ git config --global user.name "laoliu"
liuhongdi@lhdpc:~/work/api/api$ git add -A
liuhongdi@lhdpc:~/work/api/api$ git commit -m "info";
[master (根提交) 33122a6] info
 1 file changed, 3 insertions(+)
 create mode 100644 info.php
liuhongdi@lhdpc:~/work/api/api$ 
liuhongdi@lhdpc:~/work/api/api$ git status
位于分支 master
您的分支基于 'origin/master',但此上游分支已经不存在。
  (使用 "git branch --unset-upstream" 来修复)

无文件要提交,干净的工作区
liuhongdi@lhdpc:~/work/api/api$ git push origin master
枚举对象: 3, 完成.
对象计数中: 100% (3/3), 完成.
写入对象中: 100% (3/3), 217 字节 | 217.00 KiB/s, 完成.
总共 3(差异 0),复用 0(差异 0),包复用 0
To ssh://8.1.2.3:22/api
 * [new branch]      master -> master

六,安装过程的报错处理

1,报错

[git@blog ~]$ ./gitolite/install -to /home/git/bin/
Can't locate FindBin.pm in @INC (you may need to install the FindBin module)
(@INC contains: /usr/local/lib64/perl5/5.32 /usr/local/share/perl5/5.32 
/usr/lib64/perl5/vendor_perl/usr/share/perl5/vendor_perl /usr/lib64/perl5 /usr/share/perl5) 
at ./gitolite/install line 9.
BEGIN failed--compilation aborted at ./gitolite/install line 9.

解决:

安装cpan:

[root@blog ~]# yum install perl-CPAN 

配置cpan

[root@blog ~]# perl -MCPAN -e shell
Terminal does not support AddHistory.
To fix that, maybe try>  install Term::ReadLine::Perl
cpan shell -- CPAN exploration and modules installation (v2.29)
Enter 'h' for help.
cpan[1]> install Term::ReadLine::Perl
...

安装FindBin

[root@blog ~]# cpan FindBin
...

 

 

posted @ 2024-07-16 09:41  刘宏缔的架构森林  阅读(42)  评论(0编辑  收藏  举报