Git详细讲解

一、Git 介绍

Git 是一款开源免费的版本控制系统,是一个应用程序。

在这里插入图片描述

1.1 Git 作用

版本控制系统在项目开发中作用重大,主要的功能有以下几点

  • 代码备份
  • 版本回退
  • 协作开发
  • 权限控制

1.2 下载安装

下载地址 https://git-scm.com/ ,安装方式与 QQ 安装相同,一路下一步,中间可以设置软件的安装路径

在这里插入图片描述

安装路径不要使用中文

二、Linux 常用命令(了解)

Linux 是一套开源免费的操作系统,它与 Windows 属于同一类型的事物,但是操作方式却与 windows 不同。

在这里插入图片描述

Windows 一般为图形化操作形式,Linux 一般使用命令与系统进行交互,常用的命令有:

命令介绍
touch创建一个或多个文件 (创建多个文件时用空格删除)
mkdir创建文件夹(make directory)
ls查看文件夹下的文件 (list 单词的缩写)
cd改变工作目录,(change directory 缩写)
cd /d或cd d:切换盘符
Tab路径自动补全
clear清屏(也可以使用 ctrl + l 快捷键)
rm删除文件或文件夹 (删除不会进入回收站) -r 递归删除 用来删除非空文件夹
cat查看文件内容
mv移动文件以及重命名 『move』 单词的缩写
ctrl + c取消命令 c cancel 缩写
上下方向键查看命令历史

三、Vim 基本使用(了解)

Vim 是一款命令行下的文本编辑器,编辑方式跟图形化编辑器不同

在这里插入图片描述

Vim 编辑文件的步骤:

  1. 命令行 vim 文件名 打开文件

  2. 按『i』进入编辑模式

  3. 编辑文件内容

  4. ESC + :wq 保存并退出 w: write q: quit

    ESC + :q! 不保存并退出

在这里插入图片描述

四、Git 使用

4.1 起始配置:必须要做!

第一次使用 Git 的时候,我们需要配置用户名和邮箱,记录开发者的信息

# 配置自己的姓名
git config --global user.name "Your Name" 
# 配置自己的邮箱
git config --global user.email "email@example.com" 

注意

  1. 命令之间有空格

  2. 上面的两个命令只需要运行一次即可, 如果输入错误, 重新运行命令即可

  3. 可以使用 git config -l 命令来查看配置信息

    窗口高度不够,会出现滚动窗口,此时使用 q 字母退出配置查看窗口) quit 的缩写

  4. 这个命令以后不用自己手敲, 直接复制修改『名字』与『邮箱』即可

  5. 命令的运行不受位置的影响

4.2 基本操作

Git 的起始操作包括以下几个步骤

  1. 创建并进入空文件夹

  2. 右键 -> 点击 Git Bash Here 启动命令行

  3. 仓库初始化 (一个仓库只运行一次 git init)

    git init
    
  4. 创建一个初始化文件 index.html

  5. 将文件加入到暂存区

    git add index.html
    
  6. 提交到仓库

    git commit -m  '文字说明'
    
添加
修改
删除

4.3 版本库的三个区域

  • 工作区(代码编辑区)
  • 暂存区(修改待提交区)
  • 仓库区(代码保存区)

在这里插入图片描述

4.4 命令小结

命令作用
git status查看版本库状态
git add .添加所有修改到暂存区 git add -A / --all / *
git ls-files查看暂存区文件
git rm --cached移除暂存区文件
git commit -m 注释 建立存档并添加注释
git restore .恢复工作区的内容
git diff查看工作区与暂存区的差异(不显示新增文件)
git diff --cached查看暂存区与仓库的差异

在这里插入图片描述

4.5 版本回滚

Git 可以将项目代码内容切换到历史的任何一个版本

4.5.1 查看历史记录

借助于下面命令,可以查看

git log
git log --oneline

如果内容偏多, 需要使用方向键上下滚动, 按 q 退出

4.5.2 版本回滚
git reset --hard  b815fd5a6ae655b521a31a9

git reset --hard HEAD^ 

进行版本回退时,不需要使用完整的哈希字符串,前七位即可

版本切换之前,建议先对工作区内容进行提交 add commit

4.5.3 找不到版本号的情况

查看所有的操作记录

git reflog 

4.6 配置忽略文件

项目开发过程中有些文件不应该存储到版本库中,这个时候配置忽略这些文件。常见情况有:

  1. 临时文件

    1. .swp 文件 vim 编辑器产生的临时文件
    2. log 文件
  2. 多媒体文件,如音频,视频

  3. 可执行文件,如 exe 文件

  4. 编辑器生成的配置文件 (.idea)

  5. npm 安装的第三方模块

Git 中需要创建一个文件 『.gitignore』 设置忽略,一般与 .git 目录同级,常用规则如下:

# 忽略所有的 .idea 文件夹
.idea
# 忽略所有以 .test 结尾的文件
*.test
# 忽略 node_modules 文件和文件夹
/node_modules
#当前目录下的index.html
/index.html

4.7 分支

分支是 Git 重要的功能特性之一,开发人员可以在主开发线的基础上分离出新的开发线。

4.7.1 基本操作
命令作用
git branch name创建分支
git branch查看所有分支
git checkout name切换分支
git merge name合并分支
git branch -d name删除分支(-d 是delete缩写) (-D 是强制删除)
git checkout -b name创建并切换(-b 是 branch缩写)

注意: 每次在切换分支前 提交工作区的修改

五、Gitee

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-q2K63crj-1669427339050)(C:\Users\13910\AppData\Roaming\Typora\typora-user-images\1666943210488.png)]

5.1 介绍

GiteeGitHub 一样,是一个 Git 仓库管理网站。可以创建远程中心仓库,为多人合作开发提供便利。

5.2 使用流程

GitHub(Gitee) 远程仓库使用流程较为简单,主要有以下几种场景:

5.2.1 本地有仓库
  1. 注册并激活账号

  2. 创建仓库

  3. 获取仓库的地址

  4. 本地配置远程仓库 URL 的别名

    git remote add origin https://gitee.com/zhibao/2022-9-2.git
    
    • add 添加
    • origin 远端仓库 URL 的别名
    • https://gitee.com/zhibao/2022-9-2.git 仓库 URL 地址
  5. 查看远程仓库列表

    git remote -v
    
  6. 删除远程仓库别名列表

    git remote remove name
    
  7. 远程仓库别名重命名

    git remote rename oldName newName
    
  8. 本地提交

    git commit -m '注释'
    
  9. 将本地仓库内容推送到远程仓库

    git push -u origin master   (第一次提交方式)
    
    • push 推送
    • -u 关联, 加上以后,后续提交时可以直接使用 git push
    • origin 远端仓库的别名
    • master 本地仓库的分支
  10. 后续提交方式

    git push
    
5.2.2 本地没有仓库
  1. 注册并激活账号

  2. 先创建远程仓库

  3. 复制远程仓库地址

  4. 克隆仓库

    git clone https://github.com/xiaohigh/test2.git 
    
  5. 增加和修改代码

  6. 本地提交

    git add -A
    git commit -m 'message'
    
  7. 推送到远程

    git push origin master
    

克隆代码之后, 本地仓库会默认有一个远程地址的配置, 名字为 origin

5.2.3 免密提交
  1. 在git命令行中执行下列命令,创建一个密钥对

    ssh-keygen -t rsa -C "13910561096@163.com"
    
  2. 一路回车-生成密钥文件

  3. 去指定文件夹下查找文件

    • id_rsa 私钥
    • id_rsa.pub 公钥 √
  4. 复制公钥的内容

  5. 打开 gitee 的 SSH 设置

    首页->头像->设置->SSH公钥 -> 添加公钥 -> 设置名称以及粘贴公钥内容

  6. 后续在使用仓库 URL 时, 选择 ssh 协议的 URL 即可

5.3 多人合作

5.3.1 账号仓库配置

Gitee 团队协作开发流程

  • 新建仓库。gitee 首页 -> 右上角 + 号-> 新建仓库
  • 填写信息。填写仓库相关内容『不建议勾选初始化选项』
  • 设置开源。仓库首页(不是 gitee 首页) -> 右侧 -> 管理 -> 基本信息 -> 是否开源 -> 开源
  • 设置权限。仓库首页(不是 gitee 首页) -> 右侧 -> 管理 -> 仓库成员管理 -> 开发者 -> 添加仓库成员 -> 邀请用户
5.3.2 协作流程

第一次提交

  1. 得到 Git 远程仓库的地址和账号密码

  2. 将代码克隆到本地(地址换成自己的)

    git clone https://github.com/xiaohigh/test.git
    
  3. 切换分支

    git checkout -b 新分支名
    
  4. 开发代码

  5. 本地提交

    git add -A
    git commit -m '注释内容'
    
  6. 合并分支

    git checkout master
    git merge 新分支名
    
  7. 更新本地代码

    git pull
    
  8. 提交代码

    git push 
    
5.3.3 工作流程

第 N 次流程

  1. 主分支更新代码

    git pull
    
  2. 创建并切换分支

    git checkout -b 新分支名
    
  3. 开发功能

  4. 提交

    git add -A
    git commit -m '注释'
    
  5. 合并分支

    git checkout master
    git merge 新分支名
    
  6. 更新代码

    git pull
    
  7. 推送代码

    git push
    
5.3.4 冲突解决
git pull

git push

同分支冲突一样的处理,将代码调整成最终的样式,提交代码即可。

5.4 GitFlow

GitFlow 是团队开发的一种最佳实践,将代码划分为以下几个分支

在这里插入图片描述

  • Master 主分支。上面只保存正式发布的版本
  • Hotfix 线上代码 Bug 修复分支。开发完后需要合并回Master和Develop分支,同时在Master上打一个tag
  • Featuer 功能分支。当开发某个功能时,创建一个单独的分支,开发完毕后再合并到 dev 分支
  • Release 分支。待发布分支,Release分支基于Develop分支创建,在这个Release分支上测试,修改Bug
  • Develop 开发分支。开发者都在这个分支上提交代码

六、附录(了解)

6.1 Git 官方书籍

https://git-scm.com/book/zh/v2/

6.2 .git 目录介绍

在这里插入图片描述

  • hooks 目录包含客户端或服务端的钩子脚本,在特定操作下自动执行
  • info 信息文件夹. 包含一个全局性排除文件,可以配置文件忽略
  • logs 保存日志信息
  • objects 目录存储所有数据内容,本地的版本库存放位置
  • refs 目录存储指向数据的提交对象的指针(分支)
  • config 文件包含项目特有的配置选项
  • description 用来显示对仓库的描述信息
  • HEAD 文件指示目前被检出的分支
  • index 暂存区文件,是一个二进制文件 (git ls-files)

切记: 不要手动去修改 .git 文件夹中的内容

6.3 CRLF

CRLF 是Carriage-Return Line-Feed 的缩写。

CR 表示的是 ASCII 码的第 13 个符号 \r 回车,LF 表示的是 ASCII 码表的第 10 个符号 \n 换行。

每个操作系统对回车换行的存储方式不同

  • windows 下用 CRLF(\r\n)表示
  • linux 和 unix 下用 LF(\n)表示
  • mac 系统下用 CR(\r)表示

在这里插入图片描述

6.4 常见错误

回车换行问题

在这里插入图片描述

这个问题主要是 Git 在你提交时自动地把回车(CR)和换行(LF)转换成换行(LF),没有影响,这里建议大家保留这个状态。可以通过下面的命令设置不转换,但是不推荐

git config --global core.autocrlf false // 不推
提交报错

在这里插入图片描述

冲突提醒

修改文件后重新提执行 git push

提交错误

在这里插入图片描述

如果第一次将本地仓库分支提交到远程时,直接使用 git push 可能会报这个错误,解决方法

git push -u origin master
提交错误

在这里插入图片描述

当前所在文件夹不是一个 git 仓库目录,切换目录工作

6.5 卸载密码管理工具

git config --system --unset credential.helper
  • 6
    点赞
  • 40
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值