您的位置:首页 > 编程语言

Git 源代码管理器使用小结

2016-03-27 16:47 218 查看
Git
http://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/0013743256916071d599b3aed534aaab22a0db6c4e07fd0000

创建版本库 Repository
cd 进去
pwd 得到当前目录
git init 命令 把目录初始化成git 能够管理的目录 
.git
的目录,这个目录是Git来跟踪管理版本库的
如果你没有看到
.git
目录,那是因为这个目录默认是隐藏的,用
ls -ah
命令就可以看见。

source Tree 和 GitLab 项目的搭建与使用
http://wenku.baidu.com/link?url=R1MMRLANKnW2eMX0bwIBKafsF8kiOIChZRUu_FTlOVMDj6GVDX9O5WRHiijyy_58mqj1ssZTV0h8DSYJLmCeBMGXKB3byNNeh3ZWkRvQdM3

git init 产生的目录解释
error: src refspec master does not match any.
引起该错误的原因是,目录中没有文件,空目录是不能提交上去的

[/code]

error: insufficient permission for adding an object to repository database ./objects

服务端没有可写目录的权限


错误提示:fatal: remote origin already exists.

解决办法:$ git remote rm origin

错误提示:error: failed to push som refs to ........

解决办法:$ git pull origin master //先pull 下来 再push 上去


git init //在当前项目工程下履行这个号令相当于把当前项目git化,变身!

git add .//把当前目次下代码参加git的跟踪中,意思就是交给git经管,提交到本地库

git add <file> //把当前文件参加的git的跟踪中,交给git经管,提交到本地库

git commit -m “…”//相当于写点提交信息

git remote add origin git@github.com:ellocc/gittest.git //这个相当于指定本地库与github上的哪个项目相连

git push -u origin master //将本地库提交到github上。

git clone git@github.com:ellocc/gittest.git  //将github上的项目down下来。

git fetch origin //取得长途更新,这里可以看做是筹办要取了

git merge origin/master //把更新的内容归并到本地分支/master

下面是删除文件后的提交

git status //可以看到我们删除的哪些文件

git add .   //删除之后的文件提交git经管。

git rm a.c //删除文件

git rm -r gittest //删除目次

 
git reset --hard HEAD 回滚到add之前的状态

git diff比较的是跟踪列表中的文件和文件系统中文件的差别


git 删除远程分支 和 本地分支
一不小心把本地的临时分支push到server上去了,想要删除。
一开始用
git branch -r -d origin/branch-name

不成功,发现只是删除的本地对该远程分支的track,正确的方法应该是这样:
git push origin :branch-name


冒号前面的空格不能少,原理是把一个空分支push到server上,相当于删除该分支。

git 神奇的分支 通过 head 指针来调配

git 学习路径
   远程主机 master 主干下的 origin  和 dev 分支
git 默认在  git clone 的时候远程和本地的同名分支下建立一次 tracking
git 可以手动调整tracking   
git branch --set-upstream master origin/next


git 还能做一次 fetch 和 merge 方式

     remotes/origin/dev  :  主干 master 本地分支dev 
git  pull origin dev: dev



$ git pull <远程主机名> <远程分支名>:<本地分支名>http://www.yiibai.com/git/git_pull.html

git pull命令的作用是,取回远程主机某个分支的更新,再与本地的指定分支合并。它的完整格式稍稍有点复杂。

$ git pull <远程主机名> <远程分支名>:<本地分支名>

比如,取回origin主机的next分支,与本地的master分支合并,需要写成下面这样。
$ git pull origin next:master

如果远程分支是与当前分支合并,则冒号后面的部分可以省略。
$ git pull origin next

上面命令表示,取回origin/next分支,再与当前分支合并。实质上,这等同于先做git fetch,再做git merge。
$ git fetch origin
$ git merge origin/next

在某些场合,Git会自动在本地分支与远程分支之间,建立一种追踪关系(tracking)。比如,在git clone的时候,所有本地分支默认与远程主机的同名分支,建立追踪关系,也就是说,本地的master分支自动”追踪”origin/master分支。
Git也允许手动建立追踪关系。
git branch --set-upstream master origin/next


使用git2.0 
git branch --set-upstream-to origin/next
上面命令指定master分支追踪origin/next分支。

如果当前分支与远程分支存在追踪关系,git pull就可以省略远程分支名。
$ git pull origin

上面命令表示,本地的当前分支自动与对应的origin主机”追踪分支”(remote-tracking branch)进行合并。
如果当前分支只有一个追踪分支,连远程主机名都可以省略。

$ git pull

上面命令表示,当前分支自动与唯一一个追踪分支进行合并。
如果合并需要采用rebase模式,可以使用–rebase选项。
$ git pull --rebase <远程主机名> <远程分支名>:<本地分支名>


git 推送
帮当前 head 指向的 repo 推向远程的 dev
git push origin HEAD:dev
 
远程重建 hdw_dev 分支
 git push origin hdw_dev

[jerry@CentOS project]$ git push origin master

上面的命令会产生以下结果。

Counting objects: 4, done.
Compressing objects: 100% (3/3), done.
Writing objects: 100% (3/3), 517 bytes, done.
Total 3 (delta 0), reused 0 (delta 0)
To gituser@git.server.com:project.git
19ae206..d1e19d3 master −> master
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: