导航

git命令2

Posted on 2017-12-22 16:50  Simon1020  阅读(333)  评论(0编辑  收藏  举报

git status

git status -s

git diff

git diff --cached

 

--添加到暂存区成为快照

  git add -A

  git add .

--删除被git追踪的文件

  git rm [file]

  git rm --cached [file]  只删除暂存区,保留工作区(支持glob匹配莫斯)  

--重命名文件

  git mv [file]

--查看历史

  git log

  git log -p 2

  git log --stat

  git log --pretty=oneline

  git log --pretty=format:"%h - %an, %ar %s"

  git log --pretty=format:"%h %s" --graph

  git log --since=2.weeks

  git log --pretty="%h - %s" --authr=gitster --since="2017-10-01" \

  --before="2017-10-30" --no-merges -- t/

--修改操作

  git commit --amend [file] 用暂存区的内容覆盖最后的提交, 并修改最后一次的commit信息

--取消暂存

  git reset [file]   把head和分支名的引用指向我们这个commit

          //--mixed(默认): 还原暂存区

          //--hard:     还原工作区 和 暂存区 

          //--soft:       不还原

  *注: 命令git reset HEAD file意思就是: 用此刻head上的已提交的内容覆盖暂存区**(默认是--mixed: git reset --mixed HEAD file)

    命令git checkout -- readme.txt意思就是: 用此刻head上的已提交的内容回到这个文件最近一次git commit或git add时的状态。

--撤销修改

  git checkout -- [file]  

 


 

远程仓库的使用

-- 查看远程仓库

  git clone <url>        命令会自动设置本地 master 分支跟踪克隆的远程仓库的 master 分支(或不管是什么名字的默认分支)。

                 运行 git pull 通常会从最初克隆的服务器上抓取数据并自动尝试合并到当前所在的分支。

  git remote -v

--添加一个远程仓库

  git remote add origin2 <url>  现在你可以用origin2来代替URL

                 例如: git fetch origin2 

  git remote -v

  

--从远程仓库抓取与拉取

  git fetch [remote-name]   拉取所有你还没有的数据。 执行完成后,你将会拥有那个远程仓库中所有分支的引用,可以随时合并或查看。

               它并不会自动合并或修改你当前的工作。 当准备好时你必须手动将其合并入你的工作。

  git pull          如果你有一个分支设置为跟踪一个远程分支, git pull 命令来自动的抓取然后合并远程分支到当前分支

--推送到远程仓库

  git push [remote-name] [branch-nane]

  git push origin master    master 分支名扩展为 refs/heads/master:refs/heads/master

-- 查看远程仓库

  git remote show [remote-name]

--远程仓库的删除和重命名

  git remote rename [old-remote-name] [new-remote-name]

  git remote rm [remote-name]

 


 标签

--查找标签

  git tag -l 'v1.8.2*'

--创建标签 轻量标签(lightweight)与附注标签(annotated)

  git tag -a v1.4 -m 'version 1.4'  附注标签

  git show            输出显示了打标签者的信息、打标签的日期时间、附注信息,然后显示具体的提交信息。

  git tag  v1.4-lw

--后期打标签 

  git log --pretty=oneline

  git tag -a v1.2 9fceg01

--共享标签

  git push origin v1.2

  git push orgin --tags  这将会把所有不在远程仓库服务器上的标签全部传送到那里。

--检出标签

  git chekout -b version2 v2.0.0  在特定的标签上创建一个新分支

                 如果在这之后又进行了一次提交,version2 分支会因为改动向前移动了,那么 version2 分支就会和 v2.0.0 标签稍微有些不同,

                 这时就应该当心了。

 


分支

  git checkut -b hotfix origin/master  //以origin/master为起点创建分支(此时hotfix相当于master了)

    git commit -am "xxx"

  git checkout master

  git merge hotfix  快进(fast-forward)

  git branch -d hotfix

  git checkout iss53

    git commit -am "xxx"

  git checkout master

  git merge iss53

  git status  /  git commit -am "xxx"  如果有冲突,解决

  

git branch -v

git btanch --merged

git branch --no-merged

  


 

远程分支


--推送本地分支

  git push origin serverfix         推送serverfix分支

  git push origin sererfix:awesomebranch   你可以把本地分支推送到某个命名不同的远程分支

  git fetch origin     当你的协作者再次从服务器上获取数据时,他们将得到一个新的远程分支 origin/awesomebranch,并指向服务器上 awesomebranch 所指向的版本

  

  git merge origin/awesomebranch    把该远程分支的内容合并到当前分支

--跟踪远程分支

  git checkout -b [分支名] [远程名]/[分支名]

  git checkout --track origin/serverfix  

  git checkout -b sf origin/serverfix    起别名   

--删除远程分支

  git push [远程名] [本地分支]:[远程分支] 语法,如果省略 [本地分支],那就等于是在说“在这里提取空白然后把它变成[远程分支]

  git push :serverfix          //删除远程分支

    git branch -d serverfix      //删除本地分支

    git push --delete origin serverfix  //删除远程分支

 --衍合 变基

  git checkout expreiment

  git rebase master    //变基操作

  git checkout master

  git merge expreiment  //此时的三方合并, 变成了快合并, 成一条线性的历史

  注: 不要对在你的仓库外有副本的分支执行变基。也就是一旦分支中的提交对象发布到公共仓库,就千万不要对该分支进行衍合操作。

  加入你或你的同事在某些情形下决定要这么做, 请一定要通知每个人执行 git pull --rebase 命令,这样尽管不能避免伤痛,但能有所缓解。

  git fetch

  git rebase teamone/master

 

 


提交指南

  git diff --check

  git log --no-merges  看看,所有提交历史的说明是怎样撰写的

本次更新的简要描述(50 个字符以内)

    如果必要,此处展开详尽阐述。段落宽度限定在 72 个字符以内。
    某些情况下,第一行的简要描述将用作邮件标题,其余部分作为邮件正文。
    其间的空行是必要的,以区分两者(当然没有正文另当别论)。
    如果并在一起,rebase 这样的工具就可能会迷惑。

    另起空行后,再进一步补充其他说明。

    - 可以使用这样的条目列举式。

    - 一般以单个空格紧跟短划线或者星号作为每项条目的起始符。每个条目间用一空行隔开。
    不过这里按自己项目的约定,可以略作变化。