首页 > 系统 > Linux > 正文

Linux中使用Gitolite搭建Git服务器,服务器和客户端可以为同一台

2024-08-27 23:58:37
字体:
来源:转载
供稿:网友

在linux系统中我们可以直接使用Gitolite 搭建 Git 服务器了,下面本文章就给各位介绍详细的配置过程,希望能帮助到大家。

一般来说,配置git服务器的话,需要一台服务器,还需要一个客户端来验证服务器是否搭建成功,而一般开发者基本都只有一台服务器,那就需要这台服务器既作为Git的服务器,又要作为客户端来使用了,下面的教程就是以服务器和客户端都是同一台服务器为例的。如果需要服务器和客户端分开的话,只需要将下面列出的服务器端和客户端的操作到相应的机器上操作就可以了。

第一步,服务器端创建git服务器专用账户,账户名字就叫git吧,创建之后为其设置密码,代码如下:

  1. # useradd -m -s /bin/bash git 
  2. # passwd git 
  3. Enter new UNIX password:  
  4. Retype new UNIX password:  
  5. passwd: password updated successfully 

切换到git用户,在家目录/home/git下创建安装目录bin,代码如下:

  1. root@letuknowit:~# su - git 
  2. git@letuknowit:~$ mkdir bin 
  3. git@letuknowit:~$ ll 
  4. total 24 
  5. drwxr-xr-x 3 git  git  4096 Aug 20 10:38 ./ 
  6. drwxr-xr-x 8 root root 4096 Aug 20 10:36 ../ 
  7. -rw-r--r-- 1 git  git   220 Apr  3  2012 .bash_logout 
  8. -rw-r--r-- 1 git  git  3486 Apr  3  2012 .bashrc 
  9. drwxrwxr-x 2 git  git  4096 Aug 20 10:38 bin/ 
  10. -rw-r--r-- 1 git  git   675 Apr  3  2012 .profile 

获取 Gitolite 并安装,gitolite要安装在服务器端,安装之前要保证系统上已经安装了git,代码如下:

  1. git@letuknowit:~$ git clone git://github.com/sitaramc/gitolite 
  2. Cloning into 'gitolite'... 
  3. remote: Counting objects: 8682, done. 
  4. remote: Total 8682 (delta 0), reused 0 (delta 0) 
  5. Receiving objects: 100% (8682/8682), 3.61 MiB | 33 KiB/s, done. 
  6. Resolving deltas: 100% (4917/4917), done. 
  7. git@letuknowit:~$ ll 
  8. total 28 
  9. drwxr-xr-x 4 git  git  4096 Aug 20 10:40 ./ 
  10. drwxr-xr-x 8 root root 4096 Aug 20 10:36 ../ 
  11. -rw-r--r-- 1 git  git   220 Apr  3  2012 .bash_logout 
  12. -rw-r--r-- 1 git  git  3486 Apr  3  2012 .bashrc 
  13. drwxrwxr-x 2 git  git  4096 Aug 20 10:38 bin/ 
  14. drwxr-xr-x 6 git  git  4096 Aug 20 10:40 gitolite/ 
  15. -rw-r--r-- 1 git  git   675 Apr  3  2012 .profile 
  16. git@letuknowit:~$ gitolite/install -ln 
  17. git@letuknowit:~$ ll 
  18. total 28 
  19. drwxr-xr-x 4 git  git  4096 Aug 20 10:40 ./ 
  20. drwxr-xr-x 8 root root 4096 Aug 20 10:36 ../ 
  21. -rw-r--r-- 1 git  git   220 Apr  3  2012 .bash_logout 
  22. -rw-r--r-- 1 git  git  3486 Apr  3  2012 .bashrc 
  23. drwxrwxr-x 2 git  git  4096 Aug 20 10:44 bin/ 
  24. drwxr-xr-x 6 git  git  4096 Aug 20 10:40 gitolite/ 
  25. -rw-r--r-- 1 git  git   675 Apr  3  2012 .profile 

第二步,客户端,创建 Gitolite 服务器管理员用户,并创建管理员用户密钥.

因为我们是在同一台服务器上,直接exit退回到root用户,之后变身为客户端模式,如果客户端和服务器分开的话,不需要exit指令了,直接在客户端执行添加用户的指令就可以了,这里的Gitolite服务器管理员用户名我们叫gitAdmin,代码如下:

  1. git@letuknowit:~$ exit 
  2. logout 
  3. root@letuknowit:~# useradd -m -s /bin/bash gitAdmin 
  4. root@letuknowit:~# passwd gitAdmin 
  5. Enter new UNIX password:  
  6. Retype new UNIX password:  
  7. passwd: password updated successfully 

切换到gitAdmin用户,创建用户密钥,代码如下:

  1. root@letuknowit:~# su - gitAdmin  
  2. gitAdmin@letuknowit:~$ mkdir .ssh 
  3. gitAdmin@letuknowit:~$ ll 
  4. total 24 
  5. drwxr-xr-x 3 gitAdmin gitAdmin 4096 Aug 20 10:48 ./ 
  6. drwxr-xr-x 9 root     root     4096 Aug 20 10:46 ../ 
  7. -rw-r--r-- 1 gitAdmin gitAdmin  220 Apr  3  2012 .bash_logout 
  8. -rw-r--r-- 1 gitAdmin gitAdmin 3486 Apr  3  2012 .bashrc 
  9. -rw-r--r-- 1 gitAdmin gitAdmin  675 Apr  3  2012 .profile 
  10. drwxrwxr-x 2 gitAdmin gitAdmin 4096 Aug 20 10:48 .ssh/ 
  11. gitAdmin@letuknowit:~$ ssh-keygen -f .ssh/gitAdmin 
  12. Generating public/private rsa key pair. 
  13. Enter passphrase (empty for no passphrase):  
  14. Enter same passphrase again:  
  15. Your identification has been saved in .ssh/gitAdmin. 
  16. Your public key has been saved in .ssh/gitAdmin.pub. 
  17. The key fingerprint is
  18. 84:a0:9d:d6:c6:43:57:0e:22:cd:67:97:8e:03:be:09 gitAdmin@letuknowit 
  19. The key's randomart image is
  20. +--[ RSA 2048]----+ 
  21. |    ooo o...     | 
  22. |   o B++ooo      | 
  23. |  . +.*+.+.      | 
  24. |   .E..oo .      | 
  25. |     . oS.       | 
  26. |      o          | 
  27. |                 | 
  28. |                 | 
  29. |                 | 
  30. +-----------------+ 

接下来将管理员公钥(gitAdmin.pub)复制 到服务器上的 git 用户的家目录下,因为我们这个服务器和客户端是在一起的,所以就方便了,如果是两台机器的话,你可能要想点办法去拷贝这个文件了,代码如下:

  1. gitAdmin@letuknowit:~$ exit 
  2. logout 
  3. root@letuknowit:~# cp /home/gitAdmin/.ssh/gitAdmin.pub /home/git/ 
  4. root@letuknowit:~# ll /home/git 
  5. total 36 
  6. drwxr-xr-x 4 git  git  4096 Aug 20 10:53 ./ 
  7. drwxr-xr-x 9 root root 4096 Aug 20 10:46 ../ 
  8. -rw------- 1 git  git   788 Aug 20 10:45 .bash_history 
  9. -rw-r--r-- 1 git  git   220 Apr  3  2012 .bash_logout 
  10. -rw-r--r-- 1 git  git  3486 Apr  3  2012 .bashrc 
  11. drwxrwxr-x 2 git  git  4096 Aug 20 10:44 bin/ 
  12. -rw-r--r-- 1 root root  412 Aug 20 10:53 gitAdmin.pub 
  13. drwxr-xr-x 6 git  git  4096 Aug 20 10:40 gitolite/ 
  14. -rw-r--r-- 1 git  git   675 Apr  3  2012 .profile 

第三步,服务器端配置 Gitolite 服务器,再回到服务器端,用从客户端复制过来的 Gitolite 管理员用户公钥,gitAdmin.pub,配置 Gitolite 服务器,代码如下:

  1. root@letuknowit:~# su - git 
  2. git@letuknowit:~$ gitolite setup -pk gitAdmin.pub  
  3. Initialized empty Git repository in /home/git/repositories/gitolite-admin.git/ 
  4. Initialized empty Git repository in /home/git/repositories/testing.git/ 
  5. WARNING: /home/git/.ssh missing; creating a new one 
  6.     (this is normal on a brand new install) 
  7. WARNING: /home/git/.ssh/authorized_keys missing; creating a new one 
  8.     (this is normal on a brand new install) 
  9. git@letuknowit:~$ ll 
  10. total 60 
  11. drwxr-xr-x 7 git  git  4096 Aug 20 10:57 ./ 
  12. drwxr-xr-x 9 root root 4096 Aug 20 10:46 ../ 
  13. -rw------- 1 git  git   788 Aug 20 10:45 .bash_history 
  14. -rw-r--r-- 1 git  git   220 Apr  3  2012 .bash_logout 
  15. -rw-r--r-- 1 git  git  3486 Apr  3  2012 .bashrc 
  16. drwxrwxr-x 2 git  git  4096 Aug 20 10:44 bin/ 
  17. -rw-r--r-- 1 root root  412 Aug 20 10:53 gitAdmin.pub 
  18. drwxr-xr-x 6 git  git  4096 Aug 20 10:40 gitolite/ 
  19. drwx------ 6 git  git  4096 Aug 20 10:57 .gitolite/ 
  20. -rw------- 1 git  git  6662 Aug 20 10:57 .gitolite.rc 
  21. -rw-r--r-- 1 git  git   675 Apr  3  2012 .profile 
  22. -rw------- 1 git  git    12 Aug 20 10:57 projects.list 
  23. drwx------ 4 git  git  4096 Aug 20 10:57 repositories/ 
  24. drwx------ 2 git  git  4096 Aug 20 10:57 .ssh/ 

你会看到在git用户的家目录下多了很多的文件夹,具体请看上面ll命令的结果.

第四步,客户端验证Gitolite管理员账户访问服务器的别名以及验证别名是否成功,代码如下:

  1. git@letuknowit:~$ exit 
  2. logout 
  3. root@letuknowit:~# su - gitAdmin 
  4. gitAdmin@letuknowit:~$ ll .ssh/ 
  5. total 16 
  6. drwxrwxr-x 2 gitAdmin gitAdmin 4096 Aug 20 10:49 ./ 
  7. drwxr-xr-x 3 gitAdmin gitAdmin 4096 Aug 20 10:53 ../ 
  8. -rw------- 1 gitAdmin gitAdmin 1679 Aug 20 10:49 gitAdmin 
  9. -rw-r--r-- 1 gitAdmin gitAdmin  412 Aug 20 10:49 gitAdmin.pub 
  10. gitAdmin@letuknowit:~$ vi .ssh/config 

切换到gitAdmin账户,在.ssh文件夹下新建config文件,输入下面内容:

  1. host git 
  2.         user git 
  3.         hostname xxx.xxx.xxx.xxx 
  4.         port 22 
  5.         identityfile ~/.ssh/gitAdmin 

host:随便定义,用于客户端标识所连接服务端的名字;

user:ssh登录服务器的账户,就是服务器端的那个git专用账户的用户名;

hostname:服务器主机名,或者直接填写服务器 IP 地址;

port:服务器的ssh访问端口,默认22;

identityfile:管理员登录服务器所使用的验证密钥;

使用服务器别名从 Gitolite 服务器 clone Gitolite 服务器管理仓库 gitolite-admin,验证别名配置是否成功,代码如下:

  1. gitAdmin@letuknowit:~$ git clone git:gitolite-admin 
  2. Cloning into 'gitolite-admin'... 
  3. The authenticity of host 'xxx.xxx.xxx.xxx (xxx.xxx.xxx.xxx)' can't be established. 
  4. ECDSA key fingerprint is c1:c2:6a:7a:68:c8:e5:a6:87:f4:9b:95:d5:fd:ff:09. 
  5. Are you sure you want to continue connecting (yes/no)? yes 
  6. Warning: Permanently added 'xxx.xxx.xxx.xxx' (ECDSA) to the list of known hosts.  --Vevb.com 
  7. remote: Counting objects: 6, done. 
  8. remote: Compressing objects: 100% (4/4), done. 
  9. Receiving objects: 100% (6/6), 763 bytes, done. 
  10. remote: Total 6 (delta 0), reused 0 (delta 0) 

第五步,客户端给普通用户创建访问 Gitolite 服务器的密钥.

系统里已经有一个kris的账户了,如果没有的话,可以自己创建一个,名字随便取,先通过ssh-keygen创建密钥,代码如下:

  1. gitAdmin@letuknowit:~$ exit 
  2. logout 
  3. root@letuknowit:~# su - kris 
  4. kris@letuknowit:~$ ssh-keygen -f .ssh/kris 
  5. Generating public/private rsa key pair. 
  6. Enter passphrase (empty for no passphrase):  
  7. Enter same passphrase again:  
  8. Your identification has been saved in .ssh/kris. 
  9. Your public key has been saved in .ssh/kris.pub. 
  10. The key fingerprint is
  11. 18:7c:21:e8:7b:4c:2a:d9:b2:e2:eb:db:5b:94:65:49 kris@letuknowit 
  12. The key's randomart image is
  13. +--[ RSA 2048]----+ 
  14. |     ..E.        | 
  15. |    ......       | 
  16. |   .  o+.        | 
  17. |    . =+         | 
  18. |   o B. S        | 
  19. |  + = o          | 
  20. |   + o           | 
  21. |. o .            | 
  22. |o*oo.            | 
  23. +-----------------+ 
  24. kris@letuknowit:~$ ll .ssh/ 
  25. total 20 
  26. drwx------ 2 kris kris 4096 Aug 20 11:22 ./ 
  27. drwxr-xr-x 9 kris kris 4096 Aug 20 09:56 ../ 
  28. -rw-r--r-- 1 kris kris  442 Nov 20  2013 known_hosts 
  29. -rw------- 1 kris kris 1679 Aug 20 11:22 kris 
  30. -rw-r--r-- 1 kris kris  410 Aug 20 11:22 kris.pub 

复制用户公钥(kris.pub)给 Gitolite 管理员(gitAdmin),代码如下:

  1. kris@letuknowit:~$ exit 
  2. logout                
  3. root@letuknowit:~# cp /home/kris/.ssh/kris.pub /home/gitAdmin/gitolite-admin/keydir/ 
  4. root@letuknowit:~# ll !$ 
  5. ll /home/gitAdmin/gitolite-admin/keydir/ 
  6. total 16 
  7. drwxrwxr-x 2 gitAdmin gitAdmin 4096 Aug 20 12:09 ./ 
  8. drwxr-xr-x 5 gitAdmin gitAdmin 4096 Aug 20 11:19 ../ 
  9. -rw-rw-r-- 1 gitAdmin gitAdmin  412 Aug 20 11:19 gitAdmin.pub 
  10. -rw-r--r-- 1 root     root      410 Aug 20 12:09 kris.pub 

使用公钥(kris.pub)为用户 kris 创建一个他能访问的 Git 仓库,代码如下:

  1. gitAdmin@letuknowit:~/gitolite-admin$ git add . 
  2. gitAdmin@letuknowit:~/gitolite-admin$ git status -s 
  3. M  conf/gitolite.conf 
  4. A  keydir/kris.pub 
  5. gitAdmin@letuknowit:~/gitolite-admin$ git commit -m "add user kris by kris.git and create a repo letu for it" 
  6. *** Please tell me who you are. 
  7. Run 
  8.   git config --global user.email "you@example.com" 
  9.   git config --global user.name "Your Name" 
  10. to set your account's default identity. 
  11. Omit --global to set the identity only in this repository. 
  12. fatal: empty ident  <gitAdmin@letuknowit.(none)> not allowed 

这里需要先配置下用户名和email,否则会给出错误提示,代码如下:

  1. gitAdmin@letuknowit:~/gitolite-admin$ git config --global user.email "xxx@163.com" 
  2. gitAdmin@letuknowit:~/gitolite-admin$ git config --global user.name "kris" 
  3. gitAdmin@letuknowit:~/gitolite-admin$ git commit -m "add user kris by kris.git and create a repo letu for it" 
  4. [master ef0bde9] add user kris by kris.git and create a repo letu for it 
  5.  2 files changed, 4 insertions(+) 
  6.  create mode 100644 keydir/kris.pub 
  7. gitAdmin@letuknowit:~/gitolite-admin$ git status  
  8. On branch master 
  9. # Your branch is ahead of 'origin/master' by 1 commit
  10. nothing to commit (working directory clean) 
  11. gitAdmin@letuknowit:~/gitolite-admin$ git push origin master  
  12. Counting objects: 10, done. 
  13. Delta compression using up to 2 threads. 
  14. Compressing objects: 100% (5/5), done. 
  15. Writing objects: 100% (6/6), 840 bytes, done. 
  16. Total 6 (delta 0), reused 0 (delta 0) 
  17. remote: Initialized empty Git repository in /home/git/repositories/letu.git/ 
  18. To git:gitolite-admin 
  19.    b19c84d..ef0bde9  master -> master 

切换到拥有私钥(~/.ssh/kris)的用户 kris,尝试使用私钥 clone “letu”这个git库,代码如下:

  1. gitAdmin@letuknowit:~/gitolite-admin$ exit 
  2. logout 
  3. root@letuknowit:~# su - kris 
  4. kris@letuknowit:~$ ll .ssh/ 
  5. total 20 
  6. drwx------ 2 kris kris 4096 Aug 20 11:22 ./ 
  7. drwxr-xr-x 9 kris kris 4096 Aug 20 09:56 ../ 
  8. -rw-r--r-- 1 kris kris  442 Nov 20  2013 known_hosts 
  9. -rw------- 1 kris kris 1679 Aug 20 11:22 kris 
  10. -rw-r--r-- 1 kris kris  410 Aug 20 11:22 kris.pub 
  11. kris@letuknowit:~$ vi .ssh/config 

为了方便,我们这里也给kris用户配置一个访问别名,输入以下内容后保存,代码如下:

  1. host kris 
  2.      user git 
  3.      hostname xxx.xxx.xxx.xxx 
  4.      port 22 
  5.      identityfile ~/.ssh/kris 

下面就可以clone 之前添加的letu这个git库了,代码如下:

  1. kris@letuknowit:~/$ git clone kris:letu 
  2. Cloning into 'letu'... 
  3. warning: You appear to have cloned an empty repository. 
  4. kris@letuknowit:~$ cd letu/ 
  5. kris@letuknowit:~/letu$ git status  
  6. On branch master 
  7. # Initial commit 
  8. nothing to commit (create/copy files and use "git add" to track) 
  9. kris@letuknowit:~/letu$ echo "Hello git" > init.txt 
  10. kris@letuknowit:~/letu$ git add . 
  11. kris@letuknowit:~/letu$ git status . 
  12. On branch master 
  13. # Initial commit 
  14. # Changes to be committed
  15. #   (use "git rm --cached ..." to unstage) 
  16. # new file:   init.txt 
  17. kris@letuknowit:~/letu$ git commit -m "Init repo" 
  18. kris@letuknowit:~/letu$ git push origin master

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表