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
git 怎么备份本地分支_Git常用个人备份笔记相关推荐
- git 怎么备份本地分支_git 入门教程之协同开发
前面我们已经介绍过远程仓库的相关概念,不过那时并没有深入探讨,只是讲解了如何创建远程仓库以及推送最新工作成果到远程仓库,实际上远程仓库对于团队协同开发很重要,不仅仅是团队协同开发的基础,也是代码备份的 ...
- git 快速清理本地分支_Git删除本地多个分支
由于本人是做QA的,经常需要发布很多分支,所以本地存留了很多的分支,需要批量删除本地分支:找到如下方法,有需要的人可以用到,多谢点赞. 要删除本地,首先要考虑以下三点 1.列出所有本地分支 2.搜索目 ...
- Git远程分支覆盖本地分支的详细介绍
导言: 在使用Git进行团队协作或者个人开发中,经常会遇到需要将远程分支的内容覆盖到本地分支的情况.本篇博客将详细介绍如何使用Git来实现远程分支覆盖本地分支的操作,帮助读者更好地应对这类需求. 一. ...
- Git如何创建本地分支并推送到远程仓库
Git如何创建本地分支并推送到远程仓库 假设新的分支名称为:new_branch -- 切换到拉取分支的原分支,假设为master git checkout master git pull -- 拉取 ...
- git 删除本地仓库中的分支_git常用命令行 新建分支 删除分支 提交
1.查看当前分支: git branch 2.查看所有分支,包含远程分支 : git branch -a 3.新建分支: git checkout -b bug123 4.推送本地分支到远程分支(远程 ...
- git 小乌龟 更新分支_git常用操作
Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件. Git ...
- git 创建新分支并关联远程分支_git常用操作命令归纳
php中文网最新课程 每日17点准时技术干货分享 git中常用的操作命令有哪些?本篇文章就给到大家归纳了一些git中常用操作命令.有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. git ...
- git 怎么备份本地分支_同步管理本地git仓库和github仓库上的分支
参考文章 分支管理策略 在实际开发中,我们应该按照几个基本原则进行分支管理: 首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活 那在哪里干活呢?干活都在 dev分支上 ...
- git idea 如何删除本地分支_git删除本地分支和删除远程分支
引言: 注:本人一直都是用的git bash窗口完成日常的开发工作. 事情是这样的,切换分支的时候命令打错了,git checkout 后面没有跟分支名,结果git status,很多delete的文 ...
最新文章
- 科技部部长:院士头衔不是学术不端挡箭牌、铁帽子!已有多位院士及候选人、校长、教授等被“拿下”...
- 在WEBSERVICE学习中遇到的问题
- 使用 JQUERY 为文本框增加提示文字
- LoadRunner解决超时错误
- 11g RAC不能启动ohasd进程
- 研磨数据结构与算法-06递归的应用
- BSEG和BSIS、BSAS、BSID、BSAD、BSIK、BSAK六个表的关系
- PHP CURL 多线程 GET/POST 类
- java代码编写出现的陷阱-1:警惕变长参数
- [设计模式]State模式
- CSS之Responsive网页设计的三个特性
- s3k3 破旧不堪的拐杖被扔出去几米远
- [转载]用数学逻辑推断三国武将排名
- 人工智能TensorFlow工作笔记007---认识张量
- html——name与value的使用
- html select下拉菜单长度过长不出滚动条问题解决办法
- SQL Server中的日期类型
- 《菜菜的机器学习sklearn课堂,孔浩Java视频百度云盘
- Google Scholar 谷歌学术文献检索技巧总结
- 火狐浏览器代理设置: