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

源码网商城

linux patch 命令小结(收藏)

  • 时间:2021-09-18 06:15 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:linux patch 命令小结(收藏)
说到patch命令,就不得不提到diff命令,也就是制作patch的必要工具。diff命令,在制作patch文件的时候,[b]基本上只需要使用到[/b][b]diff -Nau 这个参数,如果比较的是文件夹,还要加上-r参数,所以一般直接使用Naur参数。[/b] 实验的基本步骤。我打算是建立一个级联目录./x/xx/xxx/,在xxx目录下建立两个不同的文件xxx1,xxx2。然后在xxx目录下用diff命令,建立一个补丁文件xxx.patch,在xx目录下建立一个补丁文件xx.patch,在x目录下建立一个补丁文件x.patch。然后在这三个目录下实验。 开始实验:建立实验目录 [King@Fedora ~]$ mkdir -p[b]v[/b] x/xx/xxx mkdir: 已创建目录 “x” mkdir: 已创建目录 “x/xx” mkdir: 已创建目录 “x/xx/xxx” 进入xxx目录下创建xxx1,xxx2 [King@Fedora ~]$ cd x/xx/xxx [King@Fedora xxx]$[b]cat >> xxx1 << EOF [/b]> 111111 > 111111 > EOF [King@Fedora xxx]$ cat >> xxx2 << EOF > 111111 > 222222 > EOF 查看这两个文件 [King@Fedora xxx]$[b] diff -y xxx1 xxx2 [/b]111111                                111111 111111                           |    222222 [b]一定要注意:打补丁时所在的目录 [/b] 在xxx目录下创建补丁文件xxx.patch,并查看。 [King@Fedora xxx]$[b]diff -Naru xxx1 xxx2 > xxx.patch [/b][King@Fedora xxx]$ cat xxx.patch [b]- - - xxx1    2009-12-19 22:28:26.582959182 +0800 +++ xxx2    2009-12-19 22:28:42.798928591 +0800 @@ -1,2 +1,2 @@   111111 - 111111 +222222[/b] 在xx目录下创建补丁文件xx.patch,并查看 [King@Fedora xxx]$ cd .. [King@Fedora xx]$ diff -Naru xxx/xxx1 xxx/xxx2 > xx.patch [King@Fedora xx]$ cat xx.patch --- xxx/xxx1    2009-12-19 22:28:26.582959182 +0800 +++ xxx/xxx2    2009-12-19 22:28:42.798928591 +0800 @@ -1,2 +1,2 @@ 111111 -111111 +222222 在x目录下创建补丁文件x.patch,并查看 [King@Fedora xx]$ cd .. [King@Fedora x]$ diff -Nu xx/xxx/xxx1 xx/xxx/xxx2 > x.patch [King@Fedora x]$ cat x.patch --- xx/xxx/xxx1    2009-12-19 22:28:26.582959182 +0800 +++ xx/xxx/xxx2    2009-12-19 22:28:42.798928591 +0800 @@ -1,2 +1,2 @@ 111111 -111111 +222222 [b]现将patch文件都拷贝到xxx目录下去。 [/b] [King@Fedora x]$ cp x.patch xx/xxx/ [King@Fedora x]$ cp xx/xx.patch xx/xxx/ 进入xxx目录开始实验 [King@Fedora x]$ cd xx/xxx [King@Fedora xxx]$ ls x.patch  xx.patch  xxx1  xxx2  xxx.patch [King@Fedora[b]xxx[/b]]$[b]patch-p0<xxx.patch  #用第二个的 补丁 修改 第一个文件 [/b]patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 222222 [King@Fedora xxx]$[b]patch -RE < xxx.patch #用第一个的 补丁 修改 第一个文件 [/b]patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 111111 [King@Fedora xxx]$[b]patch -p1 < xx.patch [/b]patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 222222 [King@Fedora xxx]$ patch -RE < xxx.patch patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 111111 [King@Fedora xxx]$[b]patch -p2 < x.patch [/b]patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 222222 [King@Fedora xxx]$ patch -RE < x.patch patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 111111 -------------------- [King@Fedora[b]xx[/b]]$[b]patch-p0< xx.patch  # 用第二个的 补丁 修改 第一个文件 [/b]patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 222222 [King@Fedora xxx]$[b]patch -RE < xxx.patch #用第一个的 补丁 修改 第一个文件 [/b]patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 111111 [King@Fedora xxx]$[b]patch -p1 < x.patch [/b]patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 222222 [King@Fedora xxx]$ patch -RE < xxx.patch patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 111111 ---------------------------------- [King@Fedora[b]x[/b]]$[b]patch-p0<x.patch  # 用第二个的 补丁 修改 第一个文件 [/b]patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 222222 [King@Fedora xxx]$[b]patch -RE < xxx.patch #用第一个的 补丁 修改 第一个文件 [/b]patching file xxx1 [King@Fedora xxx]$ cat xxx1 111111 111111 [b]这里唯一需要说明的是p0的含义,因为在x.patch补丁文件里的路径信息是这样的:[/b][b] --- xx/xxx/xxx1    [/b] [b]p表示跳过几级目录,因为是在x目录下使用的patch命令,xx目录就在x目录下,所以不必跳过任何目录,而应该使用--- xx/xxx/xxx1   完整路径,所以此时使用的是p0。[/b] 注意:[b]patch -p后面是不能带负数 的[/b]。[b]不使用[/b][b]p参数的时候,patch命令会 忽略 任何目录[/b],[b]直接使用文件[/b]。 [King@Fedora[b]x[/b]]$[b]patch x/xx/xxx/xxx1< x.patch  # 用补丁x.patch 直接修改 文件xxx1,因为没有用p参数,所以 会 忽略掉补丁文件里的 所有目录。 [/b] 作为程序员,了解diff&patch命令是非常必要的。比如说我们发现某个项目有bug代码,而自己又没有提交权限,那么此时最合适的解决方法就是用diff命令做一个补丁发给项目成员。项目成员通过patch命令可以立刻知道你的意图。有人会说直接传一个新文件不是更简单?不要忘了,[b]一个[/b][b]patch文件尺寸更小传输更快[/b],而且可以明显的看到都做了哪些修改。 [b]保证当前目录是demo名录:[/b] # mkdir demo # cd demo 先模拟一个项目目录old: # mkdir -p old/a/b # vi old/a/b/foo.txt old_line_1 old_line_2 假设我们发现项目old有bug代码,下面我们先拷贝一个新目录new,并在此修改bug代码: # cp -r old new # vi new/a/b/foo.txt new_line_1 new_line_2 保证old和new两个目录都在当前目录下,下面就可以使用diff命令了,[b]不要使用绝对路径,而应该使用相对路径[/b],至于原因,看到文章结尾你就清楚了: # LC_ALL=C TZ=UTC0 diff -Naur old new > foo.patch 如果不在意字符集,时差等问题,也可以省略LC_ALL=C TZ=UTC0环境变量: #[b]diff -Naur old new > foo.patch [/b] 内容来自Linuxren.net 其中-Naur参数属于固定用法,大多数时候,在使用diff命令时搭配这个参数就可以了。 大概浏览一下补丁文件: # cat foo.patch diff -Naur old/a/b/foo.txt new/a/b/foo.txt --- old/a/b/foo.txt     2009-12-07 20:40:07.000000000 +0800 +++ new/a/b/foo.txt     2009-12-07 20:41:51.000000000 +0800 @@ -1,2 +1,2 @@ -old_line_1 -old_line_2 +new_line_1 +new_line_2 加减号后面的内容是有用的内容,其他的内容是方便你查阅的相关信息内容,补丁制作完成。 此时的文件目录结构大概如下所示: #tree demo |-- old |   `-- a |       `-- b |           `-- foo.txt |-- new |   `-- a |       `-- b |           `-- foo.txt -- foo.patch 下面看看如何使用patch来应用补丁,[b]要注意的是当前目录是[/b][b]demo[/b],试试下面命令: # patch -p0 < foo.patch patching file old/a/b/foo.txt 这里唯一需要说明的是p0的含义,因为在foo.patch补丁文件里的路径信息是这样的: --- old/a/b/foo.txt p表示跳过几级目录,因为是在demo目录下使用的patch命令,old目录就在demo目录下,所以不必跳过任何目录,而应该使用old/a/b/foo.txt完整路径,所以此时使用的是p0。 查看一下目标文件,你会发现内容已经修改成新的了: # cat old/a/b/foo.txt new_line_1 new_line_2 此时[b]如果你再次使用[/b][b]patch命令,[/b][b]系统会问你是否想还原,输入[/b][b]y 还原[/b]: # patch -p0 < foo.patch patching file old/a/b/foo.txt Reversed (or previously applied) patch detected!  Assume -R? [n][b] y[/b] 查看一下目标文件,你会发现内容已经还原成旧的了: # cat old/a/b/foo.txt old_line_1 old_line_2 如果你想严格指定是[b] 应用补丁[/b] 可以使用下面命令(就是增加N参数): # patch -Np0 < foo.patch 如果你想严格指定是[b]还原补丁[/b] 可以使用下面命令([b]就是增加[/b][b]R参数[/b]): # patch -Rp0 < foo.patch 注释:在本例中,每次应用补丁后,自己还原补丁,以备后用继续试验,我就不多说了。 看到这里如果你对patch的p参数还不太清楚的话,接着往下看,我们改变一下当前路径: # cd old 此时就应该是p1,而不是p0了,引用foo.patch文件的路径也要相对变一下,因为当前目录已经是old了: Linuxren.net # patch -p1 < ../foo.patch patching file a/b/foo.txt 因为[b]此时我们是在[/b][b]old下使用patch命令[/b],和a子目录平级,而补丁文件foo.patch里的路径声明是: --- old/a/b/foo.txt [b]也就是说第一个斜线左边的old/部分已经没用了,这就是p1的含义! [/b] 继续往深度变换路径,依次测试使用p2,p3参数: # cd a # patch -p2 < ../../foo.patch patching file b/foo.txt # cd b # patch -p3 < ../../../foo.patch patching file foo.txt 在本例中,p3已经是最深目录了,此时可以省略p参数: # patch < ../../../foo.patch patching file foo.txt 也就是说,[b]不使用[/b][b]p参数的时候,patch命令会 忽略 任何目录[/b],[b]直接使用文件[/b]。 下面接着文章前面说的为什么使用diff命令时最好不要使用绝对路径,而应该使用相对路径? 答:如果你在使用diff的时候使用的是绝对路径,那么补丁文件里的文件路径信息会类似下面的样子: --- /a/b/c/d/e/f/g/bar.txt 如此一来,当别人想应用你的补丁时,因为目录结构肯定有差异,所以就不得不费力判断到底使用p几。这样一来就很容易出错,相反,如果使用相对路径的话,大多数时候,p0或者p1就足够了,不易出错。 以上所述是小编给大家介绍的linux patch 命令小结,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程素材网网站的支持!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部