『无欲则无求』Linux软件包管理 — 47、Linux源码包的补丁(了解即可)

在以前的软件源码包,需要打补丁的时候比较多。现在的源码包很少进行打补丁了,因为根据需求安装不同的版本即可,比较商业化了。

从开发者的角度,补丁就是软件新版本和现有版本的不同。这个不同包括缺少的文件和修改的内容。

1、补丁的生成

#比较old和new文件的不同
[root@localhost ~] # diff 选项 old new 

选项:
-a:将任何文档当做文本文档处理。
-b:忽略空格造成的不同。
-B:忽略空白行造成的不同。
-I:忽略大小写造成的不同。
-N:当比较两个目录时,如果某个文件只在一个目录中,则在另一个目录中视作空文件。
-r:当比较目录时,递归比较子目录。
-u:使用统一的输出格式。

常用的选项为-N、-a、-u、-r

举例

#建立测试目录
[root@localhost ~ ] # mkdir test

#进入测试目录
[root@localhost ~ ] # cd test

#文件old txt,为了一会输出便于比较,每行分开
[root@localhost test] # vi old.txt 
our 
school

#文件new.txt
[root@localhost test] # vi new.txt 
our 
school 
in 
Beijing

比较下两个文件的不同,并生成补丁文件"txt.patch",命令如下:

#比较两个文件的不同,同时生成txt.patch补丁文件
[root@localhost test] # diff -Naur /root/test/old.txt /root/test/new.txt > txt.patch
注意:
-Naur是常用选项,是用的时候直接用。
两个文件一定要使用绝对路径。
最后的文件名不需要绝对路径。

#查看下这个文件
[root@localhost test] # vi txt.patch

#前一个文件,减号代表少内容的文件
---/root/test/old.txt 2012-11-23 05:51:14.347954373 +0800
#后一个文件,加号代表多内容的文件
+++/root/test/new.txt 2012-11-23 05:50:05.772988210 +0800

#后一个文件比前一个文件多两行(+表示)
@@ -2,3 + 2,5 @@
our 
school 
+in
+beijing

2、打入补丁

#按照补丁文件进行更新
[root@localhost test ] # patch -pn <补丁文件

选项:
-pn:n为数字。代表按照补丁文件中的路径,指定更新文件的位置。

可以看到上面打入补丁的命令中,没有写需要打补丁的是哪个文件。因为在补丁文件中都有记录,新文件和旧文件的位置。如下图:
在这里插入图片描述

-pn不好理解,我们说明下。

  • 补丁文件是要打入旧文件的,但是你当前所在的目录和补丁文件中的记录的目录是不一定匹配的,所以就需要"-pn"来同步两个目录的位置。(也就是说补丁文件中记录的旧文件目录,会追加到当前目录上。p几就是消除补丁文件中旧文件目录的几级目录。)
  • 比如我当前是在/root/test目录中(我要打补丁的旧文件就在当前目录下),补丁文件中记录的文件目录为/root/test/old.txt,这时如果写入-p1(在补丁文件目录中取消一级目录)
  • 那么补丁文件就会打入/root/test/root/test/old.txt文件中,这显然是不对的。那如果写入的是-p2(在补丁文件目录中取消二级目录)那么补丁文件打入的就是/root/test/test/o1d.txt,这显然也不对。如果写入的是-p3(在补丁文件目录中取消三级目录)那么补丁文件就是打入的
    /root/test/old.txt,我们的old.txt文件就在这个目录下,所以就应该是-p3

那么我们更新下"old.txt"文件,命令如下:

#给old.txt文件打补丁
[root@localhost test] # patch -p3 < txt.patch 
patching file old.txt(patch文件已经打入到old.txt文件中)

#查看下old.txt的内容吧。多出来了in Beiiing两行
[root@localhost test ] # cat old.txt
our 
school 
in 
Beijing
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章