知识屋:更实用的电脑技术知识网站
所在位置:首页 > 操作系统 > linux

Linuxtarexclude参数的用法

发布时间:2014-09-05 13:29:46作者:知识屋

最近在对Oracle 数据库使用冷备tar迁移时,遇到需要将当前数据库文件下下的datapump导出的文件过滤掉,要不然然会产生很大的tar文件以及耗用网络传输时间。其实tar命令为我们提供了过滤功能,只不过由于过滤功能通常使用的比较少,所以很多人不知道。本文描述了tar命令下如何过滤不需要的文件或文件夹。

1、演示环境

#当前的tree 目录下存在BBB,CCC以及BNR子目录,现在需要将gz的dump文件过滤掉,也就是不参与打包[oracle@linux1 ~]$ tree AAAAAA|-- BBB|   `-- SYTST_temp.dbf|-- BNR|   |-- dump|   |   |-- emp.dmp.gz|   |   |-- tb.dmp.gz|   |   `-- xx.dmp.gz|   `-- full|-- CCC|   `-- tempSYTST.dbf|-- SYTST.sh`-- initSYTST.ora5 directories, 7 files

2、演示如何进行过滤

#方法一,下面通过exclude参数进行过滤,使用通配符[oracle@linux1 ~]$ tar -czvf A1.tar.gz --exclude '*.gz' ./AAA  ./AAA/./AAA/CCC/./AAA/CCC/tempSYTST.dbf./AAA/BBB/./AAA/BBB/SYTST_temp.dbf./AAA/SYTST.sh./AAA/initSYTST.ora./AAA/BNR/./AAA/BNR/full/./AAA/BNR/dump/#查看包中的内容,没有任何gz文件[oracle@linux1 ~]$ tar -tvf A1.tar.gzdrwxr-xr-x oracle/oinstall   0 2013-12-13 14:10:43 ./AAA/drwxr-xr-x oracle/oinstall   0 2013-12-13 14:12:18 ./AAA/CCC/-rwxr-xr-x oracle/oinstall 209723392 2013-12-13 14:12:19 ./AAA/CCC/tempSYTST.dbfdrwxr-xr-x oracle/oinstall         0 2013-12-13 14:11:56 ./AAA/BBB/-rwxr-xr-x oracle/oinstall 104865792 2013-12-13 14:11:56 ./AAA/BBB/SYTST_temp.dbf-rwxr-xr-x oracle/oinstall      1281 2013-12-13 14:10:43 ./AAA/SYTST.sh-rwxr-xr-x oracle/oinstall      2949 2013-12-13 14:10:31 ./AAA/initSYTST.oradrwxr-xr-x oracle/oinstall         0 2013-12-13 14:11:12 ./AAA/BNR/drwxr-xr-x oracle/oinstall         0 2013-12-13 14:11:12 ./AAA/BNR/full/drwxr-xr-x oracle/oinstall         0 2013-12-13 14:11:04 ./AAA/BNR/dump/#方法二,下面通过使用多个exclude参数进行过滤[oracle@linux1 ~]$ tar -czvf A2.tar.gz --exclude='tempSYTST.dbf' --exclude=SYTST_temp.dbf ./AAA      ./AAA/./AAA/CCC/./AAA/BBB/./AAA/SYTST.sh./AAA/initSYTST.ora./AAA/BNR/./AAA/BNR/full/./AAA/BNR/dump/./AAA/BNR/dump/xx.dmp.gz./AAA/BNR/dump/tb.dmp.gz./AAA/BNR/dump/emp.dmp.gz#方法三,借助于exclude参数,直接将需要过滤得文件添加到文件,然后再从文件读取[oracle@linux1 ~]$ echo "*.dbf" >>exclude.txt[oracle@linux1 ~]$ echo "*.gz" >>exclude.txt[oracle@linux1 ~]$ more exclude.txt*.dbf*.gz[oracle@linux1 ~]$ tar -czvf A3.tar.gz --exclude-from=exclude.txt ./AAA./AAA/./AAA/CCC/./AAA/BBB/./AAA/SYTST.sh./AAA/initSYTST.ora./AAA/BNR/./AAA/BNR/full/./AAA/BNR/dump/#方法四,借助于exclude参数,可以直接使用目录加通配符的方式来过滤指定文件夹下的所有文件[oracle@linux1 ~]$ tar -czvf A4.tar.gz --exclude=./AAA/BNR/dump/* ./AAA./AAA/./AAA/CCC/./AAA/CCC/tempSYTST.dbf./AAA/BBB/./AAA/BBB/SYTST_temp.dbf./AAA/SYTST.sh./AAA/initSYTST.ora./AAA/BNR/./AAA/BNR/full/./AAA/BNR/dump/#方法五,借助于exclude参数,直接使用目录方式来过滤[oracle@linux1 ~]$ tar -czvf A4.tar.gz --exclude=./AAA/BNR ./AAA       ./AAA/./AAA/CCC/./AAA/CCC/tempSYTST.dbf./AAA/BBB/./AAA/BBB/SYTST_temp.dbf./AAA/SYTST.sh./AAA/initSYTST.ora

3、获取帮助信息

#使用help获取帮助信息[oracle@linux1 ~]$ tar --helpUsage: tar [OPTION...] [FILE]...GNU `tar' saves many files together into a single tape or disk archive, and canrestore individual files from the archive.Examples:  tar -cf archive.tar foo bar  # Create archive.tar from files foo and bar.  tar -tvf archive.tar         # List all files in archive.tar verbosely.  tar -xf archive.tar          # Extract all files from archive.tar.       ..........省略...........#使用man或者info获取帮助信息[oracle@linux1 ~]$ man tar    

Oracle 牛鹏社

更多参考

有关Oracle RAC请参考

有关Oracle 网络配置相关基础以及概念性的问题请参考:

有关基于用户管理的备份和备份恢复的概念请参考

有关RMAN的备份恢复与管理请参考

有关ORACLE体系结构请参考

(免责声明:文章内容如涉及作品内容、版权和其它问题,请及时与我们联系,我们将在第一时间删除内容,文章内容仅供参考)
收藏
  • 人气文章
  • 最新文章
  • 下载排行榜
  • 热门排行榜