Linux下一个patch补丁命令
基本命令语法:
patch [-R] {-p(n)} [--dry-run] < patch_file_name
p:为path的缩写。
n:指将patch文件里的path第n条’/’及其左边部分取消。
-R:卸载patch包。
--dry-run:尝试patch软件。并不真正改动软件。
使用实例:
/home/sense/patch-2.6.19.1
=============================================================
diff --git a/arch/i386/kernel/acpi/boot.c b/arch/i386/kernel/acpi/boot.c
index d12fb97..c8f96cf 100644
--- a/arch/i386/kernel/acpi/boot.c
+++ b/arch/i386/kernel/acpi/boot.c
@@ -333,7 +333,7 @@ acpi_parse_ioapic(acpi_table_entry_heade
/*
* Parse Interrupt Source Override for the ACPI SCI
*/
-static void acpi_sci_ioapic_setup(u32 bus_irq, u32 gsi, u16 polarity, u16 trigger)
+static void acpi_sci_ioapic_setup(u32 gsi, u16 polarity, u16 trigger)
=============================================================
此patch文件的path=a/arch/i386/kernel/acpi
[sense@ssn src]$ pwd
/usr/src
[sense@ssn src]$ tree
.
`-- a
`-- arch
`-- i386
`-- kernel
`-- acpi
和a/同文件夹时:
[sense@ssn src]$ pwd
/usr/src
[sense@ssn src]$ patch -p0 < /home/sense/patch-2.6.19.1 安装补丁
[sense@ssn src]$ patch -p0 -R < /home/sense/patch-2.6.19.1 卸载补丁
和a/arch/同文件夹时:
[sense@ssn src]$ pwd
/usr/src/a/
[sense@ssn src]$ patch -p1 < /home/sense/patch-2.6.19.1 安装补丁
[sense@ssn src]$ patch -p1 -R < /home/sense/patch-2.6.19.1 卸载补丁
和a/arch/i386/同文件夹时:
[sense@ssn src]$ pwd
/usr/src/a/arch/
[sense@ssn src]$ patch -p2 < /home/sense/patch-2.6.19.1 安装补丁
[sense@ssn src]$ patch -p2 -R < /home/sense/patch-2.6.19.1 卸载补丁
比方说我们发现某个项目有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几。
这样一来就非常easy出错,相反。假设使用相对路径的话。大多数时候。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的内容了。
Linux下一个patch补丁命令的更多相关文章
- Linux 下一个很棒的命令行工具
导读 Taskwarrior 是 Ubuntu/Linux 下一个简单而直接的基于命令行的 TODO 工具.这个开源软件是我曾用过的最简单的基于命令行的工具之一.Taskwarrior 可以帮助你更好 ...
- VMware Linux下拖拽补丁vmtools的安装和卸载
Linux下拖拽补丁vmtools的安装和卸载 by:授客 QQ:1033553122 Vmware 8.0.4为例子 步骤1.VM->Install Vmware Tools... 步骤2.查 ...
- linux下如何使用sftp命令【转】
linux下如何使用sftp命令 from: http://www.cnblogs.com/chen1987lei/archive/2010/11/26/1888391.html sftp 是一个 ...
- linux下一个有意思的问题(文件名以短划线或空格开头)
linux下一个有意思的问题(文件名以短划线开头) 这本是无意中的一个发现. 在linux下,文件名中含有 - 是没有问题,但是如果文件名是以-作为第一个字符的,那么就比较麻烦了. 问题演示 看这里, ...
- linux下mysql操作的命令
最近在学习mysql,还是只菜鸟,找到下面篇文章对初学者挺有用的,所以共享下 1.linux下启动mysql的命令: mysqladmin start /ect/init.d/mysql star ...
- Linux下su与su -命令的区别
在启动服务器ntpd服务时遇到一个问题 使用 su root 切换到root用户后,不可以使用service命令: 使用 su - 后,就可以使用service命令了. 原因: su命令和su -命令 ...
- Linux下一个简单的日志系统的设计及其C代码实现
1.概述 在大型软件系统中,为了监测软件运行状况及排查软件故障,一般都会要求软件程序在运行的过程中产生日志文件.在日志文件中存放程序流程中的一些重要信息, 包括:变量名称及其值.消息结构定义.函数返回 ...
- Memcahce(MC)系列(两)Linux下一个Memcache安装
Linux下一个memcache安装 memcache是高性能.分布式的内存对象缓存系统,用于在动态应用中降低数据库负载.提升訪问速度.眼下用memcache解决互联网上的大用户读取是很流行的一种使用 ...
- linux下一个Oracle11g RAC建立(五岁以下儿童)
linux下一个Oracle11g RAC建立(五岁以下儿童) 四.建立主机之间的信任关系(node1.node2) 建立节点之间oracle .grid 用户之间的信任(通过ssh 建立公钥和私钥) ...
随机推荐
- hdu5172(线段树)
传送门:GTY's gay friends 题意:判断区间[l,r]内的数字是否符合1~len(r-l+1)的一个全排列. 分析:pos[i]记录数字i出现的最大位置,pre[i]记录在位置i的数字a ...
- poj 2586 Y2K Accounting Bug(贪心算法,水题一枚)
#include <iostream> using namespace std; /*248K 32MS*/ int main() { int s,d; while(cin>> ...
- Note for video Machine Learning and Data Mining——Linear Model
Here is the note for lecture three. the linear model Linear model is a basic and important model in ...
- dedecms 获取描述信息限制字数
对于我刚刚刚开始对于获取到了描述的信息,但是有些字数简直是太多了,显示的样式不好看,所以我就希望限制字数,所以我来告诉你们获取描述信息限制字数的语法吧[field:description functi ...
- SE 2014 年4月21日(一)
如图配置 网络中存在四个自治系统,设备之间要求建立BGP对等体关系,发布BGP路由,使得全网BGP路由相互通讯. 要求 1. 由于AS 200中的路由信息频繁抖动,所以AS 100 和 AS 300 ...
- Django写的投票系统4(转)
原文地址:http://www.cnblogs.com/djangochina/archive/2013/06/04/3114269.html 现在已经可以在后台管理投票了,现在就差怎么在前台显示和如 ...
- 使用GraceNote Web API发展Mac发现音乐信息的应用
好久没有写博客,最近各种忙,特别忙里忙,今晚难得清闲.写最近完成下一个博客任务的摘要:使用GraceNote的Web API开发一个查询的音乐信息的应用,事实上,并在这些功能的前GraceNote S ...
- C#语言基础原理及优缺点
一.原理: C#是专门为.net程序框架而创造的语言. .net框架有ms的.netFramework:Mono的.NetFramework(也是符合.net IL语言,CTS规范,CLS规范, CL ...
- 共同发展一个以上的开发者账户多台电脑 证书 p12 型材 进出口
1:导出相应的开发人员证书的配置文件. 2:依据相应的app id 创建配置文件. 3:打开钥匙串,把你的公布证书导出p12文件. 4:用开发人员账号导出developerprofile文件. 5:把 ...
- Oracle历史记录
请问如何查询ORACLE的历史操作记录!!!!!------解决方案-------------------- 有一个专门存储操作的数据库表..select t.SQL_TEXT, t.FIRST_LO ...