一、新建代码库

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常用个人备份笔记相关推荐

  1. git 怎么备份本地分支_git 入门教程之协同开发

    前面我们已经介绍过远程仓库的相关概念,不过那时并没有深入探讨,只是讲解了如何创建远程仓库以及推送最新工作成果到远程仓库,实际上远程仓库对于团队协同开发很重要,不仅仅是团队协同开发的基础,也是代码备份的 ...

  2. git 快速清理本地分支_Git删除本地多个分支

    由于本人是做QA的,经常需要发布很多分支,所以本地存留了很多的分支,需要批量删除本地分支:找到如下方法,有需要的人可以用到,多谢点赞. 要删除本地,首先要考虑以下三点 1.列出所有本地分支 2.搜索目 ...

  3. Git远程分支覆盖本地分支的详细介绍

    导言: 在使用Git进行团队协作或者个人开发中,经常会遇到需要将远程分支的内容覆盖到本地分支的情况.本篇博客将详细介绍如何使用Git来实现远程分支覆盖本地分支的操作,帮助读者更好地应对这类需求. 一. ...

  4. Git如何创建本地分支并推送到远程仓库

    Git如何创建本地分支并推送到远程仓库 假设新的分支名称为:new_branch -- 切换到拉取分支的原分支,假设为master git checkout master git pull -- 拉取 ...

  5. git 删除本地仓库中的分支_git常用命令行 新建分支 删除分支 提交

    1.查看当前分支: git branch 2.查看所有分支,包含远程分支 : git branch -a 3.新建分支: git checkout -b bug123 4.推送本地分支到远程分支(远程 ...

  6. git 小乌龟 更新分支_git常用操作

    Git 是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目. Git 是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件. Git ...

  7. git 创建新分支并关联远程分支_git常用操作命令归纳

    php中文网最新课程 每日17点准时技术干货分享 git中常用的操作命令有哪些?本篇文章就给到大家归纳了一些git中常用操作命令.有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. git ...

  8. git 怎么备份本地分支_同步管理本地git仓库和github仓库上的分支

    参考文章 分支管理策略 在实际开发中,我们应该按照几个基本原则进行分支管理: 首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活 那在哪里干活呢?干活都在 dev分支上 ...

  9. git idea 如何删除本地分支_git删除本地分支和删除远程分支

    引言: 注:本人一直都是用的git bash窗口完成日常的开发工作. 事情是这样的,切换分支的时候命令打错了,git checkout 后面没有跟分支名,结果git status,很多delete的文 ...

最新文章

  1. 科技部部长:院士头衔不是学术不端挡箭牌、铁帽子!已有多位院士及候选人、校长、教授等被“拿下”...
  2. 在WEBSERVICE学习中遇到的问题
  3. 使用 JQUERY 为文本框增加提示文字
  4. LoadRunner解决超时错误
  5. 11g RAC不能启动ohasd进程
  6. 研磨数据结构与算法-06递归的应用
  7. BSEG和BSIS、BSAS、BSID、BSAD、BSIK、BSAK六个表的关系
  8. PHP CURL 多线程 GET/POST 类
  9. java代码编写出现的陷阱-1:警惕变长参数
  10. [设计模式]State模式
  11. CSS之Responsive网页设计的三个特性
  12. s3k3 破旧不堪的拐杖被扔出去几米远
  13. [转载]用数学逻辑推断三国武将排名
  14. 人工智能TensorFlow工作笔记007---认识张量
  15. html——name与value的使用
  16. html select下拉菜单长度过长不出滚动条问题解决办法
  17. SQL Server中的日期类型
  18. 《菜菜的机器学习sklearn课堂,孔浩Java视频百度云盘
  19. Google Scholar 谷歌学术文献检索技巧总结
  20. 火狐浏览器代理设置:

热门文章

  1. Java 中long类型转换成为int类型时可能会出错的地方
  2. snmp在企业网中的简单应用
  3. AutoCAD VBA对齐对象
  4. 30个HTML标签,HTML常用标签的使用 --2019年8月30日
  5. CascadingStyleSheets
  6. reactjs Context的使用:一种组件间的通信方式
  7. vscode中reactjs插件的安装
  8. linux centos7开启IP转发、路由转发解决docker 端口映射 及外部无法访问问题
  9. 【收藏】如何避免everything每次都重建索引
  10. gradle构建脚本、依赖、插件管理、生命周期进阶教程