说明:Git
是一个分布式的版本控制系统,也就意味着它可以在有网络环境或者没有网络环境的时候使用。而通常情况下会搭建一个服务端,所有用户的更改统一发布到服务端上。
服务器上的Git
一般情况下如果想与他人合作,就需要一个远程的Git
仓库。尽管技术上可以从个人的仓库里推送和拉取修改内容,但我们不鼓励这样做,因为一不留心就很容易弄混其他人的进度。另外,你也一定希望合作者们即使在自己不开机的时候也能从仓库获取数据—拥有一个更稳定的公共仓库十分有用。因此,更好的合作方式是建立一个大家都可以访问的共享仓库,从那里推送和拉取数据。我们将把这个仓库称为 "Git 服务器";代理一个Git
仓库只需要花费很少的资源,几乎从不需要整个服务器来支持它的运行。
更多参考:服务器上的 Git
Git的安装
# CentOS REHL
# yum install git
# Ubuntu
# sudo apt-get install git
# Windows
访问:http://git-scm.com/download/
部署Git
本文主要介绍通过SSH
的方式访问Git
的部署。
1、在客户端生成公钥
每个需要使用Git
服务器的客户端都需要生成这个公钥,然后将它们全部上传到服务器。
使用命令:
$ ssh-keygen
或者指定密钥算法和用户标识:
$ ssh-keygen -t rsa -C "[email protected]"
然后在你的用户文件夹下,会生成一个.ssh
文件夹,里边有两个文件:id_rsa
(私钥,不要泄漏)id_rsa.pub
(公钥,复制到服务器上)
cat ~/.ssh/id_rsa.pub
ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAklOUpkDHrfHY17SbrmTIpNLTGK9Tjom/BWDSU
GPl+nafzlHDTYW7hdI4yZ5ew18JH4JW9jbhUFrviQzM7xlELEVf4h9lFX5QVkbPppSwg0cda3
Pbv7kOdJ/MTyBlWXFCR+HAo3FXRitBqxiX1nKhXpHAZsMciLq8V6RjsNAQwdsdMFvSlVK/7XA
t3FaoJoAsncM1Q9x5+3V0Ww68/eIFmb1zuUFljQJKprrX88XypNDvjYNby6vw/Pb0rwert/En
mZ+AW4OZPnTPI89ZPmVMLuayrD2cE86Z/il8b+gw3r3+1nKatmIkjn2so1d01QraTlMqVSsbx
NrRFi9wrf+M7Q== [email protected]
2、服务端搭建
新建git
用户:
# useradd git
# su - git
$ mkdir ~/.ssh
$ chmod 700 ~/.ssh
$ cd ~/.ssh
$ touch authorized_keys
$ chmod 600 authorized_keys
请注意,.ssh
文件夹的权限为700
,authorized_keys
文件的权限为600
,一定要这样设置,不然无法生效。
将公钥添加到authorized_keys
,一行一个。
$ cat /tmp/id_rsa.john.pub >> ~/.ssh/authorized_keys
$ cat /tmp/id_rsa.josie.pub >> ~/.ssh/authorized_keys
$ cat /tmp/id_rsa.jessica.pub >> ~/.ssh/authorized_keys
创建裸仓库:
$ mkdir ~/project.git
$ cd ~/project.git
$ git --bare init
将git
用户设置为不可使用shell
:
# sudo vim /etc/passwd
最后一行应该类似于:
git:x:1000:1000::/home/git:/bin/bash
将/bin/bash
改为/usr/bin/git-shell
(使用which git-shell
查看路径)
git:x:1000:1000::/home/git:/usr/bin/git-shell
客户端使用
git clone git@server:/home/git/project.git
如果目录在git
的用户目录下,可以省略/home/git
git clone git@server:project.git
如果配置正常,应该可以直接拉下来了。如果不正常,一般是会让输入密码或者提示权限不足,请重新看一下本教程,确认无误。