git学习笔记(总结了常见命令与学习中遇到的问题和解决方法)

前言

最近学习完git,学习过程中也遇到了很多问题,这里给大家写一篇总结性的博客,主要大概讲述git命令和部分难点问题(简单的知识点这里就不再重复讲解了)

一.git概述

1.1什么是git

Git是一个分布式的版本控制软件。

  • 软件。
  • 版本控制,类似于毕业论文、写文案、视频剪辑等,需要反复修改和保留原历史数据
  • 分布式
    • 文件夹拷贝
    • 本地版本控制
    • 集中式版本控制
    • 分布式版本控制

1.2 为什么要做版本控制

要保留之前所有的版本,以便回滚和修改。

1.3 安装git

安装地址:https://git-scm.com/book/zh/v2/起步-安装-Git

windows下(Mac下同理)

再进行点击即可下载

安装一直点下一步即可。

1.4 git配置环境变量

环境变量配置参考之前写的博客: git配置环境变量

二.git常用命令

2.1 基础命令

命令 作用
git init 初始化本地库
git status 查看本地库状态
git add 文件名 把该文件添加到暂存区
git add . 把所有文件添加到暂存区
git config --global user.name "用户名" 设置用户名(全局配置,一次即可)
git config --global user.email "邮箱" 设置用户邮箱(全局配置,一次即可)
git commit -m '描述信息' 生成版本信息并提交到本地库
git log 查看版本记录
git reflog 查看历史版本记录
git reset --hard 版本号 回滚操作(可以回到定义的任意版本的状态)

2.2 分支操作

命令 作用
git branch 分支名 创建分支
git branch 查看当前分支
git checkout 分支名 切换分支
git merge 分支名 把指定的分支合并到当前分支上
git rebase 分支名 保持代码提交整洁(变基)
git log --graph 记录图形展示
git log --graph --pretty=format:"%h %s" 记录图形展示(简略版)
git tag -a v1.0[自己写Tag信息] -m '版本介绍' 本地创建Tag信息
git tag -d v1.0 删除Tag
git checkout v1.0 切换tag

2.3 将项目推到Github命令

命令 作用
git remote add origin 远程仓库地址 给远程仓库起别名(仅一次)
git remote -v 查看当前所有远程地址别名
git push -u origin 分支名 推送本地分支上的内容到远程仓库
git clone 远程仓库地址 将远程仓库的内容克隆到本地(第一次)
git pull 远程库地址别名 远程分支名 将远程仓库对于分支最新内容拉下来后与当前本地分支直接合并
git config --global http.sslVerify false 临时禁用 SSL 验证(不安全)
git config --global http.sslVerify true 重新启用 SSL 验证
git push origin --tags 将本地Tag信息推送到远程仓库
git pull origin --tags 更新本地tag版本信息

三.git用法讲解

3.1 git 打开使用

打开项目所在文件夹,右键找到git bash打开

3.2 git 工作流程图

3.3 git merge 分支名 的用法

bash 复制代码
git merge 分支名

该命令用于分支合并,但有可能会出现冲突,需要手动修改冲突文件来解决,或者使用Beyond Compare来解决(Beyond Compare的配置方法在后面讲)

3.4 git log --graph 与 git log --graph --pretty=format:"%h %s"

这两个命令都是进行图形化显示,效果如下(可以查看所有版本和分支情况):

bash 复制代码
git log --graph
bash 复制代码
git log --graph --pretty=format:"%h %s"

3.5 配置文件

  • 项目配置文件---用户配置(每个项目都需要进行配置,不推荐)

    bash 复制代码
    ### 配置文件位置:vim .git/config
    git config --local user.name "用户名"
    git config --local user.email "邮箱"
  • 全局配置文件(只需配置一次,全电脑项目之后都会使用该配置,推荐)

    bash 复制代码
    ### 配置文件位置:~/.gitconfig[当前用户所在目录]
    git config --global user.name "用户名"
    git config --global user.email "邮箱"
  • 系统配置文件(给系统进行配置,需要root权限)

    bash 复制代码
    ### 配置文件位置:/etc/.gitconfig
    ### 需要root权限
    git config --global user.name "用户名"
    git config --global user.email "邮箱"

3.6 免密登录

  • URL中体现

    bash 复制代码
    # 原来的地址
    # https://github.com/Caesar-Victory/Stacer.git
    # 修改的地址
    # https://用户名:密码@github.com/Caesar-Victory/Stacer.git
    git remote add origin https://用户名:密码@github.com/Caesar-Victory/Stacer.git
    git push origin master
    # 或者修改本地配置文件
  • SSH实现

    bash 复制代码
    # 生成公钥和私钥(默认生成在~/.ssh)
    ssh-keygen -r ssa
    # 拷贝公钥的内容并且设置到Github中
    # 在git本地中配置SSH地址
    git remote add origin git@github.com:Caesar-Victory/Stacer.git
  • git自动管理凭证(git会自动对内容进行管理操作,用户无需进行多余操作)

3.7 Git忽略文件

让Git不再管理当前目录下的某些文件

bash 复制代码
### vim 编辑
vim .gitignore
	文件内写入文件名和后缀,跨行书写
	*.h凡此后缀,均不管理
	.gitignore 免除对文件本身的管理
	files/忽略该目录所有文件
	!a.h 除该文件以外
	*.py[c|a|b] 同时忽略.pyc/.pya.pyb
### 再次git status
git status

更多规则参考:https://github.com/github/gitignore

意义:忽略关键文档,防止泄密

3.8 任务管理相关(GitHub,了解即可)

  • issues 文档及任务管理

    Markdown 复制代码
    ### 标签 9 labels
    
    #bug 
    something isn't working
    
    #documentation
    lmprovements or additions to documentation
    
    #duplicate
    This issue or pull request already exists
    
    #enhancement
    New feature or request
    
    #good first issue
    Good for newcomers
    
    #help wanted
    Extra attention is needed
    
    #invalid
    This doesn't seem right
    
    #question
    Further information is requested
    
    #wontfix
    This will not be worked on
  • wiki 项目文档

四.学习过程中会遇到的问题与解决方法

4.1 刚开始使用git时(没有用户身份和邮箱)

问题描述:

bash 复制代码
Tiamo@LAPTOP-G0EQAN1F MINGW64 /d/新建文件夹 (master)
$ git commit -m 'v1'
Author identity unknown

*** Please tell me who you are.

Run

  git config --global user.email "you@example.com"
  git config --global user.name "Your Name"

to set your account's default identity.
Omit --global to set the identity only in this repository.

fatal: unable to auto-detect email address (got 'Tiamo@LAPTOP-G0EQAN1F.(none)')

解决方法:

bash 复制代码
git config --global user.email "your_email@example.com"  
git config --global user.name "Your Name"

4.2 SSL证书验证问题(该问题会在远程链接仓库时会遇到)

问题描述:

bash 复制代码
Tiamo@LAPTOP-G0EQAN1F MINGW64 /d/新建文件夹 (master)
$ git push -u origin master
fatal: unable to access 'https://github.com/1273055646/dbhot.git/': SSL certificate problem: unable to get local issuer certificate

解决方法:

遇到这种问题基本都是自己做项目或者学习时会遇到,这里可以用临时禁用SSL 验证来解决,但是该方法有安全隐患(会使你的连接容易受到中间人攻击)不过对于自己学习的过程中使用来说并不影响。

bash 复制代码
# 该方法是全局(针对本地所有项目)
git config --global http.sslVerify false
bash 复制代码
# 该办法只针对当前仓库
git config http.sslVerify false

之后想要再恢复SSL 验证

bash 复制代码
git config --global http.sslVerify true

bash 复制代码
git config http.sslVerify true

4.3 BeyondCompare安装与永久免费使用

请参考之前写的博客:BeyondCompare安装(永久免费使用+全网最详细版)

4.4 git配置BeyondCompare解决冲突(无法用git打开BeyondCompare)

问题描述:

解决方法:

参考我之前写的博客: git配置BeyondCompare解决冲突(全网最细讲解,亲测有用,windows版本)

结尾

本篇博客主要对git的常见命令、各大疑难点和问题进行总结与梳理,希望对大家有所帮助,也欢迎大家留言或者私信学习git过程中遇到的问题,我也会对大家遇到的问题进行查阅与解答。

博主也是初学者,如有不到之处,欢迎大家批评指正!

相关推荐
并不会2 小时前
常见 CSS 选择器用法
前端·css·学习·html·前端开发·css选择器
龙鸣丿2 小时前
Linux基础学习笔记
linux·笔记·学习
Nu11PointerException4 小时前
JAVA笔记 | ResponseBodyEmitter等异步流式接口快速学习
笔记·学习
亦枫Leonlew5 小时前
三维测量与建模笔记 - 3.3 张正友标定法
笔记·相机标定·三维重建·张正友标定法
考试宝5 小时前
国家宠物美容师职业技能等级评价(高级)理论考试题
经验分享·笔记·职场和发展·学习方法·业界资讯·宠物
但老师6 小时前
Git遇到“fatal: bad object refs/heads/master - 副本”问题的解决办法
git
秃头女孩y6 小时前
git创建分支
git
黑叶白树7 小时前
简单的签到程序 python笔记
笔记·python
@小博的博客7 小时前
C++初阶学习第十弹——深入讲解vector的迭代器失效
数据结构·c++·学习
幸运超级加倍~8 小时前
软件设计师-上午题-15 计算机网络(5分)
笔记·计算机网络