纯用SSH管理GIT服务器


gitosis等管理git服务器有点小复杂,一般小规模开发没必要用,仅仅依靠Linux的SSH就可以管理了。步骤如下


1 添加用户,并准备公钥私钥

添加用户git,密码也是git

adduser danny
passwd danny
adduser git
passwd git

root用产生公钥在/root/.ssh/id_rsa下面

ssh-keygen -t rsa

然后分别su danny / su git,同样执行

ssh-keygen -t rsa  

回到root下执行

cp /home/danny/.ssh/id_rsa.pub /home/git/.ssh/danny_rsa.pub

cd /home/git/.ssh/

cat danny_rsa.pub >> authorized_keys

cat authorized_keys

rm -rf danny_rsa.pub

chown git authorized_keys

mkdir /home/git/repos

chown -R git /home/git/repos

2 建立测试项目

切换到git用户,进入git主目录,建立testproject

su git

cd ~

mkdir /home/git/repos/testproject

cd /home/git/repos/testproject

初始化git库
git init

设置用户
git config user.email "[email protected]"
git config user.name "git"


在该目录下建立一个test文件,并提交。
vi test

git add test

git add --all 添加所有待添加文件

git commit -a -m "add test by git"

此时就建立了基础代码库。

创建分支,初始默认为master分支。注意:服务端当前所在分支不允许其他用户提交。

git branch develop
查看分支
git branch
切换分支
git checkout develop

这里我们只允许其它用户把修改提交到develop分支上,然后由管理员维护master分支,所以我们切回master分支。

git checkout master

3 克隆测试项目

切换到danny用户,进入danny的主目录

su danny

cd ~

git clone git@localhost:/home/git/repos/testproject

注意:clone只下载当前目录有的文件,不管你在master还是develop分支,只下载当前目录下有的文件。本例子中由于上面git切换回master分支了,所以这里clone的是master分支下的内容。

cd testproject

设置用户
git config user.email "[email protected]"
git config user.name "danny"


在该目录下建立一个test文件,并提交。注意此时只是提交到danny目录下的库,并没有提交到git用户目录下的库。
vi test2

git add test2

git commit -a -m "add test2 by danny"

此时可以把更改提交到服务器上,由于git用户在master分支上,所以不能提交到master分支,只能提交到develop分支。

git push (origin master)改命令会报错refusing to update checked out branch: refs/heads/master

git push origin master:develop 把本地master分支提交到远程的develop分支

如果git用户想看到test2,必须切换到master分支。

4 在windows下,使用TortoiseGit连接

在管理员windows机器上通过mysygit的bash命令生成公钥,私钥;在 C:\Documents and Settings\Administrator\.ssh 目录下

ssh-keygen -t rsa

使用 D:\Program Files\TortoiseGit\bin\puttygen.exe,存为putty专用格式

"Load" Administrator\.ssh 目录下的id_rsa

"Save private kay" putty.ppk

同时将公钥中的那行复制到git/.ssh/authorized_keys中

使用TortoiseGit clone一个项目

ssh://[email protected]/home/git/repos/testproject

勾上Load Putty key "C:\Documents and Settings\Administrator\.ssh\putty.ppk"

注意此时远程的master和develop分支已经不一致了,develop分支多一个test2文件,由于git用户在master下面,所以clone下来只有test文件。必须pull最新的develop分支。

git pull origin develop

此时在本地添加test3文件并提交到git用户的develop分支。

git push origin master:develop

注意:不能push到服务器上当前所在的master分支,会报错。

你可能感兴趣的:(软件工程)