这里是新手。是否有方法同步两个存储库,使当前签出的文件成为所有更改的最新版本?
我所拥有的是:
Desktop Server
------- ------
Change_X Change_Y我想输入一些“魔术”命令,然后这些更改被合并。
Desktop Server
------- ------
Change_X Change_X
Change_Y Change_Y问题之一是桌面是NAT后面的Windows机器,我想避免在上面设置sshd。基本上,我想使用ssh从桌面到服务器进行所有操作。
这似乎与git无关,但我想不出怎么做。
(我原以为git push会做到这一点,但事实证明它不会对当前签出的分支进行更改,因此从桌面到服务器的更改不会发生)
有没有办法用git来做这件事,还是我偏离了轨道?
解决方案:I从这里下载了更新后脚本,并将其放在服务器上的钩子目录中,现在git push使服务器通过更改进行更新。因此,“魔术命令”基本上决定:
git pull server:scripts/ master
git push server:scripts/(scripts是我正在同步的文件夹)
发布于 2009-02-08 12:00:05
应该可以创建一个post提交钩子,它将在更改时更新服务器的工作副本(我对mercurial做了完全相同的操作,所以我假设git也是可能的)。因此,推送后,工作副本将自动更新。
创建将运行git up或git的任何等效命令的post提交钩子。
对不起,我不知道还能说什么。
upd:在官方git常见问题中有一些解释。
发布于 2009-02-08 12:28:05
问题之一是桌面是NAT后面的Windows机器,我想避免在上面设置sshd。基本上,我想使用ssh从桌面到服务器进行所有操作。
不是直接回答您的问题,但是如果您在NAT后面,则更容易的做法是使用Putty或其他工具运行反向SSH隧道,而不是sshd服务器。
ssh -R3333:127.0.0.1:9418 <user>@<server>现在,连接到<server>的端口3333将被转发到您的NAT机器的git端口。
https://stackoverflow.com/questions/525576
复制相似问题