美文网首页程序员
跟我学Git(四)

跟我学Git(四)

作者: 橙皇cc | 来源:发表于2020-06-16 13:46 被阅读0次

    凭据保存

    如何保存

    Git有一套有助于解决重复验证的凭据系统,有如下选项:

    • 默认不缓存任何内容。所有连接都会提醒你输入用户名和密码。
    • cache模式将凭据保存在内存一段时间,15分钟后从缓存中清除。
    • store模式将凭据保存在磁盘的纯文本文件中,永不过期。
    • 如果使用的是Mac,Git有一种osxkeychain模式,凭据会以加密的形式缓存在与个人账户相关的安全密钥链中,存放在磁盘上,永不过期。
    • 如果使用的是Windows,可以安装Git Credential Manager for Windows。与Mac特有的osxkeychain模式类似。

    以上配置如下实现:

    git config --global credential.helper cache
    git config --global credential.helper store --file ~/.my-credentials  # 添加--file选项自定义存储位置,默认为~/.git-credentials
    
    

    配置Git

    Git使用多个配置文件来确定需要的非默认配置。

    1. Git首先查看/etc/gitconfig文件,系统中每一个用户及其仓库在该文件中都有对应的值。通过git config --system读写这个文件。
    2. 查看~/.gitconfig(或者~/.config/git/config)文件,该文件针对单个用户,可以传入--global读写这个文件。
    3. 最后查看当前使用仓库的Git目录(.git/config)中配置文件内容,针对单个仓库。

    客户端基本配置

    如果查看当前所用Git的全部选项,可以执行以下命令。

    man git-config   #详细列出所有可用选项
    
    1. commit.template
      把此项设置改为系统中某个文件的路径,提交的时候,Git就会使用该文件作为提交的默认信息。开发团队对于提交消息都会有统一规范,可以把规定的模板放入系统中并配置Git默认使用它。
    git config --global commit.template ~/.gitmessage.txt  #默认文件为 gitmessage
    

    2.core.excludesfile
    这个配置允许设置一种全局性质的.gitignore文件。

    git config --global core.excludesfile ~/.gitignore_global  #按照gitignore_global忽略所有符合类型的文件
    

    3.core.autocrlf
    如果开发团队用的平台有Windows和Mac或Linux,会碰上行终止符的问题。Git可以在将文件加入索引时自动把CRLF形式的行终止符转换成LF,在将代码检出到本地文件系统时自动将LF形式的行终止符转换成CRLF,通过如下命令启用:

    git config --global core.autocrlf true   #Windows系统 检出代码将LF转换成CRLF
    git config --global core.autocrlf input  #Linux或Mac系统 提交时将CRLF转换成LF
    

    二进制文件

    可以告诉Git哪些文件是二进制格式,并特别指示Git如何处理这些文件。

    比较二进制文件

    如果你想对Word文件进行版本控制,可以把文件放进Git仓库中,在.gitattributes中加入*.docx diff=word来告诉Git包含变更的差异比较结果时,所有匹配.docx模式的文件都应该使用word过滤器。下面来配置Git设置word过滤器。首先,安装docx2txt到shell能查找到的路径下,然后编写包装器脚本将输出转换成Git支持的格式,在shell的PATH路径下创建一个名为docx2txt的文件,加入以下内容:

    #!/bin/bash
    docx2txt.pl $1 -
    

    最后配置Git使用这个脚本:

    git config diff.word.textconv docx2txt
    

    现在如果对两份快照进行差异比较,就转换成了对应文本改动的比较。
    同样的方法也可以运用在图像文件上,将如下添加到.gitattributes:

    *.png diff=exif
    

    配置Git使用该工具:

    git config diff.exif.textconv exiftool
    

    实现图像比较的前提是下载并安装了exiftool程序。

    数据恢复

    在使用Git时,有可能丢失了某次提交,如强行删除了正在使用的分支或者硬重置了分支,丢弃了有用的提交。这时候需要找出最后一次提交的SHA-1值,然后添加一个指向它的分支。这里的技巧在于找到最后一次提交的SHA-1值。
    通常最快的方法是利用git reflog工具,每次提交或修改分支,引用日志(reflog)都会更新,git update-ref命令也会也会更新引用日志。可以执行git log -g,会将引用日志按照正常的日志格式输出。

    git branch recover-branch ab1afef  #新建分支指向丢失提交
    

    假如某种原因引用日志无法找到,或者引用日志丢失。可以使用git fsck工具,加上--full选项,它会显示出所有没有被其他对象指向的对象。可以在dangling commit之后看到丢失的提交,再新建分支指向就可以了。

    相关文章

      网友评论

        本文标题:跟我学Git(四)

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