使用git在两台机器间同步代码

Posted elloop

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用git在两台机器间同步代码相关的知识,希望对你有一定的参考价值。

前言

本文记录了如何使用git来在两台机器间同步代码,一台机器是linux,另一台是windows。

需求描述

有一份代码放在linux机器A上,我需要在另一台机器B上查看并编辑它,为了方便两台机器之间相互同步修改后的代码,git相比于scp等手动操作的好处:

1. 自动检查到修改的文件,不要自己去找改了那些文件

2. 附带版本管理功能

3. 便于扩展:有了第三台或更多机器的话,自己clone一份即可

步骤

1. 在存放原始代码的机器上,比如A,假设代码目录为:/codes/project,

cd /codes/project

# 创建git代码仓库
git init
git add .
git commit -m "create project"

# 切换到project父目录,创建一个project-bare目录
cd ..
mkdir project-bare
cd project-bare

# 从原始代码仓库创建bare仓库,作为“中央”仓库,其他机器(包括本机的原始仓库)往这里push,从这里pull
git clone --bare ../project ./project-bare.git

# 回到project仓库目录
cd ../project

# 把project-bare添加为remote,
git remote add origin ../project-bare.git
git branch --set-upstream-to=origin/master master

2. 在其它机器上,比如B:

假设通过ssh来连接机器A

git clone ssh://<username>@<ip>:<port>:/codes/project-bare/project-bare.git ./project

clone下来之后,在机器B上做修改,然后commit,push之后,在机器A上就可以pull到了。反之在机器A的project目录做修改,commit,push之后,在机器B上也能pull下来了。

若要再添加一台开发机,重复第2步,clone操作即可。

遇到的坑

注意第1步中创建 project-bare.gti 的必要性

如果B直接clone A上的project仓库,并且将其添加为remote,那么在执行git push操作的时候是会报错的,因为此时B不知道A是否也在对工作副本进行了修改,直接push过去可能造成working copy的冲突,而创建的project-bare仓库只记录仓库信息不保存working copy,作为一个中央仓库使用,详情参考bare仓库和non-bare仓库的区别这篇文章


作者水平有限,对相关知识的理解和总结难免有错误,还望给予指正,非常感谢!

在这里也能看到这篇文章:github博客, CSDN博客, 欢迎访问

以上是关于使用git在两台机器间同步代码的主要内容,如果未能解决你的问题,请参考以下文章

使用git在两台机器间同步代码

如何使用 git 作为云存储在两台不同的机器上工作?

php网站部署两套代码在两台服务器上面,如何做到上传文件同步

onenote如何在两台电脑之间同步

使用 Multipeer Connectivity 在两台设备之间同步计时器?

禁用 git EOL 转换