©
Ce document utilise Manuel du site Web PHP chinois Libérer
git-remote - 管理追踪存储库的集合
git remote [-v | --verbose]git remote add [-t <branch>] [-m <master>] [-f] [--[no-]tags] [--mirror=<fetch|push>] <name> <url>git remote rename <old> <new>git remote remove <name>git remote set-head <name> (-a | --auto | -d | --delete | <branch>)git remote set-branches [--add] <name> <branch>… git remote get-url [--push] [--all] <name>git remote set-url [--push] <name> <newurl> [<oldurl>]git remote set-url --add [--push] <name> <newurl>git remote set-url --delete [--push] <name> <url>git remote [-v | --verbose] show [-n] <name>… git remote prune [-n | --dry-run] <name>… git remote [-v | --verbose] update [-p | --prune] [(<group> | <remote>)…]
管理您追踪分支的一组存储库(“远程”)。
-v --verbose
稍微详细一点,并在名称后显示远程 URL 。注意:这必须放在remote
和之间subcommand
。
没有参数,显示现有遥控器的列表。几个子命令可用于在遥控器上执行操作。
add
在 <url> 处添加一个名为 <name> 的存储库。该命令git fetch <name>
然后可用于创建和更新远程跟踪分支<name> / <branch>。
使用-f
选项,git fetch <name>
在远程信息设置完成后立即运行。
使用--tags
选项,git fetch <name>
从远程存储库导入每个标记。
使用--no-tags
选项,git fetch <name>
不会从远程存储库导入标签。
默认情况下,只有取回分支上的标签被导入(参见 git-fetch [1])。
使用-t <branch>
选项,而不是远程的默认 glob refspec 来跟踪refs/remotes/<name>/
命名空间下的所有分支,将<branch>
创建仅用于跟踪的 refspec 。您可以给-t <branch>
多个分支追踪多个分支,而无需抓取所有分支。
使用-m <master>
选项,符号引用refs/remotes/<name>/HEAD
被设置为指向远程的<master>
分支。另请参阅 set-head 命令。
当创建获取镜像时--mirror=fetch
,参考将不会存储在refs/remotes/
命名空间中,而是refs/
将远程中的所有内容直接镜像到refs/
本地存储库中。这个选项在裸存储库中才有意义,因为提取会覆盖任何本地提交。
当创建一个推式镜像时--mirror=push
,它git push
总是表现得好像--mirror
被传递一样。
rename
将名为 <old> 的远程重命名为 <new> 。远程的所有远程跟踪分支和配置设置都会更新。
如果 <old> 和 <new> 相同,并且 <old> 是$GIT_DIR/remotes
或者下的文件$GIT_DIR/branches
,则将远程转换为配置文件格式。
remove rm
删除名为 <name> 的远程。远程的所有远程跟踪分支和配置设置均被删除。
set-head
设置或删除refs/remotes/<name>/HEAD
指定远程的默认分支(即 symbolic-ref 的目标)。有一个远程的默认分支不是必需的,但允许指定远程的名称来代替特定的分支。例如,如果默认分支for origin
设置为master
,则origin
可以在通常指定的任何位置指定origin/master
。
使用-d
或 --delete
,符号 ref refs/remotes/<name>/HEAD
被删除。
使用-a
或--auto
,远程被查询来确定它HEAD
,然后
symbolic-ref refs/remotes/<name>/HEAD
被设置为同一分支。例如,如果远程HEAD
正指向next
“ git remote set-head origin -a
”将设置符号 -REF refs/remotes/origin/HEAD
到refs/remotes/origin/next
。这只有在refs/remotes/origin/next
已经存在的情况下才有效; 如果不是,它必须先取得。
用于显式<branch>
设置符号引用refs/remotes/<name>/HEAD
。例如,“GIT 中远程设置头原点主”将设置符号 -REF refs/remotes/origin/HEAD
到refs/remotes/origin/master
。这只有在refs/remotes/origin/master
已经存在的情况下才有效; 如果不是,它必须先取得。
set-branches
更改已命名远程所跟踪分支的列表。这可以用于在远程初始设置后跟踪可用远程分支的一个子集。
指定的分支将被解释为与命令行中的-t
选项一起指定git remote add
。
随着--add
的,而不是替换当前跟踪的分支列表,添加到列表中。
get-url
检索远程的 URL 。这里的配置insteadOf
和pushInsteadOf
扩展。默认情况下,仅列出第一个 URL 。
使用--push
,查询推送 URL 而不是获取 URL 。
与--all
,远程的所有 URL 将被列出。
set-url
更改远程的 URL 。为匹配 regex <oldurl> 的远程 <name> 设置第一个 URL(如果没有给出 <oldurl> ,则为第一个 URL )为 <newurl> 。如果 <oldurl> 与任何 URL 都不匹配,则会发生错误并且没有任何更改。
使用时--push
,推送网址将被操纵,而不是抓取网址。
随着--add
,而不是改变现有的 URL ,新的 URL 添加。
用--delete
,而不是改变现有的 URL ,所有匹配正则表达式
<URL> URL 被用于远程 <name> 删除。试图删除所有非推送网址是一个错误。
请注意,即使可以设置不同的推送网址和提取网址,仍必须引用相同的地方。您推送到推送网址的内容应该是您立即从提取网址获取的内容。如果您试图从一个地方(例如上游)获取数据并推送到另一个地方(例如您的发布存储库),请使用两个单独的遥控器。
show
给出关于远程 <name> 的一些信息。
通过-n
选项,远程头不首先被查询git ls-remote <name>
; 取而代之的是使用缓存的信息。
prune
删除 <name> 下的所有陈旧的远程追踪分支。这些陈旧的分支已从 <name> 引用的远程存储库中删除,但仍在本地“remotes / <name>”中可用。
使用--dry-run
选项,报告将修改哪些分支,但不实际修改它们。
update
按遥控器 <group> 的定义,获取存储库中一组指定遥控器的更新。如果未在命令行中指定命名组,则将使用配置参数 remotes.default ; 如果没有定义 remotes.default ,那么没有配置参数 remote. <name> .skipDefaultUpdate 设置为 true 的所有遥控器都将被更新。(请参阅 git-config [1])。
使用--prune
选项,修剪所有更新的遥控器。
远程配置使用remote.origin.url
和remote.origin.fetch
配置变量来实现。(请参阅 git-config [1])。
添加一个新的远程,获取并签出一个分支 $ git remote origin $ git branch -r origin / HEAD - > origin / master origin / master $ git remote add staging git://git.kernel.org/。 ../gregkh/staging.git $ git 远程原点暂存 $ git fetch staging ...从git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging *新的分支主控 - > staging / staging-next $ git branch -r origin / HEAD - > origin / master origin / master staging / master staging / master staging / master staging / master staging / master staging / staging-linus staging / staging-next $ git checkout -b临时分段/主...
模仿git clone
但只追踪选定的分支
$ mkdir project.git $ cd project.git $ git init $ git remote add -f -t master -m master origin git://example.com/git.git/ $ git merge origin
git-fetch [1] git-branch [1] git-config [1]