您的位置:首页 > 其它

my project 中git使用过程(基本操作流程)

2013-11-08 17:05 471 查看
1.g it clone
git@name:server/BM/APPS.git

则BM_APPS.git项目被下载到当前目录下了,这时git@name:server/BM/APPS.git就是自己的origin库。

2.为自己的仓库定义别名

为方便以后操作,可给自己的仓库定义一个别名:

#git remote add fork
git@name:dev/zhangsan/BM/APPS.git

3.checkout 切换到当前的开发分支,作为工作分支

git checkout origin/dev_sp4 -b dev_sp4 (也可以是

等价与两条命令:git branch dev_sp4//先创建分支 再 git checkout dev_sp4)

4.将当前分支push到git Server上的fork库中

#git push fork dev_sp4

这时BM_APPS.git项目即为开发者zhangsan自己的仓库,它相当于是从git@name:server/BM/APPS.git中fork出来的。

5.在本地dev_sp4分支上开发,开发前要先同步代码

git pull origin dev_sp4

开发者在本地进行开发(新建/修改文件)并提交(commit)。

git add .

git commit -a -m "<san_zhang@audiencetouch.com><BMS-749><dev><2011/05/03>fix BMS-749"

6.一般开发流程如下:

开发人员有新的提交后,需要将提交push到自己的fork库中,操作如下:

A.查看origin上dev_sp4分支的修改记录:

#git fetch origin dev_sp4

B.比较看和本地dev_sp4分支有没有改变:

#git diff origin/dev_sp4

C.如果有改变就要建立临时分支合并修改:

#git branch dev_sp4_tmp

#git checkout dev_sp4_tmp

#git rebase origin/dev_sp4 这是远端的内容合并到当前分支(当前为tmp分支)

D.如果有冲突就解决冲突再提交:

一般过程为:

E.将merge这部分修改合并到本地dev_sp4分支:

#git checkout dev_sp4

#git merge dev_sp4_tmp

可以看出总体是,先下载总库(fetch origin)到本地dev分支(rebase),在这个分支上进行开发后,有了提交(add,commit后)。先不能提交(总库可能有变化,别人提交了),此时再fetch 总库,并合到一个新建tmp分支,处理冲突后,将最新总库内容,合并到真分支(checkout
真分支,然后rebase或者merge tmp都行),最后删除tmp

F.如果没有冲突就删除临时分支:

#git branch --d dev_sp4_tmp

G.推送代码到服务器上的fork库:

#git push fork dev_sp4

最后通过邮件或其他方式告知管理员来合并代码。

aso项目git库:

查看 cat .git/config后

[core]

repositoryformatversion = 0

filemode = true

bare = false

logallrefupdates = true

[remote "origin"]

url = git@repo.allfuck.com:aso

fetch = +refs/heads/*:refs/remotes/origin/*

[branch "master"]

remote = origin

merge = refs/heads/master

[branch "waterforest"]

remote = origin

merge = refs/heads/waterforest

url是个内部代理名。我的机器是内部网络机,直接用就可以访问到代理名指定的服务器。

想换成实际ip地址,就要到服务器,去查对应的转换名。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: