• 路径.git下的文件


    用了这么久的git, 可以毫不谦虚地说对git是一无所知. 每天用来用去的就是commit, add, merge 等几个有限的命令, 这不符合我这刨根问底的性格啊. 不行, 得研究研究, 从哪里下手呢? 别的咱先不说, 所有 git 项目都有这么一个文件夹.git, 不如就从它入手 ? 那咱就看看这个文件夹下都有些什么妖魔鬼怪.

    先来想一想, .git文件夹下保存了git仓库的所有信息, 那么就包括:

    • 提交历史
    • 暂存内容
    • 当前分支
    • 远程分支路径
    • 等等

    好, 来看一看都有些什么:

    image-20210522220738773

    image-20210523124534487

    内容都在这了, 好, 那就对这些文件依次看一下吧.

    先来说一下我目前对这个测试项目的操作.

    ; 创建文件提交
    touch readme.md
    git add readme.md
    git commit -m 'add readme'
    ; 修改文件提交
    echo test > readme.md
    git add readme.md
    git commit -m 'change readme'
    ; 创建分支
    git checkout -b master_test
    

    仅做了两次提交操作, 这是为了保持.git文件夹最初的状态, 好方便查看.

    COMMIT_EDITMSG

    此文件保存了最后一次commit的信息. 没搞懂存这玩意有啥用, 我直接 git log看不就行了么.

    image-20210522223207116

    保存当前使用的分支.

    image-20210522223417114

    另外, 直接修改这个文件, 就可以达到git checkout命令的目的. (可以切换分支, 但是不能创建分支哦)

    再另外, 从这个文件内容中, 可以推断出, refs文件夹是用来保存分支信息的, 不过这个先记到小本本上, 接着往后看.

    config

    不用说, 看名字也知道, 是用来保存配置信息的.

    我们加一条本地配置信息看一下: git config --local user.name 'git_test'

    如果不出所料, 远程地址也保存在这里, 加一下: git remote add origin http://test.com/aa/bb

    image-20210523143935008

    description

    不多说了, 上图, 看文件描述是用来填写项目的描述信息的.

    image-20210522224441090

    hooks

    存放项目的各个钩子函数, 就是在各种操作的前后添加自己的执行逻辑. 这个之前倒是一直没有用过. 文件夹下有样例文件, 直接将.sample后缀删除即可使用. (下面只列举了常用的几个, 并不是全部)

    • pre-commit: commit 之前触发. 可用来对代码进行检查

    • prepare-commit-msg: commit 之前, 添加 message 之后.

    • commit-msg: commit 时调用, 可修改 message, 也可以取消本次提交

    • post-commit: commit 之后调用

    • post-update: push之后触发

    • pre-receive: push 时, 实际推送之前调用

    • pre-push: push 之前触发

    • pre-merge-commit: merge之前触发

    • pre-rebase: rebase 之前触发

    等等, 具体信息可到官网文档查看

    可以看到, 此文件夹用来对工作流程进行自动化管理的.

    index

    用来保存本地暂存区中的内容. 二进制文件, 不可直接查看. 可通过命令: git ls-files --stage来查看当前暂存区内容.

    info

    路径下目前只有一个文件: exclude. 此文件用来在git中忽略某些文件. 与.gitignore不同的是, 此文件不会进行提交. 也就是用来忽略一些仅你本地使用的文件.

    logs

    用来记录所有的操作记录. 看一下我本地这几个文件的内容.

    image-20210523141224344

    HEAD文件记录的是所有的操作, 而对应refs文件夹下, 则记录的时候各个分支中的操作.

    同时, 可以通过git reflog命令来进行查看, 当出现误操作的时候, 通过git reset --hard {id}来后悔.

    objects

    这个文件保存的就是所有 git 历史变动了, 具体文件的保存结构就留待日后研究. 这里先不深究.

    可通过git gc来减少文件体积.

    refs

    保存本地的分支和标签. 文件内容也很简单, 就是一个 commit id.

    另外, gc之后, 会多出来一个: .git/packed-refs文件. 此文件包含refs下的所有信息, 同时refs下的文件会被清空.

    其他文件

    FATCH_HEAD

    用来保存远程分支信息

    image-20210523145221640

    ORIG_HEAD

    在执行如merge, reset, rebase等操作时, 对 "HEAD"文件内容进行备份.

    sourcetreeconfig

    当使用sourcetree对项目进行管理时, 用来保存sourcetree中的配置信息.


    .git文件夹下的内容过了一遍, 基本保存的位置都找到了, 剩下保存内容的二进制文件了还整不明白.

    过下来之后, 倒也发现了一些能够帮到我的内容, 比如本地的 ignore, 之前的处理是在路径下添加.gitignore同时将.gitignore文件本身也忽略. 后面可以直接修改.git/info/exclude这个文件.

  • 相关阅读:
    【JZOJ3852】【NOIP2014八校联考第2场第2试9.28】单词接龙(words)
    【JZOJ3853】【NOIP2014八校联考第2场第2试9.28】帮助Bsny(help)
    【JZOJ3854】【NOIP2014八校联考第2场第2试9.28】分组(group)
    【JZOJ4934】【NOIP2017GDKOI模拟1.12】a
    【JZOJ4935】【NOIP2017GDKOI模拟1.12】b
    【JZOJ4925】【GDOI2017模拟12.18】稻草人
    【JZOJ4930】【NOIP2017提高组模拟12.18】C
    【JZOJ4929】【NOIP2017提高组模拟12.18】B
    如何重新加载Spring Boot上的更改,而无需重新启动服务器?
    什么是JavaConfig及其优点?
  • 原文地址:https://www.cnblogs.com/hujingnb/p/14801202.html
Copyright © 2020-2023  润新知