repo start时遇到Project not found: …

参考文档:https://gerrit-review.googlesource.com/Documentation/error-project-not-found.html

```
如果推送到的 git 存储库在 Gerrit 服务器中不作为项目存在,或者推送用户对此项目没有读取权限,则出现此错误消息时,Gerrit 拒绝推送提交。

Gerrit 中的项目名称与其 git 存储库的路径名称相同(不包括“.git”扩展名)。

如果您遇到此问题,请执行以下操作:

1、验证push命令中指定为git repository的项目名称是否输入正确(区分大小写)。
2. 验证您正在推送到正确的 Gerrit 服务器。
3. 在 Gerrit Web UI 中转到“项目”>“列表”并检查项目是否已列出。如果该项目未列出,则该项目要么不存在,要么您没有 ['Read'](https://gerrit-review.googlesource.com/Documentation/access-control.html#category_read) 访问权限。这意味着如果您确定项目名称是正确的,您应该联系 Gerrit 管理员或项目所有者以请求访问该项目。

如果项目确实存在但推送失败,则此错误消息可能会产生误导,因为推送用户没有项目的读取权限。在这种情况下,Gerrit 拒绝项目存在的原因是为了防止用户探测 Gerrit 服务器以查看特定项目是否存在。
```

### 获取指定间段的 Git Tags 而不克隆项目 为了实现这一目标,可以通过 `git ls-remote` 和其他辅助工具来完成。以下是具体方法: #### 使用 `git ls-remote` 列出远程仓库中的标签 `git ls-remote` 是一种轻量级的方式,可以直接访问远程仓库而无需克隆整个项目。它能够列出所有的引用(包括 tags 和 branches)。通过过滤这些引用,可以找到特定间范围内的标签。 ```bash git ls-remote --tags <repository-url> ``` 此命令会返回所有标签及其对应的哈希值[^1]。然而,默认情况下,这不会提供间戳信息。因此需要进一步处理以筛选出符合条件的间段。 #### 结合 `git log` 查看标签创建间 由于 `git ls-remote` 无法直接获取标签的间戳,需借助 `git log` 来查看每个标签的具体日期。为此,可以选择先拉取部分数据再分析。 ##### 步骤说明 1. **提取标签列表** 首先运行上述 `git ls-remote` 命令并将结果保存到本地文件中以便后续解析。 2. **逐个查询标签详情** 对于每一个感兴趣的标签,执行如下命令以获得其确切的提交间和作者信息: ```bash git show-ref --dereference | grep refs/tags/<tag-name>^{} | cut -d' ' -f1 | xargs git log -n 1 --pretty=format:"%ai %H" ``` 上述脚本的作用是从标准输入读取标签名称并打印对应的历史记录条目,其中包含完整的 ISO8601 间格式字符串以及关联的 commit hash[^3]。 3. **自动化脚本编写** 编写一个简单的 shell 或 Python 脚本来遍历所有可能匹配的目标 tag 并判断它们是否落在给定区间之内。 下面是一个基于 Bash 的例子演示如何实现这一点: ```bash #!/bin/bash REPO_URL="https://github.com/example/repo.git" start_date="$1" end_date="$2" # Fetch all available remote tags. all_tags=$(git ls-remote --tags "$REPO_URL") while read -r line; do ref_name=$(echo "$line" | awk '{print $2}') # Extract actual tag name from full reference path. tag=${ref_name##*/} # Get the timestamp of this particular tag's associated commit object. commit_hash=$(git rev-parse --verify "${ref_name}^{commit}") if [[ $? != 0 ]]; then continue ; fi creation_time=$(git log -1 --format=%at "$commit_hash") formatted_time=$(date -u --date=@"$creation_time" "+%Y-%m-%d") if (( start_date <= formatted_time && formatted_time <= end_date ));then echo "Found matching tag '$tag', created on ${formatted_time}." fi done <<<"$all_tags" ``` 注意:以上代码片段假设用户已经安装 GNU Coreutils 版本的 date 工具,并且支持 @epoch 秒数作为参数形式转换成可读日志表示法;如果不是 Linux 系统,则可能需要调整相应的调用方式或者改用 Perl/Python 实现相同功能逻辑[^4]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值