diff制作补丁文件的原理:告诉我们怎么修改第一个文件后能得到第二个文件。

diff命令常用选项:

-u 输出统一内容的头部信息(打补丁使用),计算机知道是哪个文件需要修改    -r 递归对比目录中的所有资源(可以对比目录)

-a 所有文件视为文本(包括二进制程序)      -N 无文件视为空文件(空文件怎么变成第二个文件)

patch  -pnum(其中num为数字,指定删除补丁文件中多少层路径前缀)

如原始路径为/u/howard/src/blurfl/blurfl.c

-p0则整个路径不变     -p1则修改路径为u/howard/src/blurfl/blurfl.c     -p4则修改路径为blurfl/blurfl.c

-R(reverse)反向修复    -E修复后如果文件为空,则删除该文件

patch对单文件代码打补丁

[root@proxy ~]# cd demo

[root@proxy demo]# vim test1.sh    //v1版本脚本

#!/bin/bash

echo "hello world"

echo "test"

[root@proxy demo]# vim test2.sh   //v2版本脚本

#!/bin/bash

echo "hello the world"

echo "test file"

[root@proxy demo]# diff -u test1.sh test2.sh > test.patch   //diff生成补丁文件

[root@proxy demo]# yum -y install patch       //安装patch软件包

[root@proxy demo]# patch -p0 < test.patch                    //在代码相同目录下为代码打补丁

patching file test1.sh

[root@proxy demo]# patch -RE < test.patch                     //还原旧版本,反向修复

patch对目录下的所有代码打补丁

[root@proxy ~]# mkdir demo

[root@proxy ~]# cd demo

[root@proxy demo]# mkdir {source1,source2}

[root@proxy demo]# echo "hello world"  > source1/test.sh     //source1目录及文件

[root@proxy demo]# cp /bin/find  source1/

[root@proxy demo]#  tree source1/                        //source1目录下2个文件

|-- find

`-- test.sh

[root@proxy demo]# echo "hello the world"  > source2/test.sh    //source2目录及文件

[root@proxy demo]# echo "test" > source2/tmp.txt

[root@proxy demo]# cp /bin/find  source2/

[root@proxy demo]# echo "1" >> source2/find

[root@proxy demo]#  tree source2/                        //source1目录下3个文件

|-- find

|-- test.sh

`-- tmp.txt

[root@proxy demo]# diff -Nuar source1/ source2/ > source.patch   //生成补丁

[root@proxy demo]# ls

source1  source2  source.patch

[root@proxy demo]# cat source.patch                //对比的文件有路径信息

--- source1/test.sh 2018-02-07 22:51:33.034879417 +0800

+++ source2/test.sh 2018-02-07 22:47:32.531754268 +0800

@@ -1 +1 @@

-hello world

+hello the world

[root@proxy demo]# cd source1

[root@proxy source1]# patch  -p1 < ../source.patch

十一、diff和patch打补丁的更多相关文章

  1. diff和patch 打补丁

    在Linux环境下,有两个工具用来给project打补丁,即diff和patch diff         diff具有比较功能.可以使用man命令查看其使用方法. NAME        diff ...

  2. [daily] 使用diff和patch打补丁

    diff org new > xxx.patch patch /path/org xxx.patch /path/org是相对路径时, 会报错. 这是一个bug.

  3. diff生成补丁与patch打补丁

    1.使用diff生成补丁: diff是Linux下的文件比较命令,参数这里就不说了,直接man一下就行了,不仅可以比较文件,也可以比较两个目录,并且可以将不同之处生成补丁文件,其实就是一种打补丁的命令 ...

  4. patch 打补丁,和diff 生成制作补丁

    一.diff 命令: diff命令就是比较两个文件的差异,然后生成差异文件,即补丁文件. 参数:diff --help获得,最常用的 1.-N --new-file 在比较时,如果没有就拿一个空的文件 ...

  5. git apply、git am打补丁.diff 和 .patch【转】

    本文转载自:https://www.jianshu.com/p/e5d801b936b6 前提: 生成patch: git format-patch -M master 生成指定patch,0163b ...

  6. diff和patch的使用、patch文件的格式解说

    为了弄懂 patch中的 p0   p1    和.orig文件是啥,找到了这篇文章! 来源:http://www.cnblogs.com/super119/archive/2010/12/18/19 ...

  7. 【转】Linux下patch打补丁命令

    [转]Linux下patch打补丁命令 转自:http://www.cnblogs.com/noaming1900/archive/2010/10/28/1863282.html 此命令用于为特定软件 ...

  8. Linux下patch打补丁命令

    此命令用于为特定软件包打补丁,他使用diff命令对源文件进行操作. 基本命令语法: patch [-R] {-p(n)} [--dry-run] < patch_file_name p:为pat ...

  9. 关于 diff 和patch

    参考: https://blog.csdn.net/zygblock/article/details/53384862 diff和patch是 版本控制 git 的不可缺少的工具 diff 是用来比较 ...

随机推荐

  1. Web 服务器安全

    目录 Apache Apache出现过的漏洞 Tomcat Tomcat出现过的漏洞 Nginx

  2. VS Code插件推荐-Settings Sync

    Settings Sync功能 将vscode的本地设置.插件保存至远端,方便保存 Usage 插件市场安装Setting Sync之后,⌘+P输入>sync,即可看到相关操作,选中点击之后官方 ...

  3. MongonDb在thinkphp中常用的功能整理

    1.以某字段开头的数据查询条件 $title = input('param.title'); $where['title'] = new \MongoDB\BSON\Regex("^{$ti ...

  4. VMware-viclient-all

    VMware-viclient-all https://my.vmware.com/web/vmware/details?productId=491&downloadGroup=ESXI60U ...

  5. 三、多线程之Thread与Runnable的区别

    Thread与Runnable的区别(用三个窗口同时出售10张车票为例子) 运行代码 运行结果 分析 System.out.println("开始测试多线程");class MyT ...

  6. ACM、考研、就业,在我心底已经有了明确的答案_人生没有完整的,只有无悔的

    思绪再三,还是决定放弃了ACM,走上考研路(我现在是大二下学期,马上结束).虽然我们ACM的带队老师经常说:"ACM和考研是不冲突的",但是我感觉做ACM和考研的关系不是很紧密,而 ...

  7. Junit单元测试&反射&注解

    内容索引 1. Junit单元测试 2. 反射 3. 注解 Junit单元测试: * 测试分类: 1. 黑盒测试:不需要写代码,给输入值,看程序是否能够输出期望的值. 2. 白盒测试:需要写代码的.关 ...

  8. MSSQL·CLI执行T-SQL

    阅文时长 | 0.44分钟 字数统计 | 480.8字符 主要内容 | 1.引言&背景 2.详细步骤&排坑指南 3.中途执行异常处理方式 4.声明与参考资料 『MSSQL·CLI执行T ...

  9. [Java] Structs

    背景 基于MVC的WEB框架 在表示层过滤访问请求并处理 步骤 在eclipse中创建Web动态项目 导入相关jar包到WEB-INF/lib 在WEB-INF目录下新建web.xml,配置Filte ...

  10. KVM 添加新硬件

    1 显卡 spice 2视频 qxl驱动 3 声音 ich6最好  ich9最清楚 4 输入 鼠标 智能图   否则不能VNC找不到焦点 5 磁盘大小 至少80G 否则 无法自动安装  无swap和 ...