美文网首页
Git 的基本使用

Git 的基本使用

作者: 前端开发养成记 | 来源:发表于2021-08-23 12:06 被阅读0次

    Git 的介绍

    Git 是一种分布式的版本管理系统。简单来说,它就是一个版本控制软件,而且也是现在世界上最流行最先进的。

    Git 的一个具体作用就是对文件进行版本管理。由于每次项目上线,可能会产生一些无法预料的bug,这时就需要选择上一个正常的版本进行回滚操作。而 Git 的存在,就是为了开发人员能够方便地在不同版本之间进行切换。

    Github、码云Gitee,在某种程度上来说,就是代码的网盘。也有开源的开发商作为代码发布、存放、征集bug的地方。

    除了版本管理这个功能,Git 在团队协作开发上也有很大的优势。由于每个模块的代码都是独立的,并不会影响到其他人员的模块代码。开发完成后,项目负责人会通过git命令,去把每个模块的分支合并到一个叫master主分支上面,项目正式上线的时候,就会把master主分支进行上线部署。

    SVN,也是一个版本管理系统,但是它必须要在指定的网络环境上才能进行开发和管理。所以一旦网络崩溃或者说服务器宕机了,那么SVN的版本控制功能也就崩溃了。Git —— 分布式,可以让每个开发人员都能将整个代码完整地下载到本地,包括这个项目的分支、版本更新记录。如果线上环境崩溃,完全可以通过本地选择上一个正常的呆板,然后进行回滚,再将代码覆盖至线上就能进行恢复了。

    1.1 Git 工作原理

    1.1.1 工作区

    Git 在本地初始化一个仓库后,会存在一个 .git 文件夹。它还存在三个工作区域:工作目录(工作区)、暂存区、资源库。如果从远端仓库拉去的项目,那就会多一个工作区域,就是远程git仓库。

    • 工作区(workspace):平时开发代码、写代码的地方;
    • 暂存区(Stage / Index):用于临时保存代码的改动;
    • 本地仓库(Repository):用于存放所有版本的数据;
    • 远程仓库(Remote):保存代码的地方,Github、码云;

    2. Git 命令

    2.1 Git 基础操作命令

    2.1.1 Git 四步走

    添加当前工作区文件到暂存区

    git add .
    

    将暂存区的代码提交到本地仓库

    git commit -m "备注信息"
    

    将远程仓库代码拉取到本地

    git pull
    

    将本地仓库的代码,推送到远端仓库

    git push
    
    2.1.2 克隆远程仓库代码

    如果你本地没有这些代码的情况下,使用这个命令将远程仓库的代码克隆至本地

    git clone https://gitee.com/lyan-test/git-demo.git
    

    2.2 Git 配置命令

    2.2.1 查看配置命令

    # 查看所有配置
    git config -l
    
    # 查看系统配置
    git config --system -l
    
    # 查看全局配置
    git config --global -l
    

    2.2.2 配置全局

    git config --global user.name "lyan_test"
    git config --global user.email "1055869654@qq.com"
    

    2.3 进阶操作

    恢复某个阶段的代码

    # 恢复到上一次版本
    git reset --hard HEAD^
    
    # 恢复到前3次提交时的版本
    git reset --hard HEAD~3
    
    # 恢复到指定的hash版本
    git reset --hard 哈希码
    

    3. 忽略文件

    在项目根目录下创建一个名为 .gitignore 文件,文件里面写上需要排除的文件名即可。

    如果说忽略文件之前就已经提交过这个文件,那就需要在工作目录先执行一次删除文件操作,再把这次操作提交到我们的本地仓库中进行同步。那下次推送时,远程仓库需要被忽略的文件就会被删除了。

    3.1 匹配规则

    如果想要忽略所有以某个后缀名为后缀的文件

    *.md
    

    如果想要排除某个文件不被忽略,可以通过英文感叹号 !

    !readme.md
    

    想排除根目录下的某个文件夹,可以通过 / + 文件夹来忽略

    /test               # 这里代表根目录下的test文件夹将会被忽略提交,而 /js/test 的则不会。
    

    如果想排除所有文件夹下的test文件夹

    */test
    test/
    

    4. 分支

    每一个实际项目中,都会存在多个分支。每个分支都对应着一个模块,或者说需要修复的bug。

    查看本地所有分支
    git branch
    
    查看远程所有分支
    git branch -r
    
    新建分支
    git branch 分支名
    
    切换开发分支
    git checkout 分支名
    
    新建并切换分支
    git checkout -b 分支名
    

    在切换分支时,一定要提交已修改的代码。否则另一条分支的代码将会覆盖工作区的代码文件,当然,git 是不允许这样操作的。

    合并分支
    git merge 分支B           # 假设当前开发的分支为分支A
    

    代码意思是,分支B的内容将会合并到分支A内,但分支B的代码不会受到影响。

    如果出现了有代码冲突的地方,那就需要去和开发人员商讨如何保留。

    删除分支
    git branch -d 分支名
    

    删除分支时,首先要保证当前开发的分支不是被删除的那条分支,否则会删除失败。

    如果被删除分支中存在差异性代码,那么也会导致删除失败。因为Git认为该操作会导致代码丢失的情况出现,所以确保没问题之后,可以通过强制删除命令删除分支。或者去将要删除的分支中,进行一次代码提交。

    git branch -D 分支名           # 强制删除分支
    
    删除远程分支
    git branch -dr [remote/branch]      # 这个方法只是将本地的远程信息删除,并不会实际影响到远程仓库的分支
    git push origin --delete branch         # 能够直接将远程仓库的分支进行删除
    

    杂项命令

    查看当前文件的状态
    git status
    
    • Untracked:未跟踪,文件在工作区内,但是并没有经过 Git 的管理,要通过 git add 将文件加到暂存区,然后状态变为 Staged
    • Unmodify:文件已经进入 Git 版本库,此时 Git 会将版本库中的文件与工作区内的文件进行对比,如果内容完全一致,则代表文件未修改,也就是现在文件的状态。可以通过 git rm 将文件移出版本库,变为 Untracked 状态的文件;
    • Modified:文件已进入 Git 版本库,并且经对照后发现文件已经发生修改,但没有添加到暂存区。此时文件可以通过 git add 进入暂存区,或者通过 git checkout 命令,用版本库中的文件覆盖掉工作区的文件,此时文件状态会变为 Unmodify;
    • Staged:文件处于暂存区,通过 git commit 命令提交到本地仓库中。可以使用 git reset HEAD filename 取消暂存,文件状态将变为 Modified。

    可能存在的问题

    push 代码时,出现 403 错误

    如果当前电脑之前登陆过码云,这时用的是另外一个码云账号,一般push时会出现403错误。

    • Windows用户:控制面板 —— 用户帐户 —— 凭据管理器 —— Windows凭据,找到gitee凭据删除即可。

    • Mac:钥匙串访问 —— 搜索git,会出现 gitee.com 的一个钥匙串,右键删除即可。

    git push -f 导致远程仓库历史记录丢失

    当本地仓库没有包含远程仓库所有的历史记录时,强制推送会导致远程仓库的历史记录丢失,产生不可逆的影响。

    相关文章

      网友评论

          本文标题:Git 的基本使用

          本文链接:https://www.haomeiwen.com/subject/kordiltx.html