跟我学Git(四)

凭据保存

如何保存

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之后看到丢失的提交,再新建分支指向就可以了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351