Git——分布式版本控制工具使用教程
本文主要介绍两种版本控制工具——SVN和Git的概念,接着会讲到Git的安装,Git常用的命令,以及怎么在Vscode中使用Git。帮助新手小白快速上手Git。如果想直接上手用Vscode操作远程仓库则直接看7和9即可!
目录
1. SVN和Git介绍
1.1 SVN
1.2 Git
2.Git工作流程
3.Git安装与配置
3.1 Git安装
3.2 Git配置
3.2.1 设置用户
3.2.2 为常用命令设置别名
3.2.3 解决GitBash乱码问题
4. 获取本地库
5.常用的基本命令
5.1 查看暂存区和工作区修改的状态(status)
5.2 将修改过后的文件添加到暂存区(add)
5.3 将暂存区内容提交到本地仓库(commit)
5.4 查看提交日志(log)
5.5 版本回退(reset)
5.6 添加文件至忽略列表
6. 分支
6.1 查看所有分支(branch)
6.2 创建并切换到分支(不要-b,就是只创建)
6.3 合并分支(merge)
6.4 删除分支
6.5 解决冲突
7. 配置远程仓库
7.1 注册码云
7.2 创建远程仓库
7.3 配置SSH公钥
8. 操作远程仓库
8.1 添加远程仓库
8.2 查看远程仓库
8.3 推送到远程仓库
8.4 本地分支与远程分支的关联关系
8.5 从远程仓库克隆
8.6 从远程仓库中抓取和拉取
8.7 解决合并冲突
9. Vscode使用Git
1. SVN和Git介绍
1.1 SVN
集中式版本控制工具,版本库是集中存放在中央服务器的,团队里每个人工作时从中央服务器下载代码,是必须联网才能工作,局域网或互联网。
1.2 Git
分布式版本控制系统没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样工作的时候,无需要联网了,因为版本库就在你自己的电脑上。
2.Git工作流程
你作为一名新人,进到了公司,公司发给你了远程仓库的链接,以及账号密码,接下来你只需要按照git的工作流程来就行了。
- clone: 从远程仓库把代码克隆到本地,也就是你的计算机上
- checkout: 为了避免直接在master主分支上进行开发,通常会创建一个新的分支,在这个分支上操作,不会影响到主分支
- add: 你今天写完了代码,先提交到暂存区(分阶段审查,这样能精细化控制版本)
- commit: 提交到本地仓库。本地仓库中保存修改的各个历史版本
- pull: 你想要推送本地更改的时候,最好先从远程仓库拉取到最新的更改,万一有人跟你动了同一行代码,你就得需要手动解决冲突。或者你是旧版本的代码,直接推送会导致版本历史分叉,触发冲突。pull相当于fetch+merge
- push: 将本地的提交推送到远程仓库
3.Git安装与配置
3.1 Git安装
下载地址:Git - Downloads
得到下面这样的安装包:
除了安装位置调整外,一直点下一步就行:
安装成功后,可以右键看一下有没有这两个东西,有的话就是安装成功了。
备注:
Git GUI:Git提供的图形界面工具 Git Bash:Git提供的命令行工具
3.2 Git配置
3.2.1 设置用户
1.打开Git Bash
2.设置用户名和邮箱
git config --global user.name “yqd”
git config --global user.email "你的邮箱@xx.com"
查看用户名和邮箱
git config --global user.name
git config --global user.email
3.2.2 为常用命令设置别名
有些常用的指令参数非常多,每次都要输入好多参数,我们可以使用别名。
1. 打开用户目录,创建 .bashrc 文件
touch ~/.bashrc
2.用vi命令编辑.bashrc文件
vi .bashrc
3.按 “i” 键输入如下内容 ,输入完成先按ESC,输入 :wq! 退出
#用于输出git提交日志
alias git-log='git log --pretty=oneline --all --graph --abbrev-commit'
4. 执行 source ~/.bashrc
source ~/.bashrc
3.2.3 解决GitBash乱码问题
1.打开Git Bash执行下面命令
git config --global core.quotepath false
2.${git_home}/etc/bash.bashrc 文件最后加入下面两行
export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"
4. 获取本地库
要使用Git对我们的代码进行版本控制,首先需要获得本地仓库
1.先建一个文件夹(例如test)
2.进入这个文件,右键打开Git Bash
3.执行命令git init
4.如果创建本地仓库成功,就会在文件夹下看到隐藏的.git目录
5.常用的基本命令
5.1 查看暂存区和工作区修改的状态(status)
git status
5.2 将修改过后的文件添加到暂存区(add)
#单个文件
git add 文件名
#多个文件
git add .
5.3 将暂存区内容提交到本地仓库(commit)
git commit -m '注释内容'
5.4 查看提交日志(log)
git log [option] (若之前配置过git-log命令,可以直接使用,就不用手动写这些选项)
- options
--all 显示所有分支
--pretty=oneline 将提交信息显示为一行
--abbrev-commit 使得输出的commitId更简短
--graph 以图的形式显示
5.5 版本回退(reset)
当弄错了,可以通过reset实现版本的切换,commitID 可以使用 git-log 或 git log 指令查看
git reset --hard commitID
当你版本回退之后,你看不到后面的提交记录。那如何查看你执行回退之前的提交记录?
git reflog
5.6 添加文件至忽略列表
一般有些文件我们不想提交,比如说生成的日志文件等等,那么我们可以在工作目录中创建一个名为 .gitignore 的文件(文件名称固定),列出要忽略的文件模式。下面是一个示例:
# --------------------------
# 编辑器/IDE
# --------------------------
# VS Code
.vscode/ # VS Code 工作区配置
!.vscode/settings.json # 例外:允许提交共享的 settings.json
# IntelliJ
.idea/ # JetBrains IDE 配置目录
*.iml # 项目模块文件
# Vim
*.swp # Vim 交换文件
*.swo
# --------------------------
# 日志/编译产物
# --------------------------
logs/ # 日志目录(所有日志文件)
*.log # 所有后缀为 .log 的文件
dist/ # 前端项目构建目录
build/ # 编译产物目录
# --------------------------
# 测试相关
# --------------------------
coverage/ # 测试覆盖率报告
.junit_results # 单元测试结果
# --------------------------
# 特殊文件
# --------------------------
.env # 环境变量文件(永远不要提交!)
secret.key # 密钥文件
*.bak # 备份文件
6. 分支
几乎所有的版本控制系统都以某种形式支持分支。 使用分支可以把你的工作从开发主线上分离开来进行重大的Bug修改、开发新的功能,以免影响开发主线。下面示例让你更好理解分支:
从 M2 版本开始分支,最后将 M3 和 F2 进行合并,成为了 M4 版本
6.1 查看所有分支(branch)
git branch
6.2 创建并切换到分支(不要-b,就是只创建)
git checkout -b 分支名
6.3 合并分支(merge)
#将其他分支合并到当前分支
git merge 其他分支名
6.4 删除分支
不能删除当前分支,只能删除其他分支
git branch -d b1 删除分支时,需要做各种检查
git branch -D b1 不做任何检查,强制删除
6.5 解决冲突
当两个分支上对文件的修改可能会存在冲突,例如同时修改了同一个文件的同一行,这时就需要手动解决冲突,解决冲突步骤如下:
1. 处理文件中冲突的地方
2. 将解决完冲突的文件加入暂存区(add)
3. 提交到仓库(commit)
示例如下:
7. 配置远程仓库
7.1 注册码云
由于访问国外的GitHub比较慢,我们选择国内的Gitee作为远程仓库。
码云地址:Gitee - 基于 Git 的代码托管和研发协作平台
7.2 创建远程仓库
7.3 配置SSH公钥
1.在GitBash用下面命令生成公钥,不断回车(如果公钥已经存在,则自动覆盖)
ssh-keygen -t rsa
2. 获取公钥
cat ~/.ssh/id_rsa.pub
3.添加公钥
4.验证公钥
ssh -T git@gitee.com
8. 操作远程仓库
8.1 添加远程仓库
#远端名称默认为origin 仓库路径-点"我的",仓库那里切换到SSH可以查看
git remote add 远端名称 仓库路径
8.2 查看远程仓库
git remote
8.3 推送到远程仓库
-f 表示强制覆盖(慎用)
--set-upstream 推送到远端的同时并且建立起和远端分支的关联关系
如果远程分支名和本地分支名称相同,则可以只写本地分支
git push --set-upstream 远程仓库名 本地分支名:远程分支名
查看远程仓库
8.4 本地分支与远程分支的关联关系
git branch -vv
8.5 从远程仓库克隆
仓库路径可在"克隆/下载"处查看 本地目录可省略,会自动生成一个
git clone 仓库路径 本地目录
8.6 从远程仓库中抓取和拉取
#抓取指令就是将仓库里的更新都抓取到本地,不会进行合并
#如果不指定远端名称和分支名,则抓取所有分支
git fetch 远程仓库名 远程分支名
#拉取指令就是将远端仓库的修改拉到本地并自动进行合并,等同于fetch+merge
#如果不指定远端名称和分支名,则抓取所有并更新当前分支git pull 远程仓库名 远程分支名
8.7 解决合并冲突
打工人one在本地修改代码后优先推送到远程仓库,此时打工人two在本地修订代码,提交到本地仓库后,也需要推送到远程仓库,此时two晚于one,故需要先拉取远程仓库的提交,经过合并后才能推送到远端分支
远程分支也是分支,所以合并时冲突的解决方式也和解决本地分支冲突相同相同
9. Vscode使用Git
9.1 在Gitee建立仓库并配置公钥
请看7.2 和7.3
9.2 在vscode中克隆仓库
9.3 操作仓库
1.建立文件,编写代码
2.添加,并提交
3.拉取和推送
9.4 版本回退
如果想回去,也可以
总结
Git 确实很有用,让版本控制自如,结合Vscode编码,真的很不错,希望本文能帮助到你!