源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

用git打更新包的办法分享

  • 时间:2020-09-11 13:10 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:用git打更新包的办法分享
[b]前言[/b] 相信很多人都有过这种经历,当修改了一堆bug后,要更新代码到服务器上,此时,最简单的方式是将项目文件全部上传一次,这种方式可行,但不可取。为什么?你懂的! 其实可以直接在服务器用[code]git pull[/code]代码的方式来更新代码,但如果遇到你的服务器是linux服务器并且不带UI界面的,除非你命令行指令及git很熟悉,要不然遇到代码冲突还是比较麻烦的,小编这方面的水平有限。当然也有其他原因,不推荐此方式更新。 [b]下面,小编为大家介绍下利用git来打更新包。[/b] [b]打包原理:[/b] 利用[code]git archive[/code]输出两个提交间的改变 [img]http://files.jb51.net/file_images/article/201608/2016828152621943.jpg?2016728152632[/img] [code]NEW_COMMIT_ID_HERE[/code] 较新的提交ID [code]OLD_COMMIT_ID_HERE[/code] 较旧的提交ID(以此作为更新打包起始点) [img]http://files.jb51.net/file_images/article/201608/2016828152755331.jpg?201672815284[/img] [img]http://files.jb51.net/file_images/article/201608/2016828152835451.jpg?2016728152846[/img] 现在我有两次提交(commit) 第一次提交的ID为438eac0,提交了一个文件 第二次提交的ID为4d5baf6,提交了三个文件 [b]然后按照上面打包指令:[/b]
git archive -o update.zip 4d5baf6 $(git diff –name-only 438eac0 4d5baf6)
执行一下指令,会发现目录中多了一个update.zip压缩文件 [img]http://files.jb51.net/file_images/article/201608/2016828152932281.jpg?2016728152940[/img] 小编解压文件看一下有什么内容 [img]http://files.jb51.net/file_images/article/201608/2016828153054576.jpg?201672815315[/img] 是小编第二个提交的文件及目录,这说明了[code]OLD_COMMIT_ID_HERE[/code]仅作为打包的起始点,但并不包含[code]OLD_COMMIT_ID_HERE[/code]提交的内容。 当然[code]NEW_COMMIT_ID_HERE [/code]和[code]OLD_COMMIT_ID_HERE[/code]之间可以间隔多个[code]COMMIT[/code]的,这样就会打多个[code]COMMIT[/code]的内容打包到一个压缩包内。 最后,只要解压出来的内容通过FTP工具上传到服务器即可。 [b]总结[/b] 上面展示的内容只是单一的代码更新,实际的更新可能还会涉及多个方面的,例如数据库脚本、配置文件等,小编在此文章中就不作过多的讨论。有兴趣的同学可以百度或者GOOGLE。 [b]结束语[/b] 谢谢各位的阅读,希望本文的内容对大家的学习和工作能带来帮助。如果有疑问可以留言讨论,谢谢大家对编程素材网的支持。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部