内容简介:为了提高自己远程办公的效率,花了不到一天的时间,开发了一个代码同步工具,来同步多个远程服务器之间的代码。地址:最近由于肺炎疫情大家都在远程办公,我平时的开发工具其实就是
为了提高自己远程办公的效率,花了不到一天的时间,开发了一个代码同步工具,来同步多个远程服务器之间的代码。
针对场景
最近由于肺炎疫情大家都在远程办公,我平时的开发 工具 其实就是 终端 + PyCharm 。
终端连接服务器运行命令,然后通过PyCharm的同步工具把代码实时的上传到服务器上,大概就是这样的:
然而,服务器都是内网的,在家连到服务器上就需要通过配置代理,如果不在实验室,那么如果我连接到 服务器1 ,那就要多经历2-3次ssh。比如说termnial的话我就要多用两次ssh。
不过对于termnial的话,我可以在自己的云服务器上开一个tmux,这样其实和在实验室操作没有区别。
但是对于代码编辑,因为我个人还是不习惯用vim,所以如果用PyCharm,那么我就要多两次scp,这显然不是我想要的。
为什么要造轮子
翻阅github,我找到了一款这样的工具: github.com/serkanyerse…
但这款工具经过我的使用我发现这其实是一款本地工具,并不适用于这种网络延迟高的场景,如果在我这种场景使用,我发现上传的大部分文件的大小都是0。
因为在网络中传输一个1M的文件,可能都要几秒钟,所以在这个几秒钟内,会一直触发文件被写这个事件。所以可能就会不停的上传。
另外对于网络文件的传输,首先要创建一个空文件,然后再对空文件去写,这两个时间间隔很短。
// create destination file
dstFile, err := sftpClient.Create(remotepath)
if err != nil {
log.Fatal(err)
}
defer dstFile.Close()
// create source file
srcFile, err := os.Open(localpath)
if err != nil {
log.Fatal(err)
}
// copy source file to destination file
_, err = io.Copy(dstFile, srcFile)
if err != nil {
log.Fatal(err)
}
复制代码
像上面这款工具,可能只接收到一个文件创建信号,就去创建了个新的文件,但其实后面还跟着一个写操作。如果网络速度还可以,没到这个软件的最短响应时间,这个写操作可能就会被忽视掉。
所以相对于本地到远程服务器的同步工具,在远程服务器之间的同步工具我增加了以下两点:
-
- 增加一些延迟,防止文件多次被写入。
-
- 对每一次的文件修改,如果文件大小大于一定程度(比如说20KB),需要不断判断文件是否正在被写入,需要等待文件被写入完成再上传。
使用方法
下载安装
这里因为我使用的是 go 语言,直接下载编译好的结果即可。然后加到path里面。
wget https://github.com/nladuo/sync-go/releases/download/1.0/sync-go chmod +x sync-go mv sync-go /usr/local/bin/ 复制代码
这里只提供linux-64位的编译结果,因为这个肯定是在 linux 之间用的,32位的服务器现在也应该很少了。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- WakaTime数据同步展示工具
- 环境篇:数据同步工具DataX
- Syncthing 1.4.0 发布,续文件同步工具
- Syncthing 1.4.1 发布,连续文件同步工具
- Syncthing 1.4.2 发布,连续文件同步工具
- Syncthing 1.5.0 发布,连续文件同步工具
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
MySQL入门很简单
黄缙华 / 清华大学出版社 / 2011-1 / 59.50元
《MySQL入门很简单》从初学者的角度出发,由浅入深,循序渐进地介绍了mysql数据库应用与开发的相关知识。书中提供了大量操作mysql数据库的示例,还提供了大量实例和上机实践内容,供读者演练。《MySQL入门很简单》附带1张dvd光盘,内容为与《MySQL入门很简单》内容完全配套的多媒体教学视频和《MySQL入门很简单》涉及的源代码。 《MySQL入门很简单》共分5篇。第1篇介绍数据库的基......一起来看看 《MySQL入门很简单》 这本书的介绍吧!