Git 详解
半塘 2023/10/25 Git
目录
- 1、代码托管服务平台
- 2、常用命令
- 上传到git
- git clone 克隆项目
- git merge 合并分支
- git init 初始化
- git status 查看状态
- git remote 操作远程库
- git branch 分支命令
- git checkout 分支检出
- git cherry-pick 合并记录
- git add 提交文件
- git commit 提交到本地仓库
- git fetch 远程仓库获取
- git merge 合并分支
- git diff 比较版本
- git push 推送远程仓库
- git log 查看记录
- git reset 撤销提交
- git reset 撤销提交
- git revert 撤销某次提交
- git tag 操作标签
- git mv 重命名
- git rm 删除
- git 配置操作命令
- git 刷新远程分支
- git 回退指定版本
Git是用于项目代码管理的工具。
# 1、代码托管服务平台
1、GitHub:全球最大的Git代码托管平台
2、Gitee:码云,开源中国旗下的Git代码托管平台,国内的代码托管平台
3、Gitlab:企业级源代码管理
4、SVN:是一个开放源代码的版本控制系统
个人选择的话,GitHub和Gitee都可以,Gitee是国产的,GitHub是国外。
# 2、常用命令
# 上传到git
新项目上传到git
# 如果已经连接远程仓库了,要换仓库,需要先移除了
git remote rm origin
# 初始化
git init
# 把全部文件添加到暂存区中
git add .
# 把暂存区中的文件提交到本地仓库,并增加描述信息:first commit
git commit -m "first commit"
# 连接远程git仓库
git remote add origin <远程仓库地址链接>
# 提交到远程仓库master分支
git push -u origin master
1
2
3
4
5
6
7
8
9
10
11
12
13
2
3
4
5
6
7
8
9
10
11
12
13
# git clone 克隆项目
从远程仓库克隆一个版本库到本地
# 默认在当前目录下创建和版本库名相同的文件夹并下载版本到该文件夹下
git clone <远程仓库的网址>
# 指定本地仓库的目录
git clone <远程仓库的网址> <本地目录>
# -b 指定要克隆的分支,默认是master分支
git clone <远程仓库的网址> -b <分支名称> <本地目录>
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# git merge 合并分支
合并某个分支到当前分支
git merge <分支名称>
1
# git init 初始化
初始化项目所在目录,初始化后会在当前目录下出现一个名为 .git 的目录。
# 初始化本地仓库,在当前目录下生成 .git 文件夹
git init
1
2
2
# git status 查看状态
查看本地仓库的状态
# 查看本地仓库的状态
git status
# 以简短模式查看本地仓库的状态
# 会显示两列,第一列是文件的状态,第二列是对应的文件
# 文件状态:A 新增,M 修改,D 删除,?? 未添加到Git中
git status -s
1
2
3
4
5
6
7
2
3
4
5
6
7
# git remote 操作远程库
# 列出已经存在的远程仓库
git remote
# 列出远程仓库的详细信息,在别名后面列出URL地址
git remote -v
git remote --verbosehe
# 添加远程仓库
git remote add <远程仓库的别名> <远程仓库的URL地址>
# 修改远程仓库的别名
git remote rename <原远程仓库的别名> <新的别名>
# 删除指定名称的远程仓库
git remote remove <远程仓库的别名>
# 修改远程仓库的 URL 地址
git remote set-url <远程仓库的别名> <新的远程仓库URL地址>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
# git branch 分支命令
操作 Git 的分支命令
# 列出本地的所有分支,当前所在分支以 "*" 标出
git branch
# 列出本地的所有分支并显示最后一次提交,当前所在分支以 "*" 标出
git branch -v
# 创建新分支,新的分支基于上一次提交建立
git branch <分支名>
# 修改分支名称
# 如果不指定原分支名称则为当前所在分支
git branch -m [<原分支名称>] <新的分支名称>
# 强制修改分支名称
git branch -M [<原分支名称>] <新的分支名称>
# 删除指定的本地分支
git branch -d <分支名称>
# 强制删除指定的本地分支
git branch -D <分支名称>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# git checkout 分支检出
检出命令,用于创建、切换分支等
# 切换到已存在的指定分支
git checkout <分支名称>
# 创建并切换到指定的分支,保留所有的提交记录
# 等同于 "git branch" 和 "git checkout" 两个命令合并
git checkout -b <分支名称>
# 创建并切换到指定的分支,删除所有的提交记录
git checkout --orphan <分支名称>
# 替换掉本地的改动,新增的文件和已经添加到暂存区的内容不受影响
git checkout <文件路径>
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
# git cherry-pick 合并记录
把已经提交的记录合并到当前分支
# 把已经提交的记录合并到当前分支
git cherry-pick <commit ID>
1
2
2
# git add 提交文件
提交文件,把要提交的文件的信息添加到暂存区中。当使用 git commit 时,将依据暂存区中的内容来进行文件的提交
# 把指定的文件添加到暂存区中
git add <文件路径>
# 添加所有修改、已删除的文件到暂存区中
git add -u [<文件路径>]
git add --update [<文件路径>]
# 添加所有修改、已删除、新增的文件到暂存区中,省略 <文件路径> 即为当前目录
git add -A [<文件路径>]
git add --all [<文件路径>]
# 查看所有修改、已删除但没有提交的文件,进入一个子命令系统
git add -i [<文件路径>]
git add --interactive [<文件路径>]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
2
3
4
5
6
7
8
9
10
11
12
13
14
# git commit 提交到本地仓库
将暂存区中的文件提交到本地仓库中
# 把暂存区中的文件提交到本地仓库,调用文本编辑器输入该次提交的描述信息
git commit
# 把暂存区中的文件提交到本地仓库中并添加描述信息
git commit -m "<提交的描述信息>"
# 把所有修改、已删除的文件提交到本地仓库中
# 不包括未被版本库跟踪的文件,等同于先调用了 "git add -u"
git commit -a -m "<提交的描述信息>"
# 修改上次提交的描述信息
git commit --amend
1
2
3
4
5
6
7
8
9
10
11
12
2
3
4
5
6
7
8
9
10
11
12
# git fetch 远程仓库获取
从远程仓库获取最新的版本到本地的 tmp 分支上
# 将远程仓库所有分支的最新版本全部取回到本地
git fetch <远程仓库的别名>
# 将远程仓库指定分支的最新版本取回到本地
git fetch <远程主机名> <分支名>
1
2
3
4
5
2
3
4
5
# git merge 合并分支
合并分支
# 把指定的分支合并到当前所在的分支下
git merge <分支名称>
1
2
2
# git diff 比较版本
比较版本之间的差异
# 比较当前文件和暂存区中文件的差异,显示没有暂存起来的更改
git diff
# 比较暂存区中的文件和上次提交时的差异
git diff --cached
git diff --staged
# 比较当前文件和上次提交时的差异
git diff HEAD
# 查看从指定的版本之后改动的内容
git diff <commit ID>
# 比较两个分支之间的差异
git diff <分支名称> <分支名称>
# 查看两个分支分开后各自的改动内容
git diff <分支名称>...<分支名称>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# git push 推送远程仓库
把本地仓库的提交推送到远程仓库
# 把本地仓库的分支推送到远程仓库的指定分支
git push <远程仓库的别名> <本地分支名>:<远程分支名>
# 删除指定的远程仓库的分支
git push <远程仓库的别名> :<远程分支名>
git push <远程仓库的别名> --delete <远程分支名>
1
2
3
4
5
6
2
3
4
5
6
# git log 查看记录
显示提交的记录
# 打印所有的提交记录
git log
# 打印从第一次提交到指定的提交的记录
git log <commit ID>
# 打印指定数量的最新提交的记录
git log -<指定的数量>
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# git reset 撤销提交
Git add之后撤销
git reset 文件名称
1
# git reset 撤销提交
Git add之后撤销提交,还原提交记录
# 重置暂存区,但文件不受影响
# 相当于将用 "git add" 命令更新到暂存区的内容撤出暂存区,可以指定文件
# 没有指定 commit ID 则默认为当前 HEAD
git reset [<文件路径>]
git reset --mixed [<文件路径>]
# 将 HEAD 的指向改变,撤销到指定的提交记录,文件未修改
git reset <commit ID>
git reset --mixed <commit ID>
# 将 HEAD 的指向改变,撤销到指定的提交记录,文件未修改
# 相当于调用 "git reset --mixed" 命令后又做了一次 "git add"
git reset --soft <commit ID>
回退配合log查看,查看最近三次提交
git log -3
# 将 HEAD 的指向改变,撤销到指定的提交记录,文件也修改了
git reset --hard <commit ID>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
# git revert 撤销某次提交
生成一个新的提交来撤销某次提交,此次提交之前的所有提交都会被保留
# 生成一个新的提交来撤销某次提交
git revert <commit ID>
1
2
2
# git tag 操作标签
操作标签的命令
# 打印所有的标签
git tag
# 添加轻量标签,指向提交对象的引用,可以指定之前的提交记录
git tag <标签名称> [<commit ID>]
# 添加带有描述信息的附注标签,可以指定之前的提交记录
git tag -a <标签名称> -m <标签描述信息> [<commit ID>]
# 切换到指定的标签
git checkout <标签名称>
# 查看标签的信息
git show <标签名称>
# 删除指定的标签
git tag -d <标签名称>
# 将指定的标签提交到远程仓库
git push <远程仓库的别名> <标签名称>
# 将本地所有的标签全部提交到远程仓库
git push <远程仓库的别名> –tags
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# git mv 重命名
重命名文件或者文件夹
# 重命名指定的文件或者文件夹
git mv <源文件/文件夹> <目标文件/文件夹>
1
2
2
# git rm 删除
删除文件或者文件夹
# 移除跟踪指定的文件,并从本地仓库的文件夹中删除
git rm <文件路径>
# 移除跟踪指定的文件夹,并从本地仓库的文件夹中删除
git rm -r <文件夹路径>
# 移除跟踪指定的文件,在本地仓库的文件夹中保留该文件
git rm --cached
1
2
3
4
5
6
7
8
2
3
4
5
6
7
8
# git 配置操作命令
# 查看配置信息
# --local:仓库级,--global:全局级,--system:系统级
git config <--local | --global | --system> -l
# 查看当前生效的配置信息
git config -l
# 编辑配置文件
# --local:仓库级,--global:全局级,--system:系统级
git config <--local | --global | --system> -e
# 添加配置项
# --local:仓库级,--global:全局级,--system:系统级
git config <--local | --global | --system> --add <name> <value>
# 获取配置项
git config <--local | --global | --system> --get <name>
# 删除配置项
git config <--local | --global | --system> --unset <name>
# 配置提交记录中的用户信息
git config --global user.name <用户名>
git config --global user.email <邮箱地址>
# 更改Git缓存区的大小
# 如果提交的内容较大,默认缓存较小,提交会失败
# 缓存大小单位:B,例如:524288000(500MB)
git config --global http.postBuffer <缓存大小>
# 调用 git status/git diff 命令时以高亮或彩色方式显示改动状态
git config --global color.ui true
# 配置可以缓存密码,默认缓存时间15分钟
git config --global credential.helper cache
# 配置密码的缓存时间
# 缓存时间单位:秒
git config --global credential.helper 'cache --timeout=<缓存时间>'
# 配置长期存储密码
git config --global credential.helper store
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# git 刷新远程分支
同步分支
git remote update origin --prune
git remote update origin -p
1
2
2
# git 回退指定版本
git reset --hard <提交历史HEAD>
1