1. 程式人生 > >linux打patch的方法

linux打patch的方法

作為程式設計師,瞭解diff&patch命 令是非常必要的。比如說我們發現某個專案有bug程式碼,而自己又沒有svn的提交許可權,那麼此時最合適的解決方法就是用diff命令做一個補丁發給專案成 員。專案成員通過patch命令可以立刻知道你的意圖。有人會說直接傳一個新檔案不是更簡單?不要忘了,一個patch檔案尺寸更小傳輸更快,而且可以明 顯的看到都做了哪些修改。

保證當前目錄是demo名錄:

# 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命令了,不要使用絕對路徑,而應該使用相對路徑,至於原因,看到文章結尾你就清楚了:

# LC_ALL=C TZ=UTC0 diff -Naur old new > foo.patch

如果不在意字符集,時差等問題,也可以省略LC_ALL=C TZ=UTC0環境變數:

# diff -Naur old new > foo.patch

其中-Naur引數屬於固定打法,不管是對一個檔案,還是對一個目錄,在使用這個引數基本就可以了。

大概瀏覽一下補丁檔案:

# 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來應用補丁,要注意的是當前目錄是demo,試試下面命令:

# 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

此時如果你再次使用patch命令,系統會問你是否想還原:

# patch -p0 < foo.patch
patching file old/a/b/foo.txt
Reversed (or previously applied) patch detected! Assume -R? [n] y

檢視一下目標檔案,你會發現內容已經還原成舊的了:

# cat old/a/b/foo.txt
old_line_1
old_line_2

如果你想嚴格指定是應用補丁可以使用下面命令(就是增加N引數):

# patch -Np0 < foo.patch

如果你想嚴格指定是還原補丁可以使用下面命令(就是增加R引數):

# patch -Rp0 < foo.patch

註釋:在本例中,每次應用補丁後,自己還原補丁,以備後用繼續試驗,我就不多說了。

看到這裡如果你對patch的p引數還不太清楚的話,接著往下看,我們改變一下當前路徑:

# cd old

此時就應該是p1,而不是p0了,引用foo.patch檔案的路徑也要相對變一下,因為當前目錄已經是old了:

# patch -p1 < ../foo.patch
patching file a/b/foo.txt

因為此時我們是在old下使用patch命令,和a子目錄平級,而補丁檔案foo.patch裡的路徑宣告是:

--- old/a/b/foo.txt

也就是說第一個斜線左邊的old/部分已經沒用了,這就是p1的含義!

繼續往深度變換路徑,依次測試使用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

也就是說,不使用p引數的時候,patch命令會忽略任何目錄,直接使用檔案。

下面接著文章前面說的為什麼使用diff命令時最好不要使用絕對路徑,而應該使用相對路徑?

答:如果你在使用diff的時候使用的是絕對路徑,那麼補丁檔案裡的檔案路徑資訊會類似下面的樣子:

--- /a/b/c/d/e/f/g/bar.txt

如此一來,當別人想應用你的補丁時,因為目錄結構肯定有差異,所以就不得不費力判斷到底使用p幾。這樣一來就很容易出錯,相反,如果使用相對路徑的話,大多數時候,p0或者p1就足夠了,不易出錯。

跟著本文的步驟操作一下,肯定能掌握diff&patch用法,基本上使用diff時就是"diff -Naur FROM TO"(FROM, TO為變數)這樣的固定打法,然後在使用patch的時候,先看看補丁檔案的大致內容,結合當前目錄以確定需要跳過的目錄數,然後套用"patch -pN < patch.file"(N為變數)即可。

-------------------
  總結一下:

  單個檔案

  diff –uN from-file to-file >to-file.patch

  patch –p0 < to-file.patch

  patch –RE –p0 < to-file.patch

  多個檔案


  diff –uNr from-docu to-docu >to-docu.patch

  patch –p1 < to-docu.patch

  patch –R –p1

  -------------------

應用

  為核心打補丁。前面在建立交叉編譯工具鏈時,其中有一步就是為核心打補丁。當時還不是特別瞭解,現在很清晰了。參考前面的文章《基於ARM+Linux嵌入式開發的開發工具鏈的建立》。


  1、首先是解壓,因為釋出的補丁檔案都是使用gzip壓縮的。

  $gunzip ../setup-dir/ patch-2.4.21-rmk1.gz

  2、然後進入你的核心原始碼目錄

  $cd linux-2.4.21

  3、打補丁

  $patch –p1 < ../../setup-dir/patch-2.4.21-rmk1

  打完補丁後,需要檢查一下有沒有拒絕執行的檔案,即檢查.rej檔案的存在。使用命令:

  $find . -name *.rej

  如果發現,會將其輸出到標準輸出終端,預設螢幕。當然,你也可以採用重定向,輸出到指定檔案,比如reject。

  $fine . -name *.rej >reject

  然後可以檢視reject的內容了。

相關推薦

linuxpatch方法

作為程式設計師,瞭解diff&patch命 令是非常必要的。比如說我們發現某個專案有bug程式碼,而自己又沒有svn的提交許可權,那麼此時最合適的解決方法就是用diff命令做一個補丁發給專案成 員。專案成員通過patch命令可以立刻知道你的意圖。有人會說直接傳一個新

openwrt PATCH方法

http://wiki.openwrt.org/doc/devel/patches 全來官網 package目錄打法 Adding a new patch 1>make package/example/{clean,prepare} V=s QUILT=1 make

git am PATCH_FILE_NAME自動patch失敗後的操作方法

操作方法 reverse git 信息 合並 沖突 失敗 根據 操作 1.找到打入patch不成功的patch 從打入patch的失敗信息可以找到 2.根據patch的index重新打入 patch,將可以合並的內容合並,沖突的部分單獨生成文件 比如出問題patch的ind

linux下生成patchpatch

1 patch 的生成 使用diff指令生成補丁檔案 1.1 單個檔案的生成指令 diff -up 檔案1 檔案2 > patch_test.patch 引數解釋: u: 顯示有差異行的前後幾行(上下文), 預設是前後各3行 p: 顯示程式碼所在的c函式的資訊 1.2 兩個資料夾的生成指令

linux 核心原始碼 patch

一、下載當前Linux核心對應的增量包 https://www.kernel.org/   我的核心當前版本是 4.9.135 最新的版本是4.9.145,中間有10個增量版本,需要全部下載,增量包不支援跨版本,只能從相鄰的版本打patch 增量包下載地址示例:

LinuxPatch補丁的生成與補丁命令

之前在公司做專案的時候用到了在linux打補丁的技術(呵呵,其實也不是什麼技術說大了就是一條命令),感覺這個還是挺有用的,因為很多原廠都是給出原始碼基礎或是他們修改基礎上的補丁包都我們,讓我們自己打上去來更新一些程式碼的功能的。 一、打補丁最需要注意有以下兩點: 1、要打補

在ORACLE11g下patch方法

OPatch介紹 補丁包是一個可以拷貝的檔案的集合,他們是基於特定的oracle產品版本的。當在特性版本的oracle產品中應用了新的patch後,這個產品就升級到了一個新的版本。 Opatch是一個基於java的工具,它可以進行補丁的應用和臨時補丁的回滾。Opatch是平

IntentFilter方法

_id pre net .net content log intent 方法 方式 轉載請註明出處:http://blog.csdn.net/droyon 在我們進行Android應用程序開發時。我們有時須要對某個對象進行打印輸出。以方便我們進行調試。 非常多對象實現了

mysql 忘記了root的password(linux下解決方法,window同理)

.cn rac oot 命令行 linu size word sta ont mysql 忘記了root的password的時候的解決步驟, 1: cd /etc/mysql/(進入mysql的配置文件夾) 2:vim my.cnf \skip-grant-t

Linux分區方法

linux分區1.1 linux分區方法1.1.1 通用分區方法一,數據不是很重要分區大小說明/boot200M存放內核及系統的引導信息/swap物理內存<8G,SWAP 物理內存1.5倍物理內存>8G,SWAP 給8G交換分區(虛擬內存),防止內存用光掛掉,內存快使用完時使用/剩余所有空間存放所

Windows之Xmanager連接linux開Oracle視圖操作

技術分享 content 雙擊 登錄名 www. gpm 一行 () esp 前提:安裝Xmanager 能夠百度Xmanager下載其破解版或者帶註冊機的版本號,也能夠官網下載。只是須要秘鑰(建議下載企業版) 官網下載地址:http

Linux系統學習方法——寫給小白

linux每個人都有心中向往的一些事情,而我,剛進實驗室,看到師兄師姐在電腦前面劈裏啪啦的敲代碼,真的好羨慕,看著他們實現一個又一個的功能滿心歡喜,我也很想嘗試。後來了解到師兄師姐是在學習Linux,於是我就開始了我的Linux學習之路。 開始的我真的一點頭緒都沒有,真的是萬事開頭難。向師兄師姐請教了

Swift 自定義方法

orm rom -m http mat cti nbsp 使用 span Swift 自定義打印方法 #代碼如下 // MARK:- 自定義打印方法 func MLLog<T>(_ message : T, file : String = #file, fun

zabbix監控Linux進程方法

zabbix zabbix監控服務利用zabbix proc.num方法監控Linux服務進程proc.num[<name>,<user>,<state>,<cmdline>]監控用戶某些狀態的進程的數量name - 進程名稱 (默認“all processes

Linux開TCP BBR擁塞控制算法

efault echo def ont linux linu modules span log 要求內核為4.9以上,如果不是,請升級內核. modprobe tcp_bbr echo "tcp_bbr" >> /etc/modules-load.d/mo

如何開啟mysql5.5的客戶端服務 命令行方法

get 每次 htm d3d div alt 服務 erl services MySQL分為兩個部分,服務器端和客戶端,只有服務器端的服務開啟後,才可以通過客戶端登錄到MySQL數據庫。這裏介紹如何用命令行方式開啟mysql的客戶端服務。 在計算機上安裝好mysql軟

linux I2C_client產生方法

就會 client setup evm sta 總線 reg array bsp \arch\arm\mach-omap2/board-am335xevm.c static struct i2c_board_info am335x_i2c2_boardinfo[] = {

【安全牛學習筆記】Kali Linux滲透測試方法

信息安全 kali linux security+ 1.安全問題的根源①由於分層思想,導致每個層次的相關人員都只關心自己層次的工作,因此每個人認識系統都是片面的,而安全是全方位的,整體的,所以造成安全問題。②技術人員追求效率,導致只追求功能實現,而很容易忽略安全性的工作③由於人都是會犯錯誤的,因此

windows文件復制到linux亂碼 -解決方法

windows文件復制到linux亂碼從linux往 windows拷貝文件或者從windows往Linux拷貝文件,有時會出現中文文件名亂碼的情況,出現這種問題的原因是因為,windows的文件名 中文編碼默認為GBK,而Linux中默認文件名編碼為UTF8,由於編碼不一致,所以導致了文件名亂碼的問題,解決

linux 開FTP 功能

mon file shutdown 賬號 退出 str accept iptable 使用 http://blog.csdn.net/jay285979220/article/details/62216622 今天在linux上安裝完了vsftpd後,使用ro