git 怎么备份本地分支_Git常用个人备份笔记
一、新建代码库
1、在当前目录下创建一个Git代码库
git init
创建的.git默认是隐藏的,使用命令ls -ah显示出来。
2、新建一个目录,并初始化为Git的代码库
git init [dir-name]
3、克隆一个项目包括其提交历史
git clone [url] [local-dir-name]
二、配置
1、显示当前Git配置
git config --list
2、设置提交的时候的用户信息
git config [--global] user.name "username"
git config [--global] user.email "email address"
三、增加删除文件
1、添加指定文件到暂存区
git add [file1] [file2] ···
2、添加指定目录到暂存区,包括子目录
git add [dir name]
3、将当前目录下的所有文件到暂存区(包括当前目录下的已经修改的文件夹)
git add .
4、删除工作区文件,并且将这次删除放入到暂存区
git rm [file1] [file2]
从版本库中找回rm的文件
git checkout --[file]
5、停止追踪指定文件,但该文件会保留到工作区,文件内容不变。
git rm --cached [file]
四、代码提交
1、提交暂存区到版本库
git commit -m [message]
2、提交暂存区的指定文件到仓库
git commit [file1][file2]··· -m [message]
3、提交工作区自上次commit之后的变化,直接到仓库区
git commit -a
4、提交时显示所有的diff信息
git commit -v
5、使用一次新的commit,代替上一次提交;如果代码没有变化,就用来改写上一次的commit提交信息。commit的SHA1会发生改变,上一次的提交的内容不会发生改变。
git commit --amend -m [meesage]
6、重做上一次的commit,并包括指定文件的新变化(此时不需要讲file1和file2添加到暂存区)
git commit --amend [file1] [file2]
五、分支
1、列出所有的分支
git branch
2、列出所有的远程分支
git branch -r
3、新建一个新的分支,但还是停留在当前的分支。工作区会复用,即在master上面修改的内容还没有提交,那么如果新建了一个分支,并切换过去,master的未提交的内容也会跟着带到新的分支。
git branch [branch-name]
4、新建一个分支,并切换到该分支
git checkout -b [branch-name]
5、新建一个分支,并指定指向的commit,此时如果工作区不干净,切换可能会出现失败,需要使用git stash 将当前工作区的修改给隐藏掉。
git branch [branch-name] [commit id]
6、切换到上一个分支
git branch -
7、在当前的分支和指定的远程分支之间建立追踪关系
git branch --set-upstream [branch] [remote-branch]
8、合并指定分支到当前分支
git merge [branch]
9、删除分支
git branch -d [branch-name]
10、删除一个没有被合并过的分支需要使用-D参数:
git branch -D [branch-name]
11、删除远程分支
git push [origin-name] --d [branch-name]
12、新建一个分支,指向某个tag
git checkout -b [branch] [tag]
13、显示分支图
git log --graph
14、修改分支名称
git banch -m [old-name] [new-name]
15、合并多次commit
git rebase -i [commit]
上面的命令表示的是head分支到commit上一个commit的合并,注意不包括该commit。
在弹出的Vim编辑页面输入命令:
Commands:
# p, pick = use commit
# r, reword = use commit, but edit the commit message
# s, squash = use commit, but meld into previous commit
# f, fixup = like "squash", but discard this commit's log message
# x, exec = run command (the rest of the line) using shell
# d, drop = remove commit
# l, label = label current HEAD with a name
# t, reset = reset HEAD to a label
# m, merge [-C | -c ] [# ]
然后wq保存,再弹出一个Vim编辑框,修改commit信息。
16、恢复删除的分支
git reflog 查看之前的这个已经删除的分支的提交历史
git branch
六、标签
1、列出所有标签
git tag
2、新建一个指向当前commit的tag
git tag [tag-name]
3、新建一个tag在指定的commit
git tag [tag-nam] [commit]
4、删除本地tag
git tag -d [tag-name]
5、删除远程tag
git push [origin-name]:refs/tags/[tag-name]
6、查看tag信息
git show tag
7、提交本地所有tag
git push [origin-name] --tags
8、提交指定tag
git push [origin-name] [tag]
七、查看信息
1、查看有变更的文件
git status
2、显示当前分支的版本历史
git log
3、显示commit历史,以及每次commit发生变更的文件
git log --stat
4、显示代码差异
git diff
暂存区没有文件:比较的是当前工作区和上一次的commit的差别。
暂存区有文件:比较的是当前工作区和暂存区的差别。
5、显示暂存区和上一次commit的差异
git diff --cached [file]
6、显示工作区和当前分支的最新commit的差异
git diff head
7、显示两次提交之间的差异(commit1 和 commit的顺序需要注意,不一样会导致新增和删除错位)
git diff [commit1] [commit2]
8、显示某次提交的元数据的和内容变化
git show [commit]
八、远程同步
配置远程仓库:
git remote add test http://xxxx@git.XXXX.com/scm/wbqa/xxxx.git
test为远程仓库的别名,后面的htpp为远程仓库地址。
删除远程仓库:
git remote rm test
test为别名
1、下载远程仓库的所有变动
git fetch [remote]
2、显示所有的远程仓库
git remote -v
和git remote的差别
$ git remote
origin
$ git remote -v
origin https://github.com/DimpleFeng/GitTest.git (fetch)
origin https://github.com/DimpleFeng/GitTest.git (push)
3、取回远程仓库的变化,并和本地分支合并
git pull [remote] [branch]
4、上传本地指定分支到远程仓库
git push [remote] [branch]
5、强行推送当前分支到远程仓库即使有冲突
git push [remote] --force
6、git remote 通常用于查看别人的进行,因为取回的代码对本地没有影响。
git remote add 添加远程主机
git remote rm 删除远程主机
git remote rename
7、git pull 取回远程主机某个分支的更新,再和本地的分支进行合并。
git pull :
取回origin主机的next分支,与本地的master合并
git pulll origin next:master
如果远程分支是和当前的分支进行合并,则冒号后面可以省略。
在某些场合,Git会自动在远程分支和本地分支之间创建一个追踪关系,如果当前分支和远程分支存在着追踪关系,就可以省略远程分支名称。
如果当前分支只有一个追踪分支,远程主机名也可以省略。
8、git push 将本地分支的更新,推送到远程主机
git push :
如果省略远程分支名,表示将本地分支推送给与之存在追踪关系的远程分支,如果该分支不存在会被新建。
如果省略本地分支名,则表示删除指定的远程分支:git push origin :master
如果当前分支和远程分支存在追踪关系,则本地分支和远程分支都可以省略。
如果只存在一个追踪分支,那么主机名可以省略.
如果远程主机的版本比本地的新,那么推送到Git的时候会报错,这个时候可以采用git push –force origin强制覆盖远程主机的版本。
九、撤销
1、恢复暂存区的指定文件到工作区。会丢失提交到暂存区后对该文件的所有操作。
git checkout [file]
2、恢复某次commit的指定文件到暂存区和工作区(git处于等待commit状态,同时会丢失在这之前对工作区的修改的内容)
git checkout [commit] [file]
3、恢复暂存区所有文件到工作区。会丢失在提交到暂存区之后的对文件的所有修改。
git checkout .
4、重置暂存区和工作区,与上一次commit一致
git reset --hard
5、重置当前分支的head为指定的commit,同时重置暂存区和工作区,与指定commit一致。
git reset --hard [commit]
git reset [file] 将file从暂存区回退到工作区(修改内容不会丢失)
6、将未保存的变化隐藏
git stash
弹出
git stash pop
7、查看历史命令
git reflog
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
