示例:
echo "[${_LogFlag}]:$(date "+%Y%m%d.%H%M%S"):${Use}@${Host}:${2}"|tee -a "${LogFile}";
1.tee命令
tee命令用于将数据重定向到文件,另一方面还可以提供一份重定向数据的副本作为后续命令的stdin。简单的说就是把数据重定向到给定文件和屏幕上。
存在缓存机制,每1024个字节将输出一次。若从管道接收输入数据,应该是缓冲区满,才将数据转存到指定的文件中。若文件内容不到1024个字节,则接收完从标准输入设备读入的数据后,将刷新一次缓冲区,并转存数据到指定文件。
语法:
tee(选项)(参数)
选项:
参数:
故示例中的命令是向文件中追加一句日志。
这一句命令显示ls的执行结果,同时将这些内容输出到test.log文件中
[root@bogon tmp]# ls | tee test.log
con.txt
db2drop.sh
db2reorg.sh
DB2Resource.sh
getopt.sh
keyring-3HEZN9
keyring-jRtzT4
keyring-lY40O6
keyring-OAarNF
keyring-Q1xEdc
keyring-u8JUex
orbit-gdm
orbit-ltt
passtess.txt
pd.key.user.93636
pulse-NbEuBP4f8qOo
sqlDIR.LK0
tess.file
testopt.sh
test.sh
testvariablescope.sh
VMwareDnD
vmware-root
[root@bogon tmp]# cat test.log
con.txt
db2drop.sh
db2reorg.sh
DB2Resource.sh
getopt.sh
keyring-3HEZN9
keyring-jRtzT4
keyring-lY40O6
keyring-OAarNF
keyring-Q1xEdc
keyring-u8JUex
orbit-gdm
orbit-ltt
passtess.txt
pd.key.user.93636
pulse-NbEuBP4f8qOo
sqlDIR.LK0
tess.file
testopt.sh
test.sh
testvariablescope.sh
VMwareDnD
vmware-root
下面这一句将ls的结果分别发送给tee test.log和 cat -n,所以test.log中的内容是不带序号的,cat -n的输出是带序号的。看懂图示中的管道流通图很重要。
[root@bogon tmp]# ls | tee test.log | cat -n
1 con.txt
2 db2drop.sh
3 db2reorg.sh
4 DB2Resource.sh
5 getopt.sh
6 keyring-3HEZN9
7 keyring-jRtzT4
8 keyring-lY40O6
9 keyring-OAarNF
10 keyring-Q1xEdc
11 keyring-u8JUex
12 orbit-gdm
13 orbit-ltt
14 passtess.txt
15 pd.key.user.93636
16 pulse-NbEuBP4f8qOo
17 sqlDIR.LK0
18 tess.file
19 test.log
20 testopt.sh
21 test.sh
22 testvariablescope.sh
23 VMwareDnD
24 vmware-root
sed ‘$d’
$(echo "${_output}"|sed '$d')
sed ‘$d’表示删除最后一行
awk的使用
示例1:
$(echo "${_output}"|tail -1|awk '{if($1~"^[-,0-9]*$"){printf "%d",$1}else{printf "%d",5}}')
[db2inst1@bogon tmp]$ db2 "force application all"
DB20000I The FORCE APPLICATION command completed successfully.
DB21024I This command is asynchronous and may not be effective immediately.
示例2
[db2inst1@bogon tmp]$ echo '-1316,-1017'|awk -F,-v c='-1316' '{for(i=1;i<=NF;i++){if($i==c && c!=0){f=1}}}END{if(f==1){printf 100}else{printf "%d",c}}'
100
这个代码不好看懂的话我们整理格式化一下:
awk -F,-v c='-1316' ' {for(i=1;i<=NF;i++) {if($i==c && c!=0) {f=1} } } END{if(f==1) {printf 100} else {printf "%d",c} }'
过滤掉不需要的行——grep命令
[db2inst1@bogon tmp]$ db2 list applications for database DBMDB
Auth Id Application Appl. Application Id DB # of
Name Handle Name Agents
-------- -------------- ---------- -------------------------------------------------------------- -------- -----
DB2INST1 db2bp 6289 *LOCAL.db2inst1.170607011702 DBMDB 1
DB2INST1 db2jcc_applica 6235 192.168.225.1.8374.170607004338 DBMDB 1
[db2inst1@bogon tmp]$ db2 list applications for database DBMDB| grep -vE "sql1611W|^Auth|^$|^-|Agents$"
DB2INST1 db2bp 6289 *LOCAL.db2inst1.170607011702 DBMDB 1
DB2INST1 db2jcc_applica 6235 192.168.225.1.8374.170607004338 DBMDB 1
-v选项表示反转;
-E 将范本样式为延伸的普通表示法来使用,意味着使用能使用扩展正则表达式。
sql1611W是没有application时候的返回,过滤掉这一行就没啥了。
grep(global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
* 选项 *
- -a 不要忽略二进制数据。
- -A<显示列数> 除了显示符合范本样式的那一行之外,并显示该行之后的内容。
- -b 在显示符合范本样式的那一行之外,并显示该行之前的内容。
- -C<显示列数>或-<显示列数> 除了显示符合范本样式的那一列之外,并显示该列之前后的内容。
- -e<范本样式> 指定字符串作为查找文件内容的范本样式。
- -E 将范本样式为延伸的普通表示法来使用,意味着使用能使用扩展正则表达式。
- -F 将范本样式视为固定字符串的列表。
- -h 在显示符合范本样式的那一列之前,不标示该列所属的文件名称。
- -i 胡列字符大小写的差别。
- -l 列出文件内容符合指定的范本样式的文件名称。
- -L 列出文件内容不符合指定的范本样式的文件名称。
- -q 不显示任何信息。
- -s 不显示错误信息。
- -v 反转查找
- -w 只显示全字符合的列。
- -x 只显示全列符合的列。
- -y 此参数效果跟“-i”相同。
- -o 只输出文件中匹配到的部分。
read
$(grep -i uncatalog ${DBPathFile}|tail -1|awk '{print $3,$4}') |read _DBName _DBPath2
read命令从标准输入读取变量,在这里作为管道使用,将前面的输出读入发到后面的两个变量名中。