## 10.5 引用规格
引用规格(refspec)用于远程库的获取操作。在添加一个远程版本库时,Git 会在`.git/config`文件中添加一个小节,并在其中指定远程版本库的名称(`origin`)、URL 和一个用于获取操作的引用规格(refspec):
```
[remote "origin"]
url = [url]
fetch = +refs/heads/*:refs/remotes/origin/*
```
引用规格的格式由一个可选的`+`号和紧随其后的`<src>:<dst>`组成,其中`<src>`是一个模式(pattern),代表远程版本库中的引用;`<dst>`是那些远程引用在本地所对应的位置;`+`号告诉 Git 即使在不能快进的情况下也要(强制)更新引用。
如果想让 Git 每次只拉取远程的`master`分支,而不是所有分支,可以把(引用规格的)获取那一行修改为:
```
fetch = +refs/heads/master:refs/remotes/origin/master
```
也可以指定多个引用规格:
```
[remote "origin"]
url = [url]
fetch = +refs/heads/master:refs/remotes/origin/master
fetch = +refs/heads/[branch]:refs/remotes/[remote]/[branch]
```
但是注意,不能在模式中使用部分通配符。
**引用规格推送**
与 `fetch` 类似,Git 支持引用规格推送:
```
[remote "origin"]
url = [url]
fetch = +refs/heads/*:refs/remotes/[remote]/*
push = refs/heads/[branch]:refs/heads/[remote]/[branch]
```
**删除引用**
可以借助类似下面的命令通过引用规格从远程服务器上删除引用:
```
$ git push origin :[branch]
```
或者使用更新的语法(自Git v1.7.0以后可用):
```
$ git push origin --delete [branch]
```
- 介绍
- 第一章 起步
- 1.1 关于版本控制
- 1.2 Git 简史
- 1.3 Git 基础
- 1.4 命令行
- 1.5 安装 Git
- 1.6 初次运行 Git 前的配置
- 1.7 获得帮助
- 第二章 基础
- 2.1 获取仓库
- 2.2 记录每次更新到仓库
- 2.3 查看提交历史
- 2.4 撤销操作
- 2.5 远程仓库的使用
- 2.6 打标签
- 2.7 Git 别名
- 第三章 分支
- 3.1 分支简介
- 3.2 分支的新建与合并
- 3.3 分支管理
- 3.4 分支开发工作流
- 3.5 远程分支
- 3.6 变基
- 第四章 服务器上的 Git
- 4.1 协议
- 4.2 在服务器上搭建 Git
- 4.3 生成 SSH 公钥
- 4.4 配置服务器
- 4.5 Git 守护进程
- 4.6 Smart HTTP
- 4.7 GitWeb
- 4.8 GitLab
- 4.9 第三方托管的选择
- 第五章 分布式 Git
- 5.1 分布式工作流程
- 5.2 向一个项目贡献
- 5.3 维护项目
- 第六章 GitHub
- 6.1 账户的创建和配置
- 6.2 对项目做出贡献
- 6.3 维护项目
- 6.4 管理组织
- 6.5 脚本 GitHub
- 第七章 Git 工具
- 7.1 选择修订版本
- 7.2 交互式暂存
- 7.3 储藏与清理
- 7.4 签署工作
- 7.5 搜索
- 7.6 重写历史
- 7.7 重置揭密
- 7.8 高级合并
- 7.9 Rerere
- 7.10 使用Git调试
- 7.11 子模板
- 7.12 打包
- 7.13 替换
- 7.14 凭证存储
- 第八章 自定义 Git
- 8.1 配置 Git
- 8.2 Git 属性
- 8.3 Git 钩子
- 8.4 使用强制策略的一个例子
- 第九章 Git 与其他系统
- 9.1 作为客户端的 Git
- 9.2 迁移到 Git
- 第十章 Git 内部原理
- 10.1 底层命令和高层命令
- 10.2 Git 对象
- 10.3 Git 引用
- 10.4 包文件
- 10.5 引用规格
- 10.6 传输协议
- 10.7 维护与数据恢复
- 10.8 环境变量
