1.新建代码库

1.1在当前目录新建一个 Git 代码库

$ git init

1.2新建一个目录,将其初始化为 Git 代码库

$ git init [project-name]

1.3下载一个项目和它的整个代码历史

$ git clone [url]

2.配置

Git 的设置文件为.gitconfig,它可以在用户主目录下(全局配置),也可以在项目目录下(项目配置)。

2.1设置提交代码时的用户信息

$ git config [--global] user.name "[name]"
$ git config [--global] user.email "[email address]"

2.2编辑 Git 配置文件

$ vim ~/.gitconfig

2.3显示当前的 Git 配置

$ git config --list

2.4显示当前的 Git 配置

$ cat ~/.gitconfig

3.增加/删除文件

3.1添加指定文件到暂存区

$ git add [file1] [file2] ...

3.2添加指定目录到暂存区,包括子目录

$ git add [dir]

3.3添加当前目录的所有文件到暂存区

$ git add .

3.4删除工作区文件,并且将这次删除放入暂存区

$ git rm 1.txt 2.txt
error: the following files have changes staged in the index:
1.txt
2.txt
(use --cached to keep the file, or -f to force removal)

3.4.1直接删除文件

$ git rm -fr 1.txt

3.4.2停止追踪指定文件,但该文件会保留在工作区

$ git rm --cached [file]
$ git rm --cached 1.txt 2.txt
rm '1.txt'
rm '2.txt'

3.5改名文件,并且将这个改名放入暂存区

$ git mv [file-original] [file-renamed]

4.代码提交

4.1提交暂存区到仓库区

$ git commit -m [message]

4.2提交暂存区的指定文件到仓库区

$ git commit [file1] [file2] ... -m [message]

4.3提交工作区自上次 commit 之后的变化,直接到仓库区

$ git commit -a

4.4提交时显示所有 diff 信息

$ git commit -v

4.5使用一次新的 commit,替代上一次提交如果代码没有任何新变化,则用来改写上一次 commit 的提交信息

$ git commit --amend -m [message]

5.分支

5.1列出所有本地分支

$ git branch



*表示当前分支

5.2列出所有远程分支

$ git branch -r

5.3列出所有本地分支和远程分支

$ git branch -a

5.4新建一个分支,但依然停留在当前分支

$ git branch [branch-name]

5.5新建一个分支,并切换到该分支

$ git checkout -b [branch]

5.6新建一个分支,指向指定 commit

5.6.1查看提交的日志

$ git log

commit 2cb44e585aab4d1b2370a3e42dc6d4070fe217dc (HEAD -> DevOps_RC, origin/master, master, DevOps_Release, DevOps_Dev)
Author: zhangsan <zhangsan@263.com>
Date: Sat Jul 10 11:03:12 2021 +0800
修改了ReadMe.md文件,添加了一行说明 commit 89d1d5b198a77deb9096e11b02aec7187221f384
Author: zhangsan <zhangsan@263.com>
Date: Sat Jul 10 10:59:09 2021 +0800
:...skipping...
commit 2cb44e585aab4d1b2370a3e42dc6d4070fe217dc (HEAD -> DevOps_RC, origin/master, master, DevOps_Release, DevOps_Dev)
Author: zhangsan <zhangsan@263.com>
Date: Sat Jul 10 11:03:12 2021 +0800
修改了ReadMe.md文件,添加了一行说明 commit 89d1d5b198a77deb9096e11b02aec7187221f384
Author: zhangsan <zhangsan@263.com>
Date: Sat Jul 10 10:59:09 2021 +0800
添加User文件夹 commit b54962a30b090f02a39fc3c6185750cf07b068ea
Author: zhangsan <zhangsan@263.com>
Date: Sat Jul 10 10:58:30 2021 +0800
添加忽略文件 commit e76012d77857841d344ac04893a158e75e8088fc
Author: zhangsan <zhangsan@263.com>
Date: Sat Jul 10 10:56:46 2021 +0800
添加Readme.md文件

5.6.2新建一个分支,指向指定 commit ID

$ git branch [branch] [commit]
$ git branch DevOps_V0.3FixBug 89d1d5b198a77deb9096e11b02aec7187221f384

5.7新建一个分支,与指定的本地分支建立追踪关系

$ git branch --track [branch1] [branch2]
$ git branch --track DevOps_RC1 DevOps_RC

5.7.1DevOps_RC,增加一次提交

5.7.2DevOps_RC,再增加一次提交

5.8切换到指定分支,并更新工作区

5.8.1切换到建立追踪的分支DevOps_RC1

$ git checkout [branch-name]
$ git checkout DevOps_RC1

5.8.2从建立追踪的分支拉取最新的变化

$ git pull

5.9新建一个分支,与指定的远程分支建立追踪关系

5.9.1将本地的所有分支及信息全部推送到远程仓库

$ git push -u origin *:*

说明:origin,查看是否配置origin;默认克隆时,自动建立;

5.9.2查看origin信息

$ git remote -v
origin http://192.168.145.88/devops/devops.git (fetch)
origin http://192.168.145.88/devops/devops.git (push)

5.9.3新建一个分支,与指定的远程分支建立追踪关系

$ git branch --track [branch] [remote branch]
$ git branch --track DevOps_RC2 remotes/origin/DevOps_RC1

5.9.4切换到建立追踪关系的新分支DevOps_RC2

$ git checkout DevOps_RC2
Switched to branch 'DevOps_RC2'
Your branch is behind 'origin/DevOps_RC1' by 1 commit, and can be fast-forwarded.
(use "git pull" to update your local branch)

5.9.5使用 git pull 更新本地分支(会拉取建立追踪关系的分支代码)

$ git pull
warning: ----------------- SECURITY WARNING ----------------
warning: | TLS certificate verification has been disabled! |
warning: ---------------------------------------------------
warning: HTTPS connections may not be secure. See https://aka.ms/gcmcore-tlsverify for more information.
warning: ----------------- SECURITY WARNING ----------------
warning: | TLS certificate verification has been disabled! |
warning: ---------------------------------------------------
warning: HTTPS connections may not be secure. See https://aka.ms/gcmcore-tlsverify for more information.
Updating f7ed8ad..c11bb1a
Fast-forward
Readme.md | 1 +
1 file changed, 1 insertion(+)

5.10合并指定分支到当前分支

$ git merge [branch]
$ git merge DevOps_V0.3FixBug



提示文件存在冲突,冲突解决后再提交

5.10.1解决合并产生的冲突

按照冲突提示,修改冲突文件 Readme.md

$ vim Readme.md

5.10.2编辑修改解决冲突

5.10.2.1冲突提示

5.10.2.2冲突解决

5.10.2.3查看当前状态

$ git status
On branch DevOps_RC1
Your branch is up to date with 'origin/DevOps_RC1'. You have unmerged paths.#有未合并的分支
(fix conflicts and run "git commit")#修复冲突并且运行git commit
(use "git merge --abort" to abort the merge) #使用 git merge --abort终止合并 Unmerged paths:#未合并的分支
(use "git add <file>..." to mark resolution)
both modified: Readme.md no changes added to commit (use "git add" and/or "git commit -a")

此处我的处理措施是,把合并结果加入当前分支

5.11选择一个 commit,合并进当前分支

$ git cherry-pick [commit]

5.11.1选择别的分支(DevOps_RC1)的一个commit

$ git log

5.11.2切换到另一个项目合并一个提交至此分支的分支

5.11.2.1切换分支(DevOps_Dev)

$ git checkout DevOps_Dev
Switched to branch 'DevOps_Dev'
Your branch is up to date with 'origin/DevOps_Dev'.

5.11.2.2将选定的commit,合并进当前分支

$ git cherry-pick 900d39d30f2487897c1fc09f71c4bd41e1c0cf7a

5.11.2.3查看当前状态

$ git status

5.11.2.4解决冲突

5.12删除分支

$ git branch -d [branch-name]

5.13删除远程分支

5.13.1查看当前分支的详细信息

$ git branch -av

5.13.2删除远程分支

$ git push origin --delete DevOps_RC2



可以看到远程的此分支已经删除了



可以看到远程的此分支已经删除了



$ git branch -dr

6.标签

6.1列出所有 tag

$ git tag

6.2新建一个 tag 在当前 commit

$ git tag [tag]

6.3新建一个 tag 在指定 commit

$ git tag [tag] [commit]

6.4查看 tag 信息

$ git show [tag]

6.5提交指定 tag

$ git push [remote] [tag]

6.6提交所有 tag

$ git push [remote] --tags

6.7新建一个分支,指向某个 tag

$ git checkout -b [branch] [tag]

7.查看信息

7.1显示有变更的文件

$ git status

7.2显示当前分支的版本历史

$ git log

7.3显示 commit 历史,以及每次 commit 发生变更的文件

$ git log --stat

7.4显示某个文件的版本历史,包括文件改名

$ git log --follow [file]

$ git whatchanged [file]

7.5显示指定文件相关的每一次 diff

$ git log -p [file]

7.6显示指定文件是什么人在什么时间修改过

$ git blame [file]

7.7显示暂存区和工作区的差异

$ git diff

7.8显示暂存区和上一个 commit 的差异

$ git diff --cached []

7.9显示工作区与当前分支最新 commit 之间的差异

$ git diff HEAD

7.10显示两次提交之间的差异

$ git diff [first-branch]...[second-branch]

7.11显示某次提交的元数据和内容变化

$ git show [commit]

7.12显示某次提交发生变化的文件

$ git show --name-only [commit]

7.13显示某次提交时,某个文件的内容

$ git show [commit]:[filename]

显示当前分支的最近几次提交

$ git reflog

8.远程同步

8.1下载远程仓库的所有变动

$ git fetch [remote]

8.2显示所有远程仓库

$ git remote -v

8.3显示某个远程仓库的信息

$ git remote show [remote]

8.4增加一个新的远程仓库,并命名

$ git remote add [shortname] [url]

8.5取回远程仓库的变化,并与本地分支合并

$ git pull [remote] [branch]

8.6上传本地指定分支到远程仓库

$ git push [remote] [branch]

8.7强行推送当前分支到远程仓库,即使有冲突

$ git push [remote] --force

8.8推送所有分支到远程仓库

$ git push [remote] --all

9.撤销

9.1恢复暂存区的指定文件到工作区

$ git checkout [file]

9.2恢复某个 commit 的指定文件到工作区

$ git checkout [commit] [file]

9.3恢复上一个 commit 的所有文件到工作区

$ git checkout .

9.4重置暂存区的指定文件,与上一次 commit 保持一致,但工作区不变

$ git reset [file]

9.5重置暂存区与工作区,与上一次 commit 保持一致

$ git reset --hard

9.6重置当前分支的指针为指定 commit,同时重置暂存区,但工作区不变

$ git reset [commit]

9.7重置当前分支的 HEAD 为指定 commit,同时重置暂存区和工作区,与指定 commit 一致

$ git reset --hard [commit]

9.8重置当前 HEAD 为指定 commit,但保持暂存区和工作区不变

$ git reset --keep [commit]

9.9新建一个 commit,用来撤销指定 commit

9.10后者的所有变化都将被前者抵消,并且应用到当前分支

$ git revert [commit]

======================================================================
创作不易,本人热衷开源共享 Git常用命令超级详细(全网最详细)
======================================================================

转载请附上链接:

https://www.cnblogs.com/cndevops/p/14993331.html

Git常用命令超级详细(全网最详细)的更多相关文章

  1. GIT常用命令备忘

    Git配置 git config --global user.name "storm" git config --global user.email "stormzhan ...

  2. 转收藏:Git常用命令速查表

    一. Git 常用命令速查 git branch 查看本地所有分支git status 查看当前状态 git commit 提交 git branch -a 查看所有的分支git branch -r ...

  3. 【转】Git常用命令备忘

    Git配置 git config --global user.name "robbin" git config --global user.email "fankai@g ...

  4. [转载]Git常用命令

    转载自: Git常用命令 Git配置 git config --global user.name "robbin" git config --global user.email & ...

  5. git常用命令2

    一. Git 常用命令速查 git branch 查看本地所有分支git status 查看当前状态 git commit 提交 git branch -a 查看所有的分支git branch -r ...

  6. sublime 集成git插件,及git常用命令

    以前用了很久的totoiseSVN,显然不够高大上,开发界的版本装x利器还得是git.然而git的命令行对没怎么用过linux的人可能觉得还不如用gitGUI,可是当你知道sublime可以集成git ...

  7. Git常用命令清单笔记

    git github 小弟调调 2015年01月12日发布 赞  |   6收藏  |  45 5k 次浏览 这里是我的笔记,记录一些git常用和一些记不住的命令,这个笔记原本是基于 颜海镜的文章增加 ...

  8. Git常用命令及软件推荐

    查看.添加.提交.删除.找回,重置修改文件 git help <command> # 显示command的help git show # 显示某次提交的内容 git show $id gi ...

  9. git常用命令说明教程

    git常用命令说明教程 git介绍 是一个分布式的,版本控制软件.每台使用git的电脑都是一个分版本库.svn是集中管理的. 安装git 一 git相关操作 1.官网下载最新版安装https://gi ...

随机推荐

  1. kvm虚拟机管理(3)

    一.远程管理kvm虚拟机 (1)上一节我们通过 virt-manager 在本地主机上创建并管理 KVM 虚机.其实 virt-manager 也可以管理其他宿主机上的虚机.只需要简单的将宿主机添加进 ...

  2. 程序"三高"解决方案

    0. 程序三高 1. 缓存 2. 预处理和延后处理 3. 池化 3.1 内存池 3.2 线程池 3.3 连接池 4. 异步(回调) 5. 消息队列 5.1 服务解耦 5.2 异步处理 5.3 流量削峰 ...

  3. Jmeter(四十八) - 从入门到精通高级篇 - Jmeter监控服务器性能(详解教程)

    1.简介 JMeter是一款压力.接口等等的测试工具,Jmeter也可以像loadrunner一样监控服务器CPU.内存等性能参数,用来监控服务器资源使用情况,不过需要安装一些插件.JMeter正常自 ...

  4. 小程序中在设置了textarea后三个祖级内事件失效

    在一次写小程序项目中收货地址中的详细地址时,我用的是文本域,下边的三个bindtap事件却不能使用了:下图: 报错信息如下图: 通过一番查找以及尝试之后,我发现是因为textarea标签的问题,但是依 ...

  5. Mybatis学习-GetMybatisInMyHead

    认知 Mybatis3 中文文档 练习代码 ​ MyBatis 是一款优秀的持久层框架,它支持自定义 SQL.存储过程以及高级映射.MyBatis 免除了几乎所有的 JDBC 代码以及设置参数和获取结 ...

  6. pika详解(二) BlockingConnection

    pika详解(二) BlockingConnection   本文链接:https://blog.csdn.net/comprel/article/details/94592348 版权 Blocki ...

  7. Nginx 配置实例-配置动静分离

    Nginx 配置实例-配置动静分离 1. 静态资源的创建 2. nginx 动静分离的配置 3. 验证 1. 静态资源的创建 这里使用的静态资源主要为 HTML 静态文件和图片. mkdir -vp ...

  8. GO学习-(3) VS Code配置Go语言开发环境

    VS Code配置Go语言开发环境 VS Code配置Go语言开发环境 说在前面的话,Go语言是采用UTF8编码的,理论上使用任何文本编辑器都能做Go语言开发.大家可以根据自己的喜好自行选择.编辑器/ ...

  9. GeforceRTX系列参数对比

    GeforceRTX系列参数对比

  10. 【NX二次开发】分析曲线某位置的信息 UF_MODL_ask_curve_props

    分析曲线某位置的信息:点.切线.主副法线.半径等 extern DllExport void ufsta(char *param, int *returnCode, int rlen) { UF_in ...