目录
Git 安装与设置
在 Windows上安装 Git
在 Windows上使用 Git,可以从 Git 官网直接 下载安装程序,然后按默认选项安装即可。
安装完成后,在开始菜单里找到“Git”->“Git Bash”,蹦出一个类似命令行窗口的东西,就说明Git安装成功!
git 的配置
# 设置当前目录下的用户名和邮箱
git config --global user.name "Your Name"
git config --global user.email "email@example.com"
# 查看配置列表
git config -l
Git 原理
git 的四个区域
本地 3 个区域 + 远程 git 仓库
Workspace:
工作区,即当前工作目录,存放代码的位置。Stage/Index:
暂存区,临时存放改动,事实上是一个文件,保存即将提交的文件列表信息Repository:
仓库区(版本库),存放提交的所有版本的数据, HEAD 指向最新的版本。Remote Directory:
远程仓库,托管代码的服务器
git 工作流程
- 在工作目录中添加、修改文件
- 将需要进行版本管理的文件放入暂存区
git add 文件名
- 将暂存区域的文件提交到仓库
git commit -m "提交信息"
- 本地仓库的修改 push 到远程仓库
git push origin master
,如果失败则执行第5步 - 将远程仓库的修改拉取到本地
git pull origin master
,修改冲突,回到第3步
git 文件的状态
文件的各状态转化如图所示:
Untracked:
未跟踪。文件未入仓库,不参与版本控制。Unmodify:
文件已入仓库但未修改,即工作区与仓库中的文件一致。Modified:
文件已被修改,即工作区与仓库中的文件不一致。Staged:
暂存状态
Git 操作
创建仓库
git init
:将当前文件夹作为 Git 仓库,并在该文件夹中生成一个.git
目录,该目录包含了资源的所有元数据,不可修改里面的内容。- git init --bare:在当前目录生成不带 .git 的项目文件,即把 .git 文件夹的内容直接生成到当前目录
git init myProject
:新建一个 myProject 文件夹作为 Git 仓库,并在 myProject 文件中新建一个.git
目录git init --bare myProject
:新建一个 myProject 文件夹作为 Git 仓库,并把 .git 文件夹的内容直接生成到 myProject 文件中- git clone <repo> <directory>:克隆一个仓库到指定目录
免密登录
使用协议 (http, ssh, git等) 来实现远端仓库和本地仓库的交互。
使用 ssh 公钥免密登录 git 服务器
# 1、本地生成公钥和私钥
ssh-keygen -t rsa
# 2、复制公钥内容到远端 git 服务器
# 本地:拷贝本地公钥 id_rsa.pub
cat ~/.ssh/id_rsa.pub
# 远端:复制到 git 服务器的 authorized_keys
vim .ssh/authorized_keys
# 3、远端仓库克隆到本地
git clone <git仓库路径>
基本操作
# 1、暂存,工作区 -> 暂存区
git add <文件名>
# 2、提交,暂存区 -> 本地仓库,提交到仓库的文件才真正被 git 追踪记录
git commit -m "提交信息"
-a 把当前暂存区里所有的修改(包括删除操作)都提交,未添加到暂存区的内容是不提交
# 3、推送,本地仓库 -> 远端仓库
git push origin master
# 拉取合并
git pull origin master
# 查看状态
git status
# 对比文件差异
git diff <commitID>
# 查看日志,显示每次提交的相关信息,包括 commitID、提交作者、提交日期、备注信息
git log [option]
git log --all 显示所有分支
git log --pretty=oneline 将提交信息显示为一行
git log --abbrev-commit 使得输出的commitId更简短
git log --graph 以图的形式显示
# 忽略文件
# 目录下创建.gitignore文件,添加文件至忽略列表
版本回退
- 从工作区回退,工作区 -> null,清空工作区的的修改
# 从本地仓库或暂存区中检出文件,并且覆盖工作目录的内容
# 也就是说放弃本地的所有修改,但是工作区新创建的文件不会被删除
git checkout - 从暂存区回退,暂存区 -> 工作区
git resore -S
- 从本地仓库回退
# 使用该 commit 做回滚操作
git reset commitId / HEAD^
# 1、本地仓库 -> 暂存区,暂存区和工作区都不会被改变
git reset --soft commitId / HEAD^
# 2、本地仓库 -> 工作区,暂存区同步到指定的commit,工作区不改变
git reset --mixed commitId / HEAD^
# 3、本地仓库 -> null,修改的内容被清除,暂存区和工作区都同步到指定的提交
git reset --hard commitId / HEAD^
- 从远端仓库回退
git revert commitId
fix conflict
git commit
git push
本地仓库整理
注意:修改某个结点导致从该结点往后的所有结点的 commitId 发生变化,会引起其他人冲突,要确保没有人基于你的分支开发。
- 整理上一次的提交
git commit -amend
- 整理多次提交:本地 commit 直接使用
git rebase -i
。 push 到远端的 commit 需要使用git log
查看 commit id,来确定要修改的区间范围。git rebase -i <commitId>
当你执行 `git rebase -i <commit>` 命令时,Git 会打开一个文本编辑器,列出从 `<commit>` 到当前 HEAD 的所有 commit。每个 commit 的前面都有一个命令,用于告诉 Git 对这个 commit 进行什么操作。你可以修改这个命令来改变 Git 对这个 commit 的操作。
可用的命令包括:
- - `p` 或 `pick`:使用这个 commit
- - `r` 或 `reword`:使用这个 commit,但需要修改 commit 信息
- - `e` 或 `edit`:使用这个 commit,但会停下来让你修改这个 commit(你可以修改文件内容,添加或删除文件,等等)
- - `s` 或 `squash`:使用这个 commit,但会将这个 commit 和前一个 commit 合并在一起
- - `f` 或 `fixup`:和 `squash` 类似,但会丢弃这个 commit 的 commit 信息
- - `d` 或 `drop`:不使用这个 commit
在编辑器中修改命令后保存并关闭编辑器,Git 就会开始执行 rebase,按照你指定的命令对 commit 进行操作。在 rebase 过程中,Git 可能会停下来让你解决合并冲突,或者让你修改 commit。你可以按照 Git 的提示进行操作,然后继续 rebase。
分支命令
# 查看分支
git branch
# 创建分支
git branch 分支名
# 创建并切换分支
git checkout -b 分支名
# 切换分支
git checkout 分支名
git switch 分支名
# 删除分支,不能删除当前分支,只能删除其他分支
git branch -d b1
# 合并分支
git merge
git rebase
合并分支
参考:图解 Git 基本命令 merge 和 rebase
HEAD
指向当前所在的分支,当分支切换时,HEAD
会跟着切换到对应分支。
解决冲突
冲突的产生原因:不同分支修改了同一文件的同一行或者相邻行。
解决:
- 合并分支:
git merge / git rebase
,合并前先 git pull 更新代码 git add
git commit
git push