启萌分享

技术分享,利用git来打更新包

2016-08-29  本文已影响0人  启萌分享

作为一枚程序猿,相信很多人都有过小萌同学的经历,当修改了一堆bug后,要更新代码到服务器上,此时,最简单的方式是将项目文件全部上传一次,这种方式可行,但不可取。为什么?你懂的!

本文章标题提到git,是一款免费、开源的分布式版本控制系统,想信很多人也用过或者接触过.小萌同学以前用过svn,但后来接触到git,果断放弃svn,拥抱git.

其实可以直接在服务器用git pull代码的方式来更新代码,但如果遇到你的服务器是linux服务器并且不带UI界面的,除非你命令行指令及git很熟悉,要不然遇到代码冲突还是比较麻烦的,小萌同学这方面的水平有限。当然也有其他原因,不推荐此方式更新。

下面,小萌同学为大家介绍下利用git来来打更新包。

打包原理:

利用git archive输出两个提交间的改变

NEW_COMMIT_ID_HERE 较新的提交

IDOLD_COMMIT_ID_HERE 较旧的提交ID(以此作为更新打包起始点)

现在我有两次提交(commit)

第一次提交的ID为438eac0,提交了一个文件

第二次提交的ID为4d5baf6,提交了三个文件

然后按照上面打包指令:

git archive -o update.zip 4d5baf6 $(git diff --name-only 438eac0 4d5baf6)

执行一下指令,会发现目录中多了一个update.zip压缩文件

小萌同学解压文件看一下有什么内容

是小萌同学第二个提交的文件及目录,这说明了OLD_COMMIT_ID_HERE仅作为打包的起始点,但并不包含OLD_COMMIT_ID_HERE提交的内容。

当然NEW_COMMIT_ID_HERE 和OLD_COMMIT_ID_HERE之间可以间隔多个COMMIT的,这样就会打多个COMMIT的内容打包到一个压缩包内。

最后,只要解压出来的内容通过FTP工具上传到服务器即可。

上面展示的内容只是单一的代码更新,实际的更新可能还会涉及多个方面的,例如数据库脚本、配置文件等,小萌同学在此文章中就不作过多的讨论。有兴趣的同学可以百度或者GOOGLE。

谢谢各位的阅读,希望能跟大家多交流,小萌想学习更多知识。

作者:头条号 / 启萌分享

链接:http://toutiao.com/i6323519704526750209/

来源:头条号(今日头条旗下创作平台)

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

上一篇 下一篇

猜你喜欢

热点阅读