首页 > 代码库 > 分布式版本管理器Git的基础操作与配置指南<二>

分布式版本管理器Git的基础操作与配置指南<二>


一.Git分支介绍与创建

Git中的分支,其实本质上仅仅是个指向commit对象的可变指针。Git回使用master作为分支的默认名

字,在若干次提交后,你其实已经有了一个指向最后一次提交对象的master分支,它在每次提交的时候

都会自动向前移动。

1.Git分支的创建,切换和删除

    git branch 不带参数,它会给出当前所有分支的清单,*表示当前所在的分支    

    git branch -v 附带显示各个分支最后一次commit信息

    git branch testing 创建一个tesing分支,这仅仅是建立一个新分支,但不会自动切换到这个分支上去,此时依然在master分支上工作

    git checkout testing 切换到testing分支

    git checkout -b iss53 新建并切换到该分支iss53
    git merge hotfix 用来合并分支,将当前分支合并到hotfix分支上

    git branch -d hotfix 删除分支hotfix
2.Git分支管理

    git branch --merged 查看哪些分支已经并入当前分支

    git branch --no-merged 查看尚未和并的分支

    git push origin serverfix 把分支serverfix推送到远程仓库origin,git默认拒绝了push操作,需要进行设置,修改.git/config添加如下代码:[receive]   denyCurrentBranch = ignore
    git fetch origin 从远程仓库origin获取数据,在fetch操作抓来的新的远程分支后,无法在本地编辑该远程仓库,如果要把该内容合并到当前分支,可以运行git merge origin/branchname,如果想要一份自己的branchname,可以git checkout -b serverfix orgigin/branchname

    git pull git://github.com/project.git    抓取远程仓库上的数据

二.服务器上的Git
Git可以使用四种主要的协议来传输数据:本地传输,ssh协议,git协议,和http协议

本地协议

    git clone /opt/git/project.git 或者git clone file:///opt/git/project.git
    git remote add local_proj /opt/git/project.git 添加一个本地仓库到现有Git工程

ssh协议

    git clone ssh://user@server:project.git 或者git clone user@server:project.git
http/s协议

    cd /var/www/htdocs
    git clone --bare /path/to/git_project gitproject.git
    cd gitproject.git
    mv hooks/post-update.sample hooks/post-update
    chmod +x hooks/post-update     之后就可clone仓库git clone http://example.com/gitproject.git

在服务器上部署Git

        开始架设 Git 服务器的时候,需要把一个现存的仓库导出为新的纯仓库,纯仓库的目录名以 .git 结尾git clone --bare my_project my_project.git有了仓库的纯副本以后,剩下的就是把它放在服务器上并设定相关的协议。假设一个域名为git.example.com 的服务器已经架设好,并可以通过 SSH 访问,而你想把所有的 Git 仓库储存在 /opt/git 目录下。只要把纯仓库复制上去: scp -r my_project.git user@git.example.com:/opt/git ,现在,其他对该服务器具有ssh访问权限并可以读取/opt/git的用户就可以用一下命令clone
        git clone user@git.example.com:/opt/git/my_project.git

三.实例

实例1:用authorized_keys方法来给用户授权(先做服务器端操作,后做客户机上操作)

在客户机上

ssh-kengen

ssh-copy-id -i id_rsa.pub git@ip(服务器)

cd myproject

git init

git add .

git commit -m "initial commit"

git remote add origin git@gitserver:/opt/git/project.git

git push origin master

Git服务器上

useradd git

passwd git

cd /opt/git

mkdir project.git

cd project.git

git --bare init 生成一个不含工作目录的*空仓库*,这样空仓库本地不能执行git status,git add等动作,适合远程发布仓库

如果往裸仓库放东西的话,可以这样

cd /opt/git/

mkdir project

echo "hello world!" > file1

git add .

git commit -m "initial commit"

git clone --bare project project.git

然后从本地clone该仓库

git clone git@servername:/opt/git/project.git

本地会生成一个project文件夹,file1文件会在此


实例2:公共访问

Git服务器上

mkdir /opt/git/project.git

groupadd www-data

cd project.git

git --bare init

mv hooks/post-update.sample hooks/post-update

chmod +x hooks/post-update更改apache的配置文件<VirtualHost *:80>

   ServerName git.gitserver

   DocumentRoot /opt/git

   <Directory /opt/git/>

       Order allow, deny

       allow from all

   </Directory>

</VirtualHost>

chgrp -R www-data /opt/git

重启apache就可以使用git clone http://git.gitserver/project.git