zoukankan      html  css  js  c++  java
  • 关于线上静态页面资源更新的一些经验分享

    关于线上静态页面资源更新的一些经验分享

    最近在负责公司的后台项目,包括了后端和前端。后端直接编译完打成jar包直接上线运行没什么问题。但是前端的页面文件更新每次都要把页面给运维,然后告诉运维路径让运维挨个替换,当然也可以整包替换,
    但是如果文件比较多的情况下,整包替换就不合适了。因为现在开发的项目版本控制基本必不可少了,这时候可以利用版本控制软件来生成Patch文件,然后直接交给运维,让运维在项目根目录打补丁就行。

    关于Linux的Patch

    如果熟悉linux的话对patch命令肯定不陌生,linux很多软件代码的更新都用的是patch,相较于重新下载整份源码,patch文件体积小只需要更新改动的地方。patch本身和diff经常一起用的,具体的用法我就不详细介绍了,网上已经说明很多了。这里用来更新页面的思路其实和linux中的思想是一样的。
    常用的的格式:

        patch -d /root/amqp -p0 -E  </root/amqp/0001-.patch
    

    -d 指明了patch的工作目录,此处指源码的根目录。
    -pN中的N表示忽略路径中的第几层。如patch文件中路径为a/src/main/java/spittr/chen/AlertServiceImpl.java,如果需要忽略前面的a目录就需要指明-p1
    -E表示如果文件更新之后为空则删除这个文件。
    -R表示反向,回滚更新
    -b用于备份改动的文件,用于重要的操作

    关于git

    git作为最流行的版本控制软件也实现了diff和patch的功能,git导出patch有两种方式,git diff和git format-patch 。git diff用于生成通用的patch格式,而format-patch用于生成git专用的patch文件。不过我经过测试,两种生成的文件都是和linux的patch命令兼容的,也就是说两种生成的文件都可以直接使用patch命令来打补丁。不过这里有一个需要的需要注意的地方就是,git生成的patch文件中,在指明影响的文件路径时,默认原来的文件前面会加上路径a/,而改动后的文件前面会加上路径b/(我查看了git官网文档也有提及,但是不清楚为什么要默认这么写,如果有知道的希望能告知下),如下所示:

    diff --git a/src/main/java/spittr/chen/AlertServiceImpl.java b/src/main/java/spittr/chen/AlertServiceImpl.java
    new file mode 100644
    index 0000000..7c8ebd1
    --- /dev/null
    +++ b/src/main/java/spittr/chen/AlertServiceImpl.java
    

    所以在linux中使用的时候需要指明参数-p1来忽略第一层路径,或者在使用git diff命令时加上参数--no-prefix

    其实git本身也有对应于linux patch的命令apply,还有更为强大的am。但是要求是必须是git项目。如果使用的git项目,推荐使用git的命令尤其是am命令,他必须使用format-patch生成的文件,format-patch文件携带了提交的记录包括作者,提交注释,日期等等,信息和pull差不多。关于这两个命令网上有很多的教程这里不再说明。对于我这个需求。已经因为线上的页面文件一般是文件夹的形式存在,所以使用linux的patch即可满足需求。

    关于Idea

    如果你用的开发工具是Idea的话,idea可以很方便的生成patch文件。如下图:

    在版本的控制的log标签页,选中自己需要生成补丁的提交记录右键即可生成patch文件。

  • 相关阅读:
    JS模拟出 getElementsByClassName 功能
    如何为PDF文件添加书签
    Linux内核模块学习
    Linux字符设备驱动学习
    第53篇编译线程的初始化
    第51篇SharedRuntime::generate_native_wrapper()生成编译入口
    第50篇调用约定(2)
    第52篇即时编译器
    2021 阿里云容器服务年度盘点:企业级容器应用变化和技术趋势观察
    如何在零停机的情况下迁移 Kubernetes 集群
  • 原文地址:https://www.cnblogs.com/chenfangzhi/p/9665538.html
Copyright © 2011-2022 走看看