您的位置:首页 > 运维架构 > Linux

如何创建和使用Linux中的patch

2015-06-04 17:48 447 查看
diff 选项:

-u 以统一格式创建补丁文件,这种格式比缺省格式更紧凑些。

-N 确保补丁文件将正确地处理已经创建或删除文件的情况。

-r 递归比较命令行上所给出的两个目录的所有子目录中的所有文件。

-a 比较二制文件

patch文件的结构

补丁头

补丁头是分别由---/+++开头的两行,用来表示要打补丁的文件。

一个补丁文件中的多个补丁

一个补丁文件中可能包含以---/+++开头的很多节,每一节用来打一个补丁。所以在一个补丁文件中可以包含好多个补丁。



块是补丁中要修改的地方。它通常由一部分不用修改的东西开始和结束。他们只是用来表示要修改的位置。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头。

块的缩进

块会缩进一列,而这一列是用来表示这一行是要增加还是要删除的。

块的第一列

+号表示这一行是要加上的。

-号表示这一行是要删除的。

没有加号也没有减号表示这里只是引用的而不需要修改。

创建补丁文件

diff -Naur 旧的目录 新的目录 > patch文件

或者

diff -Naur 旧的文件 新的文件 > patch文件

对于目录层数的一些限制

在创建patch的时候文件夹的层数应当是一样的,比如

--- old/modules/pcitableMon Sep 27 11:03:56 1999

+++ new/modules/pcitableTue Dec 19 20:05:41 2000

这样是可以的。



--- old/try1/other/modules/pcitableMon Sep 27 11:03:56 1999

+++ new/modules/pcitableTue Dec 19 20:05:41 2000

这样做可能会有一些问题。

如何使用patch

对于一个patch文件,使用方法:

1.cat new-patch | patch -p0

2.patch -p0 < new-patch

patch命令里面的层数(-p0?-p1?)

参数-p来指定从第几层开始比较。比如有一个patch文件的补丁头是这样的:

--- old/modules/pcitableMon Sep 27 11:03:56 1999

+++ new/modules/pcitableTue Dec 19 20:05:41 2000

如果使用参数-p0,就表示从当前目录,找一个叫作new的目录,在它下面找一个叫modules的目录,再在它下面找一个叫pcitableMon的目录。

如果使用参数-p1,就表示忽略第一层,从当前目录找一个叫modules的目录,在它下面找一个叫modules的目录。这样会忽略掉补丁头提到的new目录。

依此类推。

patch文件的结构

补丁头

补丁头是分别由---/+++开头的两行,用来表示要打补丁的文件。

一个补丁文件中的多个补丁

一个补丁文件中可能包含以---/+++开头的很多节,每一节用来打一个补丁。所以在一个补丁文件中可以包含好多个补丁。



块是补丁中要修改的地方。它通常由一部分不用修改的东西开始和结束。他们只是用来表示要修改的位置。他们通常以@@开始,结束于另一个块的开始或者一个新的补丁头。

块的缩进

块会缩进一列,而这一列是用来表示这一行是要增加还是要删除的。

块的第一列

+号表示这一行是要加上的。

-号表示这一行是要删除的。

没有加号也没有减号表示这里只是引用的而不需要修改。

一个patch的例子

diff -u old/modules/pcitable new/modules/pcitable

--- old/modules/pcitableMon Sep 27 11:03:56 1999

+++ new/modules/pcitableTue Dec 19 20:05:41 2000

@@ -1,4 +1,6 @@

0x0e110xae10"cpqarray""Compaq|Smart-2/P RAID Controller"

+0x10000x0010"cpqarray""Compaq|Integrated Array Controller"

+0x10110x0046"cpqarray""Compaq|Smart-2/P RAID Controller"

0x0e110xae32"tlan""Compaq|Netelligent 10/100"

0x0e110xae34"tlan""Compaq|Netelligent 10"

0x0e110xae35"tlan""Compaq|Integrated NetFlex-3/P"

@@ -21,6 +23,7 @@

0x10000x000f"ncr53c8xx""Symbios|53c875"

0x10000x0012"ncr53c8xx""Symbios|53c895a"

0x10000x008f"ncr53c8xx""Symbios|53c875J"

+0x10000x000a"sym53c8xx""Symbios|53c1510"

0x10000x0701"yellowfin""Symbios|83C885 gigabit ethernet"

0x10000x0702"yellowfin""Symbios|Yellowfin G-NIC gigabit ethernet"

0x10110x0001"tulip""DEC|DECchip 21050"

--- old/usr/share/kudzu/pcitableSun Sep 26 17:11:23 1999

+++ new/usr/share/kudzu/pcitableTue Dec 19 20:05:41 2000

@@ -15,6 +15,8 @@

0x0e110x3034"unknown""Compaq|QVision 1280/p"

0x0e110x4000"unknown""Compaq|4000 [Triflex]"

0x0e110xa0f3"ignore""Compaq|Triflex PCI to ISA Bridge"

+0x10000x0010"cpqarray""Compaq|Integrated Array Controller"

+0x10110x0046"cpqarray""Compaq|Smart-2/P RAID Controller"

0x0e110xae10"cpqarray""Compaq|Smart-2/P RAID Controller"

0x0e110xae29"unknown""Compaq|MIS-L"

0x0e110xae2a"unknown""Compaq|MPC"

@@ -46,6 +48,7 @@

0x10000x000f"ncr53c8xx""Symbios|53c875"

0x10000x0012"ncr53c8xx""Symbios|53c895a"

0x10000x008f"ncr53c8xx""Symbios|53c875J"

+0x10000x000a"sym53c8xx""Symbios|53c1510"

0x10000x0701"yellowfin""Symbios|83C885 gigabit ethernet"

0x10000x0702"yellowfin""Symbios|Yellowfin G-NIC gigabit ethernet"

0x10000x0901"unknown""Symbios|61C102"

分析

这个例子是由命令

diff -u old/modules/pcitable new/modules/pcitable

创建的。不过最好是用命令diff -Naur来代替diff -u。

它修改了两个文件,new/modules/pcitable和new/usr/share/kudzu/pcitable。

第一个补丁头包含两个块,分别增加了两行和一行。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: