- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为git写教学 Material ,我需要演示git prune
删除“分离的对象”。我以为可以通过使用git reset
将提交与分支历史记录分离而将提交置于分离状态。
这将触发git checkout
将提交视为已分离,但是git prune
不会在意它。
我当前的分离提交模拟的设置如下:
~ $ mkdir git-prune-demo
~ $ cd git-prune-demo/
~/git-prune-demo $ git init .
Initialized empty Git repository in /Users/kev/Dropbox/git-prune-demo/.git/
~/git-prune-demo $ echo "hello git prune" > hello.txt
~/git-prune-demo $ git add hello.txt
~/git-prune-demo $ git commit -am "added hello.txt"
[master (root-commit) 994b122] added hello.txt
1 file changed, 1 insertion(+)
create mode 100644 hello.txt
~/git-prune-demo $ echo "this is second line txt" >> hello.txt
~/git-prune-demo $ git commit -am "added another line to hello.txt"
[master 5178bec] added another line to hello.txt
1 file changed, 1 insertion(+)
~/git-prune-demo $ git reset --hard 994b122045cf4bf0b97139231b4dd52ea2643c7e
HEAD is now at 994b122 added hello.txt
~/git-prune-demo $ git prune -n
~/git-prune-demo $ nothing
git prune
通常不用作独立命令,实际上是
git gc
的子级。
最佳答案
TL; DR
您将需要先运行git reflog expire --expire-unreachable=now
,然后运行git prune --expire now
。即使那样,事情还是可能出错,尽管对于这个特定的简单示例来说,这可能就足够了。
长
I am writing educational material for git and I need to demonstrate git prune removing a detached commit.
git prune
所做的。它的作用可以产生这种效果,但仅在特定条件下才可以。重要的是,分离式提交在Git中不是一个定义明确的短语:Git为分离式HEAD定义了一个概念,我们稍后再讨论,但是提交本身是可到达的还是不可到达的。我认为您的意思是在这里谈论无法实现的提交。
git prune
处理的对象比提交的对象更通用。 Git有四种类型的对象:提交,树,blob和带注释的标签。只要满足其他几个条件,Git的
git prune
可以删除任何无法访问的对象。不过,在到达那里之前,让我们先看一些其他项目。
I thought I could put a commit in detached state by using
git reset
to detach it from the branch history.
git reset
,我们可以使仅通过当前分支名称可访问的提交变为不可访问。例如,如果仅通过当前分支名称(即,不能通过任何其他分支名称,也不能通过任何标签名称或其他非分支名称引用)访问
a123456...
,则可以使用
git reset
调整当前分支,以便排除
a123456...
使提交不可到达。
This will trigger
git checkout
to see the commit as detached ...
.git/HEAD
的文件,其中包含提交的原始哈希ID。当
.git/HEAD
包含分支名称时,就会发生相反的情况(我们可以称其为附加的HEAD,因为这是明显的detached的反义词)。在这两种情况下,
HEAD
都引用当前提交;当
HEAD
包含分支名称时,
HEAD
也引用当前分支名称。 Git内部处理此问题的方式是,它具有不同的功能和程序来象征性地解析
HEAD
:
$ git symbolic-ref HEAD
refs/heads/master
$ git rev-parse HEAD
c05048d43925ab8edcb36663752c2b4541911231
git symbolic-ref
会产生错误。)
git checkout
命令将HEAD附加到某些指定的分支名称:
origin/master
的远程跟踪名称)或--detach
标志强制分离的HEAD,即使它通常已附加HEAD。 git prune
相同。当我在这里说名称时,我的意思不仅仅是参考名称加上可能分离的
HEAD
,但在添加下一个复杂功能之前,我们将从这些名称开始。
refs/heads/*
)和远程跟踪名称(
refs/remotes/*
)都被约束为仅指向提交。它还没有涉及提交内部内容的详细信息,即Git如何存储文件和文件名。这是树和斑点对象进入的地方。
README.txt
或
subdir
或
file.ext
。哈希ID通常是blob对象或另一个树对象的ID:如果条目是针对像
README.txt
这样的文件,则是blob哈希,如果是针对像
subdir
这样的子树,则是子树的hash ID。 。
... <- commit a1234... <-- branchname
|
v
tree 07f39...: (100644, README.txt, 531c2...); (040000, subdir, ...)
| |
v |
blob 531c2...: data for README.txt |
|
v
tree ...: ...
refs/tags/v1.0
的标签引用,该标签引用指向带有一些哈希ID的带注释的标签对象,然后带注释的标签对象继续指向例如commit
a1234...
。这将为该提交提供另一个参考。如果我们还没有创建任何标签,则无需担心这些标签,但是它们对于完整图片很重要。
branchname
使提交
a1234...
可以访问。提交
a1234...
使树
07f39...
可以访问,从而使blob和另一个子树可以访问,依此类推。由于这些都是可以访问的,因此
git prune
绝对不会修剪它们。
HEAD
名称,都有一个可选的reflog,该引用日志存储该引用的先前值。这些保存的值将有效一段时间,直到过期。 Git用于使过期的保存值失效的命令是
git reflog expire
,它使用两个不同的命令行选项
--expire=when
和
--expire-unreachable=when
。
git prune
删除对象,则需要确保该对象完全未被引用。这意味着您将需要删除任何直接记住(提交)或间接记住(树和Blob)其哈希ID的reflog条目。这样做的简单方法(尽管具有破坏性)是使用:
git reflog expire --expire-unreachable=now --all
--expire=now
,但可以假定引用的当前值未达到reflog值,因此
--expire-unreachable
设置将适用。)
git prune
本身了。
git prune
git prune
命令处理所有四种类型的对象。它的工作是删除未引用的对象。从上面的内容中我们知道,在使用
git branch -f
或
git branch -D
或
git reset
这样的命令来确保没有分支名称也记住它之后,我们必须通过使可能会记住它的所有reflog条目过期来确保提交未被引用。
git gc
自动)将许多单独的对象打包到一个打包文件中。在这一点上,文件系统中的一个文件包含许多对象:几十个(也许是几百万个)或介于两者之间的某个对象。
prune
命令永远不会修剪打包的对象,因为这太难了。打包对象可能是其打包文件中增量压缩链的一部分。因此,
git prune
只会查看松散的对象。一个单独的程序
git repack
将重新打包对象,并将未引用的打包对象变回松散的对象(或完全丢弃它们)。
git repack
。
git prune
还会检查松散对象的时间戳。此时间戳必须足够旧,以允许
git prune
删除该对象。这样做的原因是,当Git创建新对象(包括新提交)时,它将一次将这些对象写入一个(或几个)对象到存储库数据库。 Git必须编写带有其Blob哈希值的最深子树,然后使用这些子树及其哈希值以及这些树中存在的任何Blob哈希值来编写下一层的树。一旦Git写出所有树并获得顶级树哈希以进行新的提交,则Git才可以编写提交对象。在此之前,所有这些树都是未引用的。即使提交已写入,也不会被引用,直到更新当前分支名称(或分离的
HEAD
)以指向新创建的提交。
git commit
需要14天以上才能完成,则
git prune
可能会删除其某些对象-但是14天应该是足够的时间。
git prune --expire now
关于git - git-如何为git prune创建无法访问的提交?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52582651/
我的情况是这样的......在同一个仓库工作的人已经从他的本地和远程仓库中删除了一个分支...... 大多数在 Stack Overflow 或其他网站上询问过此类问题的人都有分支问题仍然显示在他们的
我昨天运行命令 docker system prune,花了一些时间,然后我的 SSH session 因其他原因断开。 不幸的是我现在得到了: 来自守护程序的错误响应:修剪操作已在运行。 显然有一个
在阅读一本名为 Java Performance 的书时,我遇到了这个术语。你可以在这里找到它free sample pages第 6 页“少写代码” 最佳答案 根据 dictionary.com ,
有谁知道如何实现称为 PRUNING 的图像处理技术?任何想法,例子等?我正在使用 OpenCV 和 C#,如果有人可以提供帮助,我将不胜感激。 最佳答案 我假设您希望从图像中移除不需要的杂散和伪影。
我正在使用 git version 2.14.2.windows.2 并调用 git worktree add 在“正常”存储库上创建工作树。这在 创建了一个新的工作树结构对于分支并添加了 .g
我有一堆被删除的远程分支,现在我想删除本地的分支。我试过: git fetch -p 但它不起作用。 如果我这样做: git branch -r 和 git 分支 列表不一样,因为 git branc
来自手册页: Deletes all stale tracking branches under . These stale branches have already been removed fr
题目地址:https://leetcode.com/problems/binary-tree-pruning/description/ 题目描述 Weare given the head node
我需要在第一个目录中编辑提示文件,而不是在子目录中递归。 find(\&read_cue, $dir_source); sub read_cue { /\.cue$/ or return;
当我使用docker-compose build命令构建docker镜像时,我看到了一件意外的事情。 当Dockerfile仅具有一个RUN命令时 那么图像尺寸会减小。 当我们将其拆分为每个单独的RU
运行docker system prune -a之前,我的空白空间为900 MB,运行它可以为我提供 65 GB可用空间,尽管该命令报告说它仅清除了14.5 GB的 我在这里遗漏了什么报告是错误的吗?
我正在范 Derby 尔特大学独立学习 CS251。这项工作是为字符数组编写一个外观包装器并使其可调整大小。但是,有一个方法 prune() ,我不明白它应该做什么。你们能解释一下这个方法的含义吗?因
我有一个数据框,如下所示: data = [['1','tom',1,0],['1','tom',0,1],['2','lynda',0,1],['2','lynda',0,1]] df = pd.D
在我看来,我对 RX 函数有很好的“感觉”——我使用了其中的许多函数,或者可以想象其他函数如何有用——但我找不到 .Prune 函数的位置。我知道这是对 AsyncSubject 的多播,但这在实际场
谁能解释一下这两个陈述: 在成本复杂度剪枝中,剪枝后的树误差永远不会小于训练数据集上的原始树。 在成本复杂度剪枝中,剪枝后的树误差永远不会小于验证数据集上的原始树。 第一个说法正确,第二个说法错误。
根据 GNU find 的联机帮助页,默认使用 -print 操作, Actions which inhibit the default -print are -delete, -exec, -exe
我有一些 git 存储库,我想计算它们包含多少个 .txt、目录和其他文件。问题是每个存储库内都有一个 .git 目录,其中包含更多文件和配置。我不想计算我正在查找的文件夹,或 .git 目录或其包含
我想将 Eigen 用于稀疏矩阵乘法,在每次迭代中我想删除低于特定阈值的所有条目。在我看来,Eigen 只删除恰好等于零的元素。 我正在运行 Eigen 3.3.7,使用 g++ 进行编译。 #inc
我有一个字典和一个要从字典中删除的键列表。这是我现在的实现: var keys = (from entry in etimes where Convert.ToInt64(en
我正在寻找 git 版本 1.7.4 中不可用的命令,但我无法升级 git 客户端。 那么,有没有什么命令等同于 git push --prune 最佳答案 prune对于远程“删除 下的所有陈旧远
我是一名优秀的程序员,十分优秀!