centos+git+gitolite 安装和部署

一.部署环境

系统:CentOS 6.4x64 最小化安装

IP:192.168.52.131

git默认使用SSH协议,在服务器上基本上不用怎么配置就能直接使用。但是如果面向团队服务,需要控制权限的话,还是用gitolite方便些。

首先用x-shell 工具链接centos 系统

二.安装基础依赖包

[root@nginx ~]#yum install curl-devel expat-devel gettext-devel openssl-devel zlib-develperl-devel -y

三.在线安装git

[root@bogon ~]# yum -y install git

下载安装包安装方式:

[root@bogon git-2.2.0]#tarxf git-2.2.0.tar.gz

[root@bogon git-2.2.0]#cd  git-2.2.0/[root@bogon git-2.2.0]#makeprefix=/usr/local/git all

[root@bogon git-2.2.0]#makeprefix=/usr/local/gitinstall增加软连接

[root@bogon git-2.2.0]#ln-s /usr/local/git/bin/*/usr/bin/

验证结果,显示出版本号,表示安装成功

[root@bogon git-2.2.0]#git --version

git version 2.2.0

五.创建git用户

[root@bogon ~]# useradd git

# 切换到git用户

[root@bogon~]#su-git

[git@bogon~]$pwd#查看当前位置/home/git

# 确认.ssh/authorized_key是否存在

[git@bogon~]$ls-a

.  ..  .bash_logout  .bash_profile  .bashrc  .gnome2  .mozilla

六.获取git版本库并安装

[git@bogon ~]$ git clone https://github.com/sitaramc/gitolite

centos+git+gitolite 安装和部署_第1张图片

然后创建bin目录并安装gitolite 到bin目录($ 表示普通用户)

[git@bogon ~]$mkdir$HOME/bin

[git@bogon~]$ gitolite/install-to $HOME/bin

[git@bogon~]$ cd bin/[git@bogon bin]$lscommands  gitolite  gitolite-shell  lib  syntactic-sugar  triggers  VERSION  VREF

七.配置gitolite管理员

gitolite 使用特殊的版本库gitolite-admin 来管理用户和版本库,所以需要创建一个管理员来管理所有的用户和版本库

7.1 用git用户生成公钥(注:如果你是接着上面一直做下来的,那么只需要输入cd ,然后回车,则就进入了该用户的目录,如果不是git用户,则需要输入su – git,来切换到git用户)

[git@bogon ~]cd

[git@bogon~]$ssh-keygen-t rsa


centos+git+gitolite 安装和部署_第2张图片

7.2 修改.ssh/id_rsa.pub 为admin.pub(为什么要改成admin.pub 因为gitolite根据这个文件名来设立帐号.我这里用admin

[git@bogon ~]$mv.ssh/id_rsa.pub admin.pub

7.3 使用管理员公钥安装gitolite(然后去/home/git/repositories 里面,可以看见仓库文件.gitolite-admin.git 和test.git 一个是管理仓库的,一个是测试用)

[git@bogon ~]$ $HOME/bin/gitolite setup -pk admin.pub

7.4  生成管理员管理仓库(不需要输密码)

[git@bogon ~]$ git clone [email protected]:gitolite-admin

centos+git+gitolite 安装和部署_第3张图片

进入仓库后可以看到conf 和keydir ,conf/gitolite.conf 是添加用户/仓库的配置, keydir 是放对应用户的公想·x钥.并且此时,admin.pub这个公钥可以删除了

7.5编辑gitolite.conf

[git@bogon ~]$vimgitolite-admin/conf/gitolite.conf

centos+git+gitolite 安装和部署_第4张图片

也可以你找下图操作:

打开图按照下图添加:

centos+git+gitolite 安装和部署_第5张图片

上面的配置含义是:

定义两个用户组: admin 和 user

定义两个版本库: gitolite-admin 和 project

用户admin 对 这两个版本库有(读 写 删除)RW+ 权限

user组对project 有 (读 写)RW 权限

也可按照格式,添加多个组,多个版本库

如有一个组中有多个用户,则以空格为分割,如下图:

centos+git+gitolite 安装和部署_第6张图片

7.6 然后提交修改(注:修改用户或者增加版本库后在下图中的目录中提交修改,否则会提示修改失败)

提交修改:

[git@bogon conf]$git add keydir/test.pub conf/gitolite.conf

[git@bogon conf]$ git add . [git@bogon conf]$ git commit-am"new project"

[git@bogon conf]$ git push origin master

#注:所有的提交修改都是这三条命令,在客户端上提交文件也是这三个命令第二条命令后面引号中的 可以是任意,最好是能体现是做了什么修改

centos+git+gitolite 安装和部署_第7张图片

7.7 提交完后,查看管理仓库中多了一个project.git

[git@bogon ~]$ cd repositories/

[git@bogon repositories]$ls

gitolite-admin.git  project.git

这个时候,服务器已经搭建完毕了,只需要添加用户并给用户添加权限就可以了。下面我们添加用户测试

7.8 权限控制

[root@nginx gitolite-admin]# git status    #查看git库状态

On branch master

Your branch is up-to-datewith'origin/master'.

Changes not stagedforcommit:

(use"git add ..."to update what will be committed)

(use"git checkout -- ..."to discard changesinworking directory)

modified:  conf/gitolite.conf        #表示该文件被修改

Untracked files:  (use"git add ..."to includeinwhat will be committed)

keydir/test.pub        #增加的文件

no changes added to commit (use"git add"and/or"git commit -a")

#将有改动的文件添加到git库

[root@nginx gitolite-admin]# git add keydir/test.pub conf/gitolite.conf

[root@nginx gitolite-admin]# git status

On branch master

Your branch is up-to-datewith'origin/master'.

Changes to be committed:  (use"git reset HEAD ..."to unstage)

modified:  conf/gitolite.conf

newfile:  keydir/test.pub

#这里表示已添加#在第一次执行git commit命令时会有以下提示,需要使用者表明身份

[root@nginx gitolite-admin]# git commit -m"add repo mytest; add user test"*** Please tell mewhoyou are.Run

git config--global user.email"[email protected]"git config--global user.name"Your Name"to set your account's default identity.Omit --global to set the identity onlyinthis repository.

fatal: unable to auto-detect email address (got'root@nginx.(none)')

#在这里我们执行以下2条命令

[root@nginx gitolite-admin]# git config --global user.email"[email protected]"[root@nginx gitolite-admin]# git config --global user.name"lyao"#再重新执行git commit命令

[root@nginx gitolite-admin]# git commit -m"add repo mytest; add user test"[master 7b877e7] add repo mytest;

add user test2files changed,5insertions(+)

create mode100644keydir/test.pub

#执行完以上命令后,修改的文件只是提交在本地了,并没有提交到git server中,还需要执行git push命令

[root@nginx gitolite-admin]# git push origin master    #推送到远端的master分支

Counting objects:6,done.Compressing objects:100% (5/5),done.

Writing objects:100% (6/6),817bytes |0bytes/s,done.

Total6(delta0), reused0(delta0)

remote: Initialized empty Git repositoryin/home/git/repositories/mytest.git/To [email protected]:gitolite-admin

3554f3d..7b877e7  master-> maste

你可能感兴趣的:(centos+git+gitolite 安装和部署)