2004年12月09日

# 清除预设表 filter 中,所有规则链中的规则
iptables -F
# 清除预设表 filter 中,使用者自订链中的规则
iptables -X

# 清除mangle表中,所有规则链中的规则
iptables -F -t mangle
# 清除mangle表中,使用者自订链中的规则
iptables -t mangle -X

# 清除nat表中,所有规则链中的规则
iptables -F -t nat
# 清除nat表中,使用者自订链中的规则
iptables -t nat -X


iptables -P INPUT DROP
iptables -P OUTPUT DROP
iptables -P FORWARD DROP
iptables -A INPUT -p tcp –dport 80 -j ACCEPT
iptables -A INPUT -p tcp –dport 22 -j ACCEPT
iptables -A INPUT -p tcp –dport 21 -j ACCEPT
iptables -A INPUT -p tcp –dport 1521 -j ACCEPT

iptables -A INPUT -d 127.0.0.1 -j ACCEPT
/etc/rc.d/init.d/iptables save

2004年10月18日

用法: rpm [选项...]

查询选项 (参数 -q 或 –query):
  -c, –configfiles                列出所有配置文件
  -d, –docfiles                   列出所有文档文件
  –dump                           导出基本文件信息
  -l, –list                       列出包内的所有文件
  –queryformat=QUERYFORMAT        使用紧跟的查询格式
  -s, –state                      显示文件列表的状态
  -v, –verbose                    显示详细的文件列表
  -a, –all                        查询/校验所有包
  -f, –file                       查询/校验包的包含文件
  -g, –group                      查询/校验组内的包
  -p, –package                    查询/校验一个包文件(例如一个二进制的 *.rpm 文件)
  –querytags                      显示已知的查询标签
  –specfile                       查询规格文件
  –whatrequires                   查询/校验指定包的依赖关系
  –whatprovides                   查询/校验指定包的被依赖关系

校验选项 (参数 -V 或 –verify):
  –nomd5[|=0x1]                   不使用MD5分类校验文件
  –nofiles[|=0x10000]             不校验包中的文件
  –nodeps[|=0x20000]              不校验包的依赖关系
  –noscript[|=0x40000]            不执行校验脚本(任何脚本)
  -a, –all                        查询/校验所有包
  -f, –file                       查询/校验包所含的文件
  -g, –group                      查询/校验组内的包
  -p, –package                    查询/校验一个包文件(例如一个二进制的 *.rpm 文件)
  –querytags                      显示已知的查询标签
  –specfile                       查询规格文件
  –whatrequires                   查询/校验指定包的依赖关系
  –whatprovides                   查询/校验指定包的被依赖关系

签名选项:
  –addsign                        往包内增加一个签名
  –resign                         签名一个包(去除当前签名)
  -K, –checksig                   校验包的签名
  –nogpg[&=~0x4]                  忽略任何GPG的签名
  –nomd5[&=~0x2]                  不校验文件的MD5的校验数

数据库选项:
  –initdb                         初始化数据库
  –rebuilddb                      从已安装包的头信息中重建数据库的反转列表

安装/升级/卸载选项:
  –allfiles[|=0x40]               安装所有文件, 忽略找不到的配置项里面的部分
  –allmatches[|=0x2]              卸载所有和<package>项匹配的包。(如果<package>中指定多个包则会产生一个错误信息)
  –badreloc[|=0x8]                在非重定位包中重定位文件
  -e, –erase=<package>+           卸载包
  –excludedocs[|=0x20]            不安装文档
  –excludepath=<path>             带引导组件的忽略文件<path>
  –force[|=0x74]                  –replacepkgs –replacefiles的快捷方式
  -F, –freshen=<packagefile>+     在已安装的情况下升级包
  -h, –hash[|=0x2]                为安装包打上哈希标记(最好带-v选项)
  –ignorearch[|=0x2]              不校验包的体系
  –ignoreos[|=0x1]                不校验包的操作系统
  –ignoresize[|=0x180]            安装之前不检查磁盘空间
  –includedocs                    安装文档
  –install=<packagefile>+         安装包
  –justdb[|=0x8]                  升级数据库,但是不修改文件系统
  –nodeps                         不校验包的依赖关系
  –noorder[|=0x8]                 不重新记录包的安装信息到依赖性中
  –noscripts[|=0xff0000]          不执行包的脚本
  –notriggers[|=0x990000]         不执行被该安装包触发的任何脚本
  –oldpackage[|=0x40]             升级到该包的一个旧版本
                                   (–force 升级的时候,该操作自动执行)
  –percent[|=0x1]                 打印包的安装进度
  –prefix=<dir>                   如果允许重定位,则重定位包到<dir>
  –relocate=<old>=<new>           从路径<old>到<new>重定位文件
  –repackage[|=0x400]             重新打包保存下来的卸载包的文件
  –replacefiles[|=0x30]           安装时用包文件替换已安装文件
  –replacepkgs[|=0x4]             如果包已经存在,那么重新安装
  –test[|=0x1]                    不安装包,但是要检测能否正常运行
  -U, –upgrade=<packagefile>+     升级包

所有rpm模式的通用选项:
  –version                        打印所使用的rpm的版本信息
  –quiet                          提供少量详细信息输出
  -v, –verbose                    提供更多的详细信息输出
  –define=’<name> <body>’         使用值<body>来定义宏<name>
  –eval=<expr>+                   打印<expr>+的宏扩展
  -r, –root=<dir>                 使用<dir>作为顶层目录(默认: “/”)
  –macros=<file:…>              读入<file:…>来代替默认的宏文件
  –rcfile=<file:…>              读入<file:…>来代替默认的rpmrc文件
  –showrc                         显示最终的rpmrc和macro配置

通过popt alias/exec 实现的选项:
  –scripts                        列出包中的所有安装/卸载脚本
  –setperms                       在包中设置文件的权限
  –setugids                       在包中设置文件的用户/组关系
  –conflicts                      列出此包的兼容性
  –obsoletes                      列出安装此包需要卸载的别的包
  –provides                       列出此包提供的兼容性
  –requires                       列出此包所需要的兼容性
  –info                           列出包中的叙述信息
  –changelog                      列出该包的变更日志
  –triggers                       列出包中的触发脚本
  –last                           根据安装时间列出包,最近时间的优先
  –filesbypkg                     列出每个包的所有文件
  –redhatprovides                 根据所包含的提供的兼容性查找包名(需要安装包rpmdb-redhat)
  –redhatrequires                 根据所依赖的包的兼容性查找包名(需要安装包rpmdb-redhat)
  –buildpolicy=<policy>           设置包的根目录<policy>(例如,压缩man手册)
  –with=<option>                  打开打包的<选项>配置
  –without=<option>               关闭打包的<选项>配置

帮助选项:
  -?, –help                       显示该帮助信息
  –usage                          显示用法摘要

******************************************************1.如何不安装但是获取rpm包中的文件 使用工具rpm2cpio和cpio rpm2cpio xxx.rpm | cpio -vi rpm2cpio xxx.rpm | cpio -idmv rpm2cpio xxx.rpm | cpio --extract --make-directories 参数i和extract相同,表示提取文件。v表示指示执行进程 d和make-directory相同,表示根据包中文件原来的路径建立目录 m表示保持文件的更新时间。 

2.如何查看与rpm包相关的文件和其他信息 下面所有的例子都假设使用软件包mysql-3.23.54a-11 1.我的系统中安装了那些rpm软件包 rpm -qa 讲列出所有安装过的包 如果要查找所有安装过的包含某个字符串sql的软件包 rpm -qa |grep sql 

3.如何获得某个软件包的文件全名 rpm -q mysql 可以获得系统中安装的mysql软件包全名,从中可以获得 当前软件包的版本等信息。这个例子中可以得到信息mysql-3.23.54a-11 

4.一个rpm包中的文件安装到那里去了? rpm -ql 包名 注意这里的是不包括.rpm后缀的软件包的名称 也就是说只能用mysql或者mysql-3.23.54a-11而不是mysql-3.23.54a-11.rpm。 如果只是想知道可执行程序放到那里去了,也可以用which,比如 which mysql 

5.一个rpm包中包含那些文件 一个没有安装过的软件包,使用rpm -qlp ****.rpm 一个已经安装过的软件包,还可以使用rpm -ql ****.rpm 

6.如何获取关于一个软件包的版本,用途等相关信息? 一个没有安装过的软件包,使用rpm -qip ****.rpm 一个已经安装过的软件包,还可以使用rpm -qi ****.rpm 

6.某个程序是哪个软件包安装的,或者哪个软件包包含这个程序 rpm -qf `which 程序名` 返回软件包的全名 rpm -qif `which 程序名` 返回软件包的有关信息 rpm -qlf `which 程序名` 返回软件包的文件列表 注意,这里不是引号,而是`,就是键盘左上角的那个键。 也可以使用rpm -qilf,同时输出软件包信息和文件列表 

7.某个文件是哪个软件包安装的,或者哪个软件包包含这个文件 注意,前一个问题中的方法,只适用与可执行的程序,而下面的方法,不仅可以 用于可执行程序,也可以用于普通的任何文件。前提是知道这个文件名。 首先获得这个程序的完整路径,可以用whereis或者which,然后使用rpm -qf例如: # whereis ftptop ftptop: /usr/bin/ftptop /usr/share/man/man1/ftptop.1.gz # rpm -qf /usr/bin/ftptop proftpd-1.2.8-1 # rpm -qf /usr/share/doc/proftpd-1.2.8/rfc/rfc0959.txt proftpd-1.2.8-1 

总结: 获得软件包相关的信息用rpm -q,q表示查询query,后面可以跟其他选项,比如 i 表示info,获得软件包的信息; l 表示list,获得文件列表; a 表示all,在所有包中执行查询; f 表示file,根据文件进行相关的查询; p 表示package,根据软件包进行查询 需要的查询条件可以使用grep产生,或者从"` `"中的命令行产生 

7.关于rpm软件包的一些相关知识 1.什么是rpm rpm 即RedHat Package Management,是RedHat的发明之一 

8.为什么需要rpm 在一个操作系统下,需要安装实现各种功能的软件包。这些软件包一般都有各自的 程序,但是同时也有错综复杂的依赖关系。同时还需要解决软件包的版本,以及安装, 配置,卸载的自动化问题。为了解决这些问题,RedHat针对自己的系统提出了一个 较好的办法来管理成千上百的软件。这就是RPM管理系统。在系统中安装了rpm管理系统 以后,只要是符合rpm文件标准的打包的程序都可以方便的安装,升级,卸载 

9.是不是所有的linux都使用rpm 任何系统都需要包管理系统,因此很多linux都使用rpm系统。但rpm系统是为RH专门 但是TL,Mandrake等系统也都使用rpm。由于rpm的源程序可以在别的系统上进行编译, 所以有可能在别的系统上也使用rpm 除了rpm,其他一些系统也有自己的软件包管理程序,例如debian的deb包, slakware也都有自己的包管理系统 

10.rpm包的文件名为什么那么长 rpm包的文件名中包含了这个软件包的版本信息,操作系统信息,硬件要求等等。 比如mypackage-1.1-2TL.i386.rpm,其中mypackage是在系统中登记的软件包的名字 1.1是软件的版本号,2是发行号,TL表示用于TL操作系统,还可能是RH等。i386表示 用于intel x86平台,还可能是sparc等。 

11.软件包文件名中的i386,i686是什么意思 rpm软件包的文件名中,不仅包含了软件名称,版本信息,还包括了适用的硬件架构 的信息。 i386指这个软件包适用于intel 80386以上的x86架构的计算机(AI32) i686指这个软件包适用于intel 80686以上(奔腾pro以上)的x86架构的计算机(IA32) noarch指这个软件包于硬件架构无关,可以通用。 i686软件包的程序通常针对CPU进行了优化,所以,向后兼容比较用以,i386的包在 x86机器上都可以用。向前一般不兼容。不过现在的计算机,奔腾pro以下的CPU已经很少 用,通常配置的机器都可以使用i686软件包 

12.不同操作系统发行的rpm包可否混用? 对于已经编译成二进制的rpm包,由于操作系统环境不同,一般不能混用。 对于以src.rpm发行的软件包,由于需要安装时进行本地编译,所以通常可以在不同 系统下安装。 

13.使用rpm时遇到的一些特殊问题 Q 我用rpm -e **.rpm无法删除rpm包 A 包名不要包括rpm, rpm -e 包名,可以包含版本号等信息,但是不可以有后缀.rpm 

Q 在MS的系统下有没有读RPM文件的工具? A wincmd with rpm plugins..... 

Q 是否可以通过ftp安装安装升级rpm包? A 可以。rpm -ivh ftp://xxxxxxxx/PATH2SomeRPM 

Q rpm安装时已有的包版本过高怎么办? A 有时由于安装的软件包太老,而系统中相关的软件包版本比较新,所以可能需要 安装的包依赖的一些文件会找不到。这时有两种解决办法, 第一是在系统文件中找到和需要的文件功能相同或相似的文件,做一个符号链接到 需要的目录下。 第二是下载安装新版本的软件包。

[b:7639f4d5ed]进入vi的命令[/b:7639f4d5ed]
vi  filename   :打开或新建文件,并将光标置于第一行首
vi  +n filename  :打开文件,并将光标置于第n行首
vi  + filename    :打开文件,并将光标置于最后一行首
vi +/pattern filename:打开文件,并将光标置于第一个与pattern匹配的串处
vi  -r filename :在上次正用vi编辑时发生系统崩溃,恢复filename
vi  filename….filename :打开多个文件,依次进行编辑

[b:7639f4d5ed]移动光标类命令[/b:7639f4d5ed][/b]
h :光标左移一个字符
l  :光标右移一个字符
space:光标右移一个字符
Backspace:光标左移一个字符
k或Ctrl+p:光标上移一行
j或Ctrl+n :光标下移一行
Enter :光标下移一行
w或W :光标右移一个字至字首
b或B :光标左移一个字至字首
e或E :光标右移一个字至字尾
) :光标移至句尾
( :光标移至句首
}:光标移至段落开头
{:光标移至段落结尾
nG:光标移至第n行首
n+:光标下移n行
n-:光标上移n行
n$:光标移至第n行尾
H :光标移至屏幕顶行
M :光标移至屏幕中间行
L :光标移至屏幕最后行
0:(注意是数字零)光标移至当前行首
$:光标移至当前行尾

[b:7639f4d5ed]屏幕翻滚类命令[/b:7639f4d5ed]
Ctrl+u:向文件首翻半屏
Ctrl+d:向文件尾翻半屏
Ctrl+f:向文件尾翻一屏
Ctrl+b;向文件首翻一屏
nz:将第n行滚至屏幕顶部,不指定n时将当前行滚至屏幕顶部。

[b:7639f4d5ed]插入文本类命令[/b:7639f4d5ed]
i :在光标前
I :在当前行首
a:光标后
A:在当前行尾
o:在当前行之下新开一行
O:在当前行之上新开一行
r:替换当前字符
R:替换当前字符及其后的字符,直至按ESC键
s:从当前光标位置处开始,以输入的文本替代指定数目的字符
S:删除指定数目的行,并以所输入文本代替之
ncw或nCW:修改指定数目的字
nCC:修改指定数目的行

[b:7639f4d5ed]删除命令[/b:7639f4d5ed]
ndw或ndW:删除光标处开始及其后的n-1个字
do:删至行首
d$:删至行尾
ndd:删除当前行及其后n-1行
x或X:删除一个字符,x删除光标后的,而X删除光标前的
Ctrl+u:删除输入方式下所输入的文本

[b:7639f4d5ed]搜索及替换命令[/b:7639f4d5ed]
/pattern:从光标开始处向文件尾搜索pattern
?pattern:从光标开始处向文件首搜索pattern
n:在同一方向重复上一次搜索命令
N:在反方向上重复上一次搜索命令
:s/p1/p2/g:将当前行中所有p1均用p2替代
:n1,n2s/p1/p2/g:将第n1至n2行中所有p1均用p2替代
:g/p1/s//p2/g:将文件中所有p1均用p2替换

[b:7639f4d5ed]选项设置[/b:7639f4d5ed]
all:列出所有选项设置情况
term:设置终端类型
ignorance:在搜索中忽略大小写
list:显示制表位(Ctrl+I)和行尾标志($)
number:显示行号
report:显示由面向行的命令修改过的数目
terse:显示简短的警告信息
warn:在转到别的文件时若没保存当前文件则显示NO write信息
nomagic:允许在搜索模式中,使用前面不带“\”的特殊字符
nowrapscan:禁止vi在搜索到达文件两端时,又从另一端开始
mesg:允许vi显示其他用户用write写到自己终端上的信息

[b:7639f4d5ed]最后行方式命令[/b:7639f4d5ed]
:n1,n2 co n3:将n1行到n2行之间的内容拷贝到第n3行下
:n1,n2 m n3:将n1行到n2行之间的内容移至到第n3行下
:n1,n2 d :将n1行到n2行之间的内容删除
:w :保存当前文件
:e filename:打开文件filename进行编辑
:x:保存当前文件并退出
:q:退出vi
:q!:不保存文件并退出vi
:!command:执行shell命令command
:n1,n2 w!command:将文件中n1行至n2行的内容作为command的输入并执行之,若不指定n1,n2,则表示将整个文件内容作为command的输入
:r!command:将命令command的输出结果放到当前行

[b:7639f4d5ed]寄存器操作[/b:7639f4d5ed]
“?nyy:将当前行及其下n行的内容保存到寄存器?中,其中?为一个字母,n为一个数字
“?nyw:将当前行及其下n个字保存到寄存器?中,其中?为一个字母,n为一个数字
“?nyl:将当前行及其下n个字符保存到寄存器?中,其中?为一个字母,n为一个数字
“?p:取出寄存器?中的内容并将其放到光标位置处。这里?可以是一个字母,也可以是一个数字
ndd:将当前行及其下共n行文本删除,并将所删内容放到1号删除寄存器中。
********************************************
vi 高级技巧

交换两个字符位置
xp
上下两行调换
ddp
把文件内容反转
:g/^/m0/
保存后就加密
:X
上下两行合并 
J
删除所有行 
dG
从当前位置删除到行尾
d$
从当前位置复制到行尾
y$ 如果要粘贴到其他地方 p 就可以了

在命令状态下,nyy表示拷贝从光标行起的下n行内容,p表示paste,粘贴下来在光标处。
我常用到的单个字符替换用r,覆盖多个字符用R,用多个字符替换一个字符用s,整行替换用S
:%s/old_word/new_word/g
这个指令是于在整个文件中替换特定字符串
将光标移到第n行,按下 mk
将光标移到第m行,按下 ”ay’k
即将第n到m的行存到a寄存器,以此类推,b,c……..寄存器等
删除命令操作
d l 删除当前字符(与x命令功能相同)
d 0 删除到某一行的开始位置
d ^ 删除到某一行的第一个字符位置(不包括空格或TA B字符)
d w 删除到某个单词的结尾位置
d 3 w 删除到第三个单词的结尾位置
d b 删除到某个单词的开始位置
d W 删除到某个以空格作为分隔符的单词的结尾位置
d B 删除到某个以空格作为分隔符的单词的开始位置
下载
(续)
删除命令操作
d 7 B 删除到前面7个以空格作为分隔符的单词的开始位置
d) 删除到某个语句的结尾位置
d 4) 删除到第四个语句的结尾位置
d( 删除到某个语句的开始位置
d } 删除到某个段落的结尾位置
d { 删除到某个段落的开始位置
d 7 { 删除到当前段落起始位置之前的第7个段落位置
d d 删除当前行
d /t e x t 删除从文本中出现“ t e x t”中所指定字样的位置,一直向前直到下一个该字样所出现的
位置(但不包括该字样)之间的内容
d fc 删除从文本中出现字符“c”的位置,一直向前直到下一个该字符所出现的位置(包括
该字符)之间的内容
d tc 删除当前行直到下一个字符“ c”所出现位置之间的内容
D 删除到某一行的结尾
d $ 删除到某一行的结尾
5 d d 删除从当前行所开始的5行内容
d L 删除直到屏幕上最后一行的内容
d H 删除直到屏幕上第一行的内容
d G 删除直到工作缓存区结尾的内容
d 1 G 删除直到工作缓存区开始的内容
下载

表8-3 修改命令
修改命令操作
c l 更改当前字符
c w 修改到某个单词的结尾位置
c 3 w 修改到第三个单词的结尾位置
c b 修改到某个单词的开始位置
c W 修改到某个以空格作为分隔符的单词的结尾位置
c B 修改到某个以空格作为分隔符的单词的开始位置
c 7 B 修改到前面7个以空格作为分隔符的单词的开始位置
c 0 修改到某行的结尾位置
c) 修改到某个语句的结尾位置
c 4) 修改到第四个语句的结尾位置
c( 修改到某个语句的开始位置
c } 修改到某个段落的结尾位置
c { 修改到某个段落的开始位置
c 7 { 修改到当前段落起始位置之前的第7个段落位置
c tc 修改当前行直到下一个字符c所出现位置之间的内容
C 修改到某一行的结尾
c c 修改当前行
5 c c 修改从当前行所开始的5行内容

表8-4 替换命令
替换命令操作
s 将当前字符替换为一个或多个字符
S 将当前行替换为一个或多个字符
5 s 将从当前字符开始的5个字符替换为一个或多个字符
fx
往右移动到 x 字符上
Fx
往左移动到 x 字符上
tx
往右移动到 x 字符前
Tx
往左移动到 x 字符后
(注意:以上四个命令中,其中x是键入的字符)
;
分号,配合 f 和 t 使用,重复一次 
,
逗号,配合 f 和 t 使用,反方向重复一次
追加到缓冲区
对于已经有内容的缓冲区,可以继续追加内容在其后面,例如:
“Ad4w      删除光标后4个字,并附加到缓冲区a
“Ay)       取样从光标到文件尾的内容,并附加到缓冲区a
“K3yy      取样从光标所在行起的3行内容,并附加到缓冲区k
删除从当前行开始到最后一行的所有内容
:.,$d
在:命令行模式下,首先可以确定命令的范围
.表示当前行;数字表示行号,如1表示第一行,2表示第二行;$表示最后一行
范围用,分隔
然后用命令
d表示删除,y表示复制……大家都知道的

最后说一句,%表示全文
:%d
是删除全文

2004年10月16日

http://www.linuxsir.org/bbs/showthread.php?s=775a377bc812dc6f1744aa9511732b57&threadid=129458

2004年10月15日

rmdir (remove directory) 可以用来删除目录,但要求不包含任何文件或子目录。

     rmdir   test       //删除test子目录

rm (remove)  删除文件

     rm test.txt    //删除文件test.txt

     rm -f *.txt   //强制删除*.txt,用此参数则不提示是否删除

     rm -r /test    //删除test文件夹以及test文件夹以下的所有文件

#df  //查看文件系统当前占用的磁盘空间大小

#du -sm /bin  //查看/bin/目录占用的磁盘空间大小

                     //如不加-s就可以显示此目录下每个文件的大小

 

2004年10月14日

fdisk  第一个硬盘为sda 第二个硬盘为sdb 以此类推

比如对第二个硬盘进行分区,步骤如下:

fdisk /dev/sdb    // 为第二个硬盘分区

Command (m for help):p  //查看新硬盘的分区
Command (m for help):n  //创建新分区

可以用m命令来看fdisk命令的内部命令;n命令创建一个新分区;d命令删除一个存在的分区;p命令显示分区列表;t命令修改分区的类型ID号;l命令显示分区ID号的列表;a命令指定启动分区;w命令是将对分区表的修改存盘让它发生作用。 

Command action
   e   extended   //输入e为创建扩展分区
   p   primary partition (1-4)   //输入p为创建主分区,这里我们选择p

Partion number(1-4):1  //第一个扩展分区,按你需求可以最多分4个主分区
First Cylinder(1-1014,default 1):  1  //第一个主分区起始的磁盘块数
Last cylindet or +siza or +sizeM or +sizeK: +1024MB  //可以是以MB为单位的数字或者以

磁盘块数,这里我们输入+1024MB表示分区大小为1G。

这样我们就创建完一个分区,如果要创建更多分区可以照上面的步骤继续创建。

创建完后用w保存分区。
[code:1:5c157e4b2e]
Command (m for help): w
The partition table has been altered!

#mkfs -t ext3 -c /dev/sdb1  //如果有多个分区,则分区修改为sdb2这样
[/code:1:5c157e4b2e]
格式化完后我们需要进行挂载分区,

#mkdir www //创建/www目录,我们将把新的分区挂到www下
#mount /dev/sdb1 /www  //将/dev/sdb1挂载到/www

tar
參數說明:?
-z? :是否同時具有 gzip 的屬性??
-x? :解開一個壓縮檔案的參數指令!?
-t? :查看 tarfile 裡面的檔案!
-c? :建立一個壓縮檔案的參數指令?
-v? :壓縮的過程中顯示檔案!?
-f? :使用檔名,請留意,在 f 之後要立即接檔名喔!不要再加參數!
   例如使用『 tar -zcvfP tfile sfile』就是錯誤的寫法,要寫成
   『 tar -zcvPf tfile sfile』才對喔!
-p? :使用原檔案的原來屬性(屬性不會依據使用者而變)?
-P? :可以使用絕對路徑?
-N? :比後面接的日期(yyyy/mm/dd)還要新的才會被打包進新建的檔案中!?
–exclude FILE:在壓縮的過程中,不要將 FILE 打包!

[root @test /root]# tar -cvf? directory.tar??? directory?
只將目錄整合打包成一個檔案?
[root @test /root]# tar -zcvf directory.tar.gz directory?
除了將目錄打包外,同時以 gzip 壓縮?

[root @test /root]# tar -zcvf filename.tar.gz? /home/test/*?
將 /home/test/ 這個目錄下的檔案全部打包並壓縮成為一個 filename.tar.gz 的檔案

[root @test /root]# tar -xvf? directory.tar?
解 tar 的封包,請注意,由於沒有 gzip (.tar 而非 .tar.gz) 的作用,所以只要使用 –xvf 即可!不需要加上 z ,否則會顯示有問題!

[root @test /root]# tar -zxvf directory.tar.gz?
這個就是有加上 gzip 的壓縮的結果!所以需要加上 –z 呦!

[root @test /root]# tar –ztvf directory.tar.gz
這個 t 可以用來查看 tar 裡面的檔案資訊呢!而不需要將他解開!

[root @test /root]# tar -zcvPf home.tar.gz /home?
則建立起來的壓縮檔內檔案為絕對路徑?
請注意,使用這個 P 的參數時,不要將 P 加在 f 後面,因為
f 之後要立即接檔名才行喔!

[root @test /root]# tar -N ‘2002/06/25′ -zcvf home.tar.gz /home?
上面是說 在 /home 這個目錄中,比 2002/06/25 日還要新的檔案才會被打包進入 home.tar.gz 這個檔案中!?

[root @test /root]# tar -zcvf host.tar.gz / –exclude /mnt –exclude /proc?
上面是說,將根目錄的所有資料都打包進 host.tar.gz 這個檔案中,但是 /mnt 及 /proc 則不打包!?

[root @test /root]# tar -cvf – /home | tar -xvf –
上面的意思是『將 /home 打包之後,直接解壓縮在 /root 底下!』嘿嘿!不需要再建立一次中間檔案!不過,使用上面的語法最好使用『絕對路徑』,比較不會有問題!這個方式適合不想要建立中間檔案時!