- 浏览: 2542525 次
- 性别:
- 来自: 深圳
文章分类
- 全部博客 (676)
- linux运维 (157)
- php (65)
- mysql (78)
- nginx (27)
- apche (18)
- framework (6)
- windows (9)
- IDE工具 (23)
- struts2 (7)
- java (13)
- 移动互联网 (14)
- memcache redis (23)
- shell基础/命令/语法 (37)
- shell (50)
- puppet (4)
- C (11)
- python (9)
- 产品经理 (27)
- Sphinx (4)
- svn (12)
- 设计构建 (12)
- 项目管理 (44)
- SEO (1)
- 网站架构 (26)
- 审时度势 (42)
- 网络 (14)
- 激发事业[书&视频] (81)
- 其它 (12)
- 摄影 (8)
- android (21)
最新评论
-
zhongmin2012:
原文的书在哪里
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
renzhengzhi:
你好,请问个问题,从master同步数据到slave的时候,s ...
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
ibc789:
你好,看了你的文章,我想请教个问题, 我在用 redis的时候 ...
redis 的两种持久化方式及原理 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器 -
iijjll:
写得非常好
数据库水平切分的实现原理解析---分库,分表,主从,集群,负载均衡器
=============??????? 新增加的文件无法更新
The next patch would create the file sc_patch/update20120730.sql,
which already exists! Skipping patch.
1 out of 1 hunk ignored
===============
old:/var/www/ssc/
new:/var/www/ssc_update/
mkdir -p /var/www/ssc_update/
rm -rf /var/www/ssc_update/*
cp -rp /var/www/ssc/* /var/www/ssc_update/
tar zxvf /usr/local/shell/tar/ssc2012-07-11.tar.gz -C /var/www/ssc_update/
#进入主目录,不可缺少
cd /var/www
#制作补丁
diff -Nur ssc ssc_update > change.patch
#发布
patch -Np0 < change.patch
#还原
patch -Rp0 < change.patch
==================== 推荐 :理解 p0 和 p1
作为程序员,了解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 -N
p0 < foo.patch
如果你想严格指定是还原补丁
可以使用下面命令(就是增加R参数):
# patch -R
p0 < 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的内容了。
发表评论
-
Linux运维常用命令 (转载)
2013-01-31 10:23 25291 删除0字节文件find-type f - ... -
[汇总]shell笔试
2013-01-24 17:32 3369http://president.blog.51cto.co ... -
【汇总】shell show收藏
2012-11-29 14:03 1288================== shell从文本取对应的 ... -
Shell中脚本变量和函数变量的作用域
2012-11-28 16:21 1378在shell中定义函 ... -
你可能不知道的Shell
2012-11-26 13:41 1011!$ !$是一个特殊的环境变量,它代表了上一个命令的 ... -
read case
2012-11-01 16:55 973read -p "请输入安装程序编号:" ... -
很精彩的linux命令
2012-07-13 10:55 13721.按内存从大到小排列进程: ps -eo " ... -
[转]实用基础_shell脚本详解命令
2012-07-11 11:44 1473shell脚本编写技巧 " 1.test测试命令 tes ... -
UNIX高手的20个习惯
2012-06-29 12:02 14261. 在单个命令中创建目 ... -
【书】linux shell 脚本攻略
2012-06-27 17:39 1925转载:http://jackyrong.iteye.com/b ... -
字段分隔符IFS和循环
2012-06-27 16:10 1758Shell的内部域分隔符可以是空格、制表符和换行符。它可以作为 ... -
【汇总】sh语法汇总2
2012-06-27 16:08 3415============= " ... -
df,du,fdisk
2012-06-27 12:39 1287------------------- ... -
split,csplit切割文件
2012-06-26 18:06 1602linux split 命令 功能说明:切割文件。 ... -
head,tail
2012-06-26 13:44 3head,tail -
xargs格式化输出
2012-06-26 13:41 1984从标准输出建立并运行命令行 把从stdin接收到 ... -
read,cat,touch,head,tail
2012-06-26 13:39 1556===================== read ... -
sed简化命令:tr
2012-06-26 13:12 1298连续多个’\n‘字符压缩成单个'\n' cat t.txt ... -
cut用法
2012-06-13 17:12 1157linux之cut用法 cut是一个选取命令,就是将一段数据 ... -
shell之数组
2012-05-11 18:05 1402====================== 循环 c ...
相关推荐
- 补丁包通常包含一系列的`.diff`或`.patch`文件,这些文件记录了源代码文件之间的差异。 - `patch-2.6.tar.gz`和`patches3.0.tgz`可能分别包含针对Linux内核2.6和3.0的补丁文件,每个`.diff`文件对应源代码的一个...
29. **patch**:应用补丁文件,更新源代码。 30. **wc**:计算文件的行数、单词数和字符数,用于统计文本信息。 以上仅是部分基础命令,Linux的文件处理能力远不止这些。通过深入学习,你可以掌握更高级的命令,如...
2. 复制原始源代码:在应用补丁前备份源代码,以便可以恢复到未打补丁的状态。 3. 回滚补丁:使用`patch -R`或`patch --reverse`命令撤销补丁。 4. 验证结果:重新编译和测试代码,确认已成功回滚到预期状态。 C和...
Linux中的`patch`命令是一个非常实用的工具,用于将由`diff`命令生成的补丁应用到源代码或文件上,以更新或修复文件。它能够处理一系列的文本或源代码差异,使得软件升级、错误修复变得更加便捷。下面我们将详细探讨...
- **patch**:根据补丁文件更新源代码。`patch [选项] 补丁文件`,用于软件升级和修复。 - **rep(remotecopy)**:远程复制文件。`rep [选项] 文件`,用于跨网络的文件传输。 - **rhmask**:用于隐藏或显示文件的特殊...
- `patches` 目录可能包含了一系列修复错误或改进功能的补丁,这些补丁通常用diff格式编写,可以通过patch工具应用到源代码上。 这些文件的组合表明,这个项目系统可能是一个开源项目,具有清晰的版本控制、许可...
- `tee`: 将标准输入写入标准输出和文件。 - `tmpwatch`: 清除过期的临时文件。 - `touch`: 修改文件的时间戳或创建新文件。 - `umask`: 设置文件权限掩码。 - `whereis`: 查找二进制文件、源代码文件和帮助页的位置...
补丁文件通常采用diff格式,记录了源代码的修改差异。在这个例子中,补丁会告诉用户哪些内核文件需要改动,以及如何改动。应用补丁通常是通过`patch`命令完成的,它会比较内核源码和补丁中的差异,并自动将内核源码...
- **PATCH**: 用于应用补丁文件,通常用于更新源代码。 - **RCP (Remote Copy)**: 用于远程复制文件。 - **RHMASK**: 用于设置文件权限掩码。 - **RM (Remove)**: 用于删除文件或目录。 - **SLOCATE (Secure Locate)...
- **diff (differential)**:比较两个文件之间的差异。 - **diffstat (differential status)**:提供两个文件或目录之间更改的统计信息。 - **file**:用于确定文件类型。 - **find**:用于在文件系统中搜索文件。 -...
在"bzip2-1.0.5-src(2).zip"文件中,提供了bzip2的源代码。bzip2是一种常见的数据压缩工具,bsdiff在生成补丁文件时可能会用到bzip2来压缩生成的补丁,以进一步减小文件大小。bsdiff通常将补丁文件压缩为.bsp格式,...
15. **patch**:应用由`diff`产生的补丁文件,更新源代码。 16. **chmod**:更改文件或目录的权限,如读、写、执行权限。 17. **chown/chgrp**:更改文件或目录的所有者和组,以控制访问权限。 18. **cron**:...
35. **Whereis**: 查找二进制文件、源代码和手册页的位置。 36. **Which**: 查找可执行文件的位置。 37. **Cat**: 显示文件内容。 38. **Chattr (Change Attribute)**:更改文件属性。 39. **Chgrp (Change Group)**...
56. **patch**:应用补丁文件,更新源代码。 57. **make**:自动化构建程序,常用于C/C++项目。 58. **git**:版本控制系统,管理代码版本。 59. **sed**:流编辑器,用于文本替换、替换和模式匹配。 60. **awk**:...
- **diff**与**patch**:比较两个文件或目录的差异,并应用差异补丁。 - **磁盘和文件系统** - **磁盘的物理结构**:包括磁盘的基本组成部分如磁头、磁道、扇区等。 - **文件系统**:描述了如何组织和存储文件的...
39. **diff** 和 **patch** - 比较文件差异并生成补丁。 40. **ln** - 创建符号链接或硬链接,如 `ln -s file link` 创建软链接。 41. **source** - 执行指定文件中的shell命令,常用于加载环境变量配置。 42. **...