git pull --prune --tags
时间: 2024-05-13 15:12:11 浏览: 186
`git pull --prune --tags`是一个Git命令,用于更新远程存储库的本地版本并拉取所有未拉取的标签,并删除所有已删除的远程分支。
其中`--prune`选项用于删除本地版本库中已经不存在的远程分支。 `--tags`选项用于拉取所有未拉取的标签。 如果您的远程存储库有新的标签,将使用此选项将所有未拉取的标签复制到本地版本库中,否则将不拉取标签。
范例[](https://git-scm.com/docs/git-pull):
```shell
$ git pull --prune --tags
```
相关问题
git清空commit
### 清空 Git 仓库的提交历史
为了将 Git 仓库的提交历史重置到初始状态,可以采用以下方法之一:
#### 方法一:创建新的孤儿分支并删除旧的历史记录
通过创建一个新的孤立分支来清除所有的提交历史。这会使得新分支没有任何祖先节点。
```bash
git checkout --orphan new-branch-name
git rm -rf .
```
此时处于一个全新的工作目录下,所有文件都被标记为已删除但尚未提交。接着可以根据需求添加或初始化项目文件再做首次提交[^1]。
#### 方法二:利用过滤命令移除特定范围内的提交信息
如果希望保留某些早期提交而只清理后期不必要的更改,则可考虑使用 `filter` 命令族中的工具如 BFG Repo-Cleaner 或者原生的 `git filter-repo`(较新版Git支持) / `git filter-branch`(不推荐用于复杂场景)[^3]。
对于简单情况可以直接执行如下操作以彻底抹去除了第一次提交外的所有变更:
```bash
git replace --graft $(git rev-list --max-parents=0 HEAD)^! HEAD
git filter-branch -- --all
```
注意上述指令可能会破坏现有标签和其他引用关系,在实际应用前建议先备份整个仓库副本以防万一。
#### 方法三:克隆仅含单次提交的新裸库
当不需要保存任何原有数据时最直接的办法是从当前HEAD重新建立仅有一次commit的新repo.
```bash
git init empty_repo
cd empty_repo/
git pull old_repo_url main_branch_name --no-tags
# 这里假设main_branch_name是你想要拉取的主要分支名称
rm -fr .git/refs/original/
git reflog expire --expire=now --all
git gc --prune=now --aggressive
```
以上三种方式各有优劣,具体选择取决于个人需求以及对风险承受能力的不同考量。无论采取哪种方案都强烈建议事先做好充分准备与测试验证[^2]。
阅读全文