Linux下怎样拆分大的日志文件?

如何拆分

split命令上场。

按照行数拆分

假设文件test.txt有n多行,每2行拆分为一个文件,使用-l参数即可:


  1. $ split -l 2 test.txt  
  2. $ ls -al 
  3. -rw-r–r– 1 root root 32 Aug 31 16:55 test.txt 
  4. -rw-r–r– 1 root root 20 Aug 31 16:55 xaa 
  5. -rw-r–r– 1 root root 12 Aug 31 16:55 xab 

仔细一看,拆分后的文件名难以描述啊。

能不能好好命名一下呢?

规范命名

使用-d参数可以用数字作为新的文件后缀:


  1. $ split -l 2 test.txt -d 
  2. $ ls 
  3. test.txt  x00  x01  x02 

还可以用-a指定后缀数字的长度(默认是2):


  1. $ split -l 2 test.txt -d -a 4 
  2. $ ls 
  3. test.txt  x0000  x0001  x0002 

不过开头的x实在看不顺序,我们还可以指定前缀,比如指定前缀为test:


  1. $ split -l 2 test.txt -d -a 4 test 
  2. $ ls 
  3. test0000  test0001  test0002  test.txt 

而且你还可以从指定数字下标开始,使用–numeric-suffixes,例如从0004开始:


  1. $ split –numeric-suffixes=4 test.txt -a 4 -l 2 
  2. test.txt  x0004  x0005 

按照大小拆分

使用-b参数来按照大小来拆分,单位为字节:


  1. $ split -b 10 test.txt 

当然还可以使用k(千字节),m(兆)。即:


  1. $ split -b 10k test.txt 

分割成指定数量文件

使用-n参数即可,比如无论大小,行数,拆分为3个文件:


  1. $ split -n 4 test.txt 
  2. $ test.txt  xaa  xab  xac  xad 

其他方法

当然了,打的日志文件可以不用那种创建临时文件打开的方式(如vim打开一个文件会创建一个临时文件),而可以使用类似more,tail等命令查看部分内容。

【声明】:芜湖站长网内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

相关文章