一.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://[email protected]:project.git 或者git clone [email protected]: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 [email protected]:/opt/git ,现在,其他对该服务器具有ssh访问权限并可以读取/opt/git的用户就可以用一下命令clone
git clone [email protected]:/opt/git/my_project.git
三.实例
实例1:用authorized_keys方法来给用户授权(先做服务器端操作,后做客户机上操作)
在客户机上
ssh-kengen
ssh-copy-id -i id_rsa.pub [email protected](服务器)
cd myproject
git init
git add .
git commit -m "initial commit"
git remote add origin [email protected]:/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 [email protected]:/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
分布式版本管理器Git的基础操作与配置指南<二>