新聞中心

成都創(chuàng)新互聯(lián)10多年企業(yè)網(wǎng)站制作服務(wù);為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì)及高端網(wǎng)站定制服務(wù),企業(yè)網(wǎng)站制作及推廣,對(duì)成都活動(dòng)板房等多個(gè)行業(yè)擁有多年的營(yíng)銷(xiāo)推廣經(jīng)驗(yàn)的網(wǎng)站建設(shè)公司。
使用補(bǔ)丁文件更新源碼包,省去了用 ./configured 生成新的 Makefile 文件,還省去了大量的編譯工作,因此效率更高。學(xué)完本節(jié)會(huì)對(duì)比有更深入的理解。
Linux補(bǔ)丁文件的生成和使用
Linux 系統(tǒng)中可以使用 diff 命令對(duì)比出新舊軟件的不同,并生成補(bǔ)丁文件。
diff 命令基本格式為:
[root@localhost ~]# diff 選項(xiàng) old new
#比較old和new文件的不同
此命令中可使用如下幾個(gè)選項(xiàng):
- -a:將任何文檔當(dāng)作文本文檔處理;
- -b:忽略空格造成的不同;
- -B:忽略空白行造成的不同;
- -I:忽略大小寫(xiě)造成的不同;
- -N:當(dāng)比較兩個(gè)目錄時(shí),如果某個(gè)文件只在一個(gè)目錄中,則在另一個(gè)目錄中視作空文件;
- -r:當(dāng)比較目錄時(shí),遞歸比較子目錄;
- -u:使用同一輸出格式;
從生成補(bǔ)丁文件,到使用其實(shí)現(xiàn)更新軟件的目的,為了讓讀者清楚地了解整個(gè)過(guò)程的來(lái)龍去脈,下面我們自己創(chuàng)建兩個(gè)文件(分別模擬舊軟件和新軟件),通過(guò)對(duì)比新舊文件生成補(bǔ)丁文件,最后利用補(bǔ)丁文件更新舊文件,具體步驟如下:
- 創(chuàng)建兩個(gè)文件,執(zhí)行如下命令:
[root@localhost ~]# mkdir test
#建立測(cè)試目錄
[root@localhost ~]# cd test
#進(jìn)入測(cè)試目錄
[root@localhost test]# vi old.txt
our
school
is
lampbrother
#文件old.txt,為了便于比較,將每行分開(kāi)
[root@localhost test]# vi new.txt
our
school
is
lampbrother
in
Beijing
#文件new.txt - 利用 diff 命令,比較兩個(gè)文件(old.txt 和 new.txt)的不同,并生成補(bǔ)丁文件(txt.patch),執(zhí)行代碼如下:
[root@localhost test]# diff -Naur /root/test/old.txt /root/test/new.txt > txt. patch
#比較兩個(gè)文件的不同,同時(shí)生成txt.patch補(bǔ)丁文件
[root@localhost test]#vi txt.patch
#查看一下這個(gè)文件
--/root/test/old.txt 2012-11-23 05:51:14.347954373 +0800
#前一個(gè)文件
+ + + /root/test/new.txt 2012-11-23 05:50:05.772988210 +0800
#后一個(gè)文件
@@-2, 3+2, 5@@
school
is
lampbrother
+in
+beijing
#后一個(gè)文件比前一個(gè)文件多兩行(用+表示) - 利用補(bǔ)丁文件 txt.patch 更新 old.txt 舊文件,實(shí)現(xiàn)此步操作需利用 patch 命令,該命令基本格式如下:
[root@localhost test]# patch -pn < 補(bǔ)丁文件
#按照補(bǔ)丁文件進(jìn)行更新-pn 選項(xiàng)中,n 為數(shù)字(例如 p1、p2、p3 等),pn 表示按照補(bǔ)丁文件中的路徑,指定更新文件的位置。
這里對(duì) -pn 選項(xiàng)的使用做一下額外說(shuō)明。我們知道,補(bǔ)丁文件是要打入舊文件的,但是當(dāng)前所在目錄和補(bǔ)丁文件中記錄的目錄不一定是匹配的,需要 "-pn" 選項(xiàng)來(lái)同步兩個(gè)目錄。
例如,當(dāng)前位于 "/root/test/" 目錄下(要打補(bǔ)丁的舊文件就在當(dāng)前目錄下),補(bǔ)丁文件中記錄的文件目錄為 "/root/test/dd.txt",如果寫(xiě)入 "-p1"(在補(bǔ)丁文件目錄中取消一級(jí)目錄),那么補(bǔ)丁文件會(huì)打入 "root/test/root/test/old.txt" 文件中,這顯然是不對(duì)的;如果寫(xiě)入的是 "-p2"(在補(bǔ)丁文件目錄中取消二級(jí)目錄),補(bǔ)丁文件會(huì)打入 "/root/test/test/old.txt" 文件中,這顯然也不對(duì)。如果寫(xiě)入的是 "-p3"(在補(bǔ)丁文件目錄中取消三級(jí)目錄),補(bǔ)丁文件會(huì)打入 "/root/test/old.txt" 文件中,old.txt 文件就在這個(gè)目錄下,所以應(yīng)該用 "-p3" 選項(xiàng)。
如果當(dāng)前所在目錄是 "/root/" 目錄呢?因?yàn)檠a(bǔ)丁文件中記錄的文件目錄為 "/root/test/old.txt",所以這里就應(yīng)該用 "-p2" 選項(xiàng)(代表取消兩級(jí)目錄),補(bǔ)丁打在當(dāng)前目錄下的 "test/old.txt" 文件上。
因此,-pn 選項(xiàng)可以這樣理解,即想要在補(bǔ)丁文件中所記錄的目錄中取消幾個(gè) "/",n 就是幾。去掉目錄的目的是和當(dāng)前所在目錄匹配。
現(xiàn)在更新 "old.txt" 文件,命令如下:
[root@localhost test]# patch -p3 < txt.patch
patching file old.txt
#給old.txt文件打補(bǔ)丁
[root@localhost test]# cat old.txt
#查看一下dd.txt文件的內(nèi)容
our
school
is
lampbrother
in
Beijing
#多出了in Beijing兩行可以看到,通過(guò)使用補(bǔ)丁文件 txt.patch 對(duì)舊文件進(jìn)行更新,使得舊文件和新文件完全相同。
通過(guò)這個(gè)例子,大家要明白以下兩點(diǎn):
- 給舊文件打補(bǔ)丁依賴的不是新文件,而是補(bǔ)丁文件,所以即使新文件被刪除也沒(méi)有關(guān)系。
- 補(bǔ)丁文件中記錄的目錄和當(dāng)前所在目錄需要通過(guò) "-pn" 選項(xiàng)實(shí)現(xiàn)同步,否則更新可能失敗。
給apache打入補(bǔ)丁
本節(jié)仍以 apache 為例,通過(guò)從官網(wǎng)上下載的補(bǔ)丁文件 "mod_proxy_ftp_CVE-2008-2939.diff",更新 httpd-2.2.9 版本的 apache。
這里使用的補(bǔ)丁文件,修補(bǔ)了 apache 代理 FTP 站點(diǎn)時(shí),模塊空指針引用拒絕服務(wù)攻擊的漏洞(了解即可,不用深究)。
具體更新步驟如下:
- 從 apache 官網(wǎng)上下載補(bǔ)丁文件;
- 復(fù)制補(bǔ)丁文件到 apache 源碼包解壓目錄中,執(zhí)行命令如下:
[root@localhost ~]# cp mod_proxy_ftp_CVE-2008-2939.diff httpd-2.2.9
- 給舊 apache 打入補(bǔ)丁,具體執(zhí)行命令如下:
[root@localhost ~]# cd httpd-2.2.9
#進(jìn)入apache源碼目錄
[root@localhost httpd-2.2.9]# vi mod_proxy_ftp_CVE-2008-2939.diff
#查看補(bǔ)丁文件
--modules/proxy/mod_proxy_ftp.c (Revision 682869)
+ + + modules/proxy/mod_proxy_ftp.c (Revision 682870)
…省略部分輸出…
#查看一下補(bǔ)丁文件中記錄的目錄,以便一會(huì)兒和當(dāng)前所在目錄同步
[root@localhost httpd-2.2.9]# patch - p0 < mod_proxy_ftp_CVE-2008-2939.diff
#打入補(bǔ)丁為什么是 "-p0" 呢?因?yàn)楫?dāng)前在 "/root/httpd-2.2.9" 目錄中,但補(bǔ)丁文件中記錄的目錄是 "modules/proxy/mod_proxy_ftp.c",就在當(dāng)前所在目錄中,因此一個(gè) "/" 都不需要去掉,所以是 "-p0"。
- 重新編譯 apache 源碼包,執(zhí)行如下命令:
[root@localhost httpd-2.2.9]# make
- 安裝 apache,執(zhí)行如下命令:
[root@localhost httpd-2.2.9]# make install
通過(guò)對(duì)比《Linux源碼包安裝和卸載》一節(jié)中安裝源碼包的過(guò)程,不難發(fā)現(xiàn),打補(bǔ)丁更新軟件的過(guò)程比安裝軟件少了 "./configure" 步驟,且編譯時(shí)也只是編譯變化的位置,編譯速度更快。
注意,如果未安裝過(guò) httpd-2.2.9,就需要先打入補(bǔ)丁,再依次執(zhí)行 "./configure"、"make"、
"make install" 命令。
patch 命令不僅可以給就文件打入補(bǔ)丁,還可以執(zhí)行反操作,即恢復(fù)用補(bǔ)丁文件修改過(guò)的源文件,例如:
[root@localhost httpd-2.2.9]# patch -R < modjDroxy_ftp_CVE-2008-2939.diff
-R(大寫(xiě))選項(xiàng)表示還原補(bǔ)丁。
文章題目:Linux源碼包快速升級(jí)方法詳解
網(wǎng)站鏈接:http://m.5511xx.com/article/dppghjj.html


咨詢
建站咨詢
