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 这样的工具就可能会迷惑。 另起空行后,再进一步补充其他说明。 - 可以使用这样的条目列举式。 - 一般以单个空格紧跟短划线或者星号作为每项条目的起始符。每个条目间用一空行隔开。 不过这里按自己项目的约定,可以略作变化。