凭据保存
如何保存
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使用多个配置文件来确定需要的非默认配置。
- Git首先查看/etc/gitconfig文件,系统中每一个用户及其仓库在该文件中都有对应的值。通过
git config --system
读写这个文件。 - 查看~/.gitconfig(或者~/.config/git/config)文件,该文件针对单个用户,可以传入
--global
读写这个文件。 - 最后查看当前使用仓库的Git目录(.git/config)中配置文件内容,针对单个仓库。
客户端基本配置
如果查看当前所用Git的全部选项,可以执行以下命令。
man git-config #详细列出所有可用选项
- 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之后看到丢失的提交,再新建分支指向就可以了。