我正在尝试访问远程存储库上的分支提交历史记录。我看了一下文档,但没有找到任何关于如何使用本地git客户端访问远程回购的提交历史的实质性信息。
当前回答
这对我来说很管用:
git fetch --all
git log production/master
注意,这是从所有远程获取的,也就是说,你可能“不得不克隆2GB的对象,只是为了查看提交日志”。
其他回答
您只能在本地存储库上查看日志,但是其中可以包括已设置的所有远程的提取分支。
所以,如果你克隆一个回购…
git clone git@gitserver:folder/repo.git
这将默认为origin/master。
你可以添加一个远程到这个回购,除了原点让我们添加生产。在本地克隆文件夹中:
git remote add production git@production-server:folder/repo.git
如果我们想查看生产日志,我们需要做的是:
git fetch --all
从所有的远程(默认获取没有——ALL将只从原点获取)
获取之后,我们可以查看生产远程上的日志,您还必须指定分支。
git log production/master
所有选项都将像登录本地分支一样工作。
我不确定什么时候添加了过滤,但如果你只想获取历史/ref-logs,这是一种排除对象blobs的方法:
git clone --filter=blob:none --no-checkout --single-branch --branch master git://some.repo.git .
git log
Git不是像SVN那样的集中式SCM,所以你有两个选择:
使用目标平台的web界面(如GitHub REST API或GitLab REST API) 下载存储库并在本地显示日志
对于许多不同的平台(GitHub, GitLab, BitBucket, SourceForge, Launchpad, Gogs,…)实现它可能很烦人,但获取数据非常慢(我们谈论的是秒)-没有解决方案是完美的。
一个抓取临时目录的例子:
git clone https://github.com/rust-lang/rust.git -b master --depth 3 --bare --filter=blob:none -q .
git log -n 3 --no-decorate --format=oneline
另外:
git init --bare -q
git remote add -t master origin https://github.com/rust-lang/rust.git
git fetch --depth 3 --filter=blob:none -q
git log -n 3 --no-decorate --format=oneline origin/master
这两种方法都对性能进行了优化,将一个分支的提交限制在一个没有文件内容的最小本地副本中,并且防止控制台输出。尽管打开连接并在获取过程中计算增量需要一些时间。
GitHub的一个例子:
GET https://api.github.com/repos/rust-lang/rust/commits?sha=master&per_page=3
一个GitLab的例子:
GET https://gitlab.com/api/v4/projects/inkscape%2Finkscape/repository/commits?ref_name=master&per_page=3
两者都非常快,但有不同的界面(就像每个平台一样)。
声明:选择Rust和Inkscape是因为它们的尺寸和安全性,没有广告
我不相信这是可能的。我相信你必须在本地克隆远程repo,并在它上执行git取回,然后才能对它发布git日志。
一个快速的方法是使用——bare关键字进行克隆,然后检查日志:
git clone --bare git@giturl tmpdir
cd tmpdir
git log branch
推荐文章
- RPC失败;卷度传输已关闭,剩余未完成的读取数据
- 我应该在.gitignore文件中添加Django迁移文件吗?
- 错误:您对以下文件的本地更改将被签出覆盖
- Git rebase—即使所有合并冲突都已解决,仍然会继续报错
- 在Git中,我如何知道我的当前版本是什么?
- 跟踪所有远程git分支作为本地分支
- 自定义SSH端口上的Git
- git如何显示不存在于.gitignore中的未跟踪文件
- Git错误:遇到7个文件应该是指针,但不是
- GitHub克隆与OAuth访问令牌
- 移动(或“撤销”)最后一个git提交到非暂存区域
- 我可以在GitHub上对要点进行拉请求吗?
- Hg:如何做一个像git的rebase
- 如何丢弃远程更改并将文件标记为“已解决”?
- 如何查看远程标签?