从别人的脚本学shell(2)
示例: echo "[${_LogFlag}]:$(date "+%Y%m%d.%H%M%S"):${Use}@${Host}:${2}"|tee -a "${LogFile}";
1.tee命令tee命令用于将数据重定向到文件,另一方面还可以提供一份重定向数据的副本作为后续命令的stdin。简单的说就是把数据重定向到给定文件和屏幕上。 存在缓存机制,每1024个字节将输出一次。若从管道接收输入数据,应该是缓冲区满,才将数据转存到指定的文件中。若文件内容不到1024个字节,则接收完从标准输入设备读入的数据后,将刷新一次缓冲区,并转存数据到指定文件。 语法:
选项:
参数:
故示例中的命令是向文件中追加一句日志。 ??这一句命令显示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选项表示反转; grep(global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。
read$(grep -i uncatalog ${DBPathFile}|tail -1|awk '{print $3,$4}') |read _DBName _DBPath2
read命令从标准输入读取变量,在这里作为管道使用,将前面的输出读入发到后面的两个变量名中。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |