继续学习本系列,您将了解到一些对 Oracle 用户(无论是开发人员还是 DBA)很有帮助的更高级的 Linux 命令。
alias 和 unalias
假设您要检查 shell 中设置的 ORACLE_SID 环境变量。您必须键入:
echo $ORACLE_HOME
作为 DBA 或开发人员,您需要频繁使用此命令,很快就会对输入这 16 个字符感到厌倦。有没有更简单的方法?
当然有:您可以使用 alias 命令。使用该方法,您可以创建一个简短的别名(如 "os")来代表整条命令:
alias os='echo $ORACLE_HOME'
现在,每次要检查 ORACLE_SID 时,您只需键入 "os"(没有引号),Linux 就会执行别名代表的命令。
然而,如果您注销并重新登录,别名就不见了,您需要再次输入 alias 命令。要取消这个步骤,您只需将该命令置于 shell 的配置文件中。对于 bash,配置文件为主目录中的 .bash_profile(注意文件名前面的句点,它是文件名的一部分)。对于 bourne 和 korn shell,配置文件为 .profile;对于 c-shell,配置文件为 .chsrc。
您可以使用任何名称创建别名。例如,我总是将 rm -i 命令的别名创建为 rm,从而使它成为交互式命令。
alias rm=’rm -i’
我每次执行 rm 命令后,如果不输入 "y",Linux 就会提示我进行确认,而不会删除该文件,因此不会出现意外删除重要文件的情况。另外,我也以相同的方式使用 mv(以一个新名称另存该文件,防止意外覆盖现有的文件)和 cp(复制该文件)。
以下是一些我喜欢定义的非常有用的别名:
alias bdump='cd $ORACLE_BASE/admin/$ORACLE_SID/bdump' alias l='ls -d .* --color=tty' alias ll='ls -l --color=tty' alias mv='mv -i' alias oh='cd $ORACLE_HOME' alias os='echo $ORACLE_SID' alias rm='rm -i' alias tns='cd $ORACLE_HOME/network/admin'
要查看 shell 中已定义的别名,使用 alias 即可,无需任何参数。
但这里有一个小问题。我已经定义了一个别名 rm 来执行 rm -i。每次我试图删除一个文件时,该命令都会提示我进行确认。但如果我要删除多个文件并确信无需确认即可删除时,该怎么办?
解决方案很简单:要取消该别名,然后只使用命令,我需要输入两个单引号:
$ ''rm *
注意,rm 命令前面有两个单引号 ('),而不是两个双引号。这将取消别名 rm。另一种方法是使用反斜线 ():
$ rm *
要删除一个以前定义的别名,只需使用 unalias 命令:
$ unalias rm
ls
ls 是简单的常用命令,但几乎从未发挥其全部潜力。如果不加任何选项,则 ls 仅以表格格式显示所有文件和目录。
$ ls admin has mesg precomp apex hs mgw racg assistants install network rdbms ... output snipped ...
要以列表形式显示所有文件和目录,使用 -1 选项(数字 1,不是字母 "l")。
$ ls -1 admin apex assistants ... output snipped ...
在其中的文件名需要传给另一个程序或命令以进行操作的 shell 脚本中,该选项很有用。
您一定使用过用来显示文件和目录所有属性的 -l 选项(字母 "l",不是数字 "1")。让我们再看看它的作用方式:
$ ls -l total 272 drwxr-xr-x 3 oracle oinstall 4096 Sep 3 03:27 admin drwxr-x--- 7 oracle oinstall 4096 Sep 3 02:32 apex drwxr-x--- 7 oracle oinstall 4096 Sep 3 02:29 assistants
第一列显示了文件类型及文件的权限:"d" 代表目录,"-" 代表普通文件,"c" 代表字符设备,"b" 代表块设备,"p" 代表命名管道,"l"(字母 L 的小写形式,不是 I)代表符号链接。
一个非常有用的选项是 --color,它根据文件类型用多种颜色显示文件。注意,file1 和 file2 是普通文件。link1 是符号链接,显示为红色;dir1 是目录,显示为黄色;pipe1 是命名管道,显示为其它颜色以便于识别。
在某些版本中,ls 命令自带预先安装的别名(在上一部分中进行了描述),如 ls --color;,因此您键入 "ls" 时将看到彩色的文件。然而,该方法可能并不符合需要,尤其是当您的输出如上所示时。您可以更改颜色,但只需关闭别名就可以更快地达成您的需要:
$ alias ls="''ls"
另一个有用的选项是 -F 选项,它在每个文件后面添加一个符号来显示文件的类型:在目录后面添加 "/",在符号链接后面添加 "@",在命名管道后面添加 "|"。
$ ls -F dir1/ file1 file2 link1@ pipe1|
如果某个目录下面包含一个子目录,您希望只列出该目录,则 ls -l 还将显示该子目录中的内容。例如,假设该目录结构如下所示:
/dir1 +-->/subdir1 +--> subfile1 +--> subfile2
目录 dir1 含有一个子目录 subdir1 和两个文件:subfile1 和 subfile2。如果您只希望查看目录 dir1 的属性,则执行以下命令:
$ ls -l dir1 total 4 drwxr-xr-x 2 oracle oinstall 4096 Oct 14 16:52 subdir1 -rw-r--r-- 1 oracle oinstall 0 Oct 14 16:48 subfile1 -rw-r--r-- 1 oracle oinstall 0 Oct 14 16:48 subfile2
注意,输出中未列出目录 dir1,而是显示了该目录的内容。处理目录时需要该行为。如果仅希望显示 dir1 目录,则需要使用 -d 命令。
$ ls -dl dir1 drwxr-xr-x 3 oracle oinstall 4096 Oct 14 16:52 dir1
如果您注意以下 ls -l 的输出:
-rwxr-x--x 1 oracle oinstall 10457761 Apr 6 2006 rmanO -rwxr-x--x 1 oracle oinstall 10457761 Sep 23 23:48 rman -rwsr-s--x 1 oracle oinstall 93300507 Apr 6 2006 oracleO -rwx------ 1 oracle oinstall 93300507 Sep 23 23:49 oracle
您会发现文件的大小是用字节显示的。显示小文件时,这样做可能很简单。当文件大小很大时,较长的数字可能难以阅读。此时,使用选项 "-h" 以易读的格式来显示大小就很方便了。
$ ls -lh -rwxr-x--x 1 oracle oinstall 10M Apr 6 2006 rmanO -rwxr-x--x 1 oracle oinstall 10M Sep 23 23:48 rman -rwsr-s--x 1 oracle oinstall 89M Apr 6 2006 oracleO -rwx------ 1 oracle oinstall 89M Sep 23 23:49 oracle
注意文件大小是如何用 M(代表兆字节)、K(代表千字节)等显示的。
$ ls -lr
参数 -r 以相反的顺序显示输出。在该命令中,文件将以相反的字母顺序显示。
$ ls -lR
-R 操作符使 ls 命令以递归方式执行,即进入子目录并显示其中的文件。
如果希望按从大到小的顺序显示文件怎么办?使用 -S 参数即可以实现此操作。
$ ls -lS total 308 -rw-r----- 1 oracle oinstall 52903 Oct 11 18:31 sqlnet.log -rwxr-xr-x 1 oracle oinstall 9530 Apr 6 2006 root.sh drwxr-xr-x 2 oracle oinstall 8192 Oct 11 18:14 bin drwxr-x--- 3 oracle oinstall 8192 Sep 23 23:49 lib
xargs
大多数 Linux 命令都会产生输出:文件列表、字符串列表等。但如果要使用其他某个命令并将前一个命令的输出作为参数该怎么办?例如,file 命令显示文件类型(可执行文件、ascii 文本等);您可以处理输出,使其仅显示文件名,现在您希望将这些名称传递给 ls -l 命令以查看时间戳记。xargs 命令就是用来完成此项工作的。它允许您对输出执行其他某些命令。记住下面这个来自于第 1 部分中的语法:
file -Lz * | grep ASCII | cut -d":" -f1 | xargs ls -ltr让我们来剖析这个命令字符串。第一个, file -Lz *,用于查找是符号链接或者经过压缩的文件。它将输出传递给下一个命令 grep ASCII,该命令在其中搜索 "ASCII" 字符串并产生如下所示的输出:
alert_DBA102.log: ASCII English text alert_DBA102.log.Z: ASCII text (compress'd data 16 bits) dba102_asmb_12307.trc.Z: ASCII English text (compress'd data 16 bits) dba102_asmb_20653.trc.Z: ASCII English text (compress'd data 16 bits)由于我们只对文件名感兴趣,因此我们应用下一个命令 cut -d":" -f1,仅显示第一个字段:
alert_DBA102.log alert_DBA102.log.Z dba102_asmb_12307.trc.Z dba102_asmb_20653.trc.Z
现在,我们希望使用 ls -l 命令,将上述列表作为参数进行传递,一次传递一个。xargs 命令允许您这样做。最后一部分,xargs ls -ltr,用于接收输出并对其执行 ls -ltr 命令,如下所示:
ls -ltr alert_DBA102.log ls -ltr alert_DBA102.log.Z ls -ltr dba102_asmb_12307.trc.Z ls -ltr dba102_asmb_20653.trc.Z
因此,xargs 本身虽然没有多大用处,但在与其他命令相结合时,它的功能非常强大。
下面是另一个示例,我们希望计算这些文件中的行数:
$ file * | grep ASCII | cut -d":" -f1 | xargs wc -l 47853 alert_DBA102.log 19 dba102_cjq0_14493.trc 29053 dba102_mmnl_14497.trc 154 dba102_reco_14491.trc 43 dba102_rvwr_14518.trc 77122 total
(注:上述任务还可用以下命令完成:)
$ wc -l ‘file * | grep ASCII | cut -d":" -f1 | grep ASCII | cut -d":" -f1‘
该 xargs 版本用于阐释概念。Linux 可以用几种方法来完成同一个任务;请使用最适合您的情况的方法。
使用该方法,您可以快速重命名目录中的文件。
$ ls | xargs -t -i mv {} {}.bak
-i 选项告诉 xargs 用每项的名称替换 {}。-t 选项指示 xargs 先打印命令,然后再执行。
另一个非常有用的操作是当您使用 vi 打开要编辑的文件时:
$ file * | grep ASCII | cut -d":" -f1 | xargs vi
该命令使用 vi 逐个打开文件。当您希望搜索多个文件并打开它们进行编辑时,使用该命令非常方便。
它还有几个选项。最有用的可能是 -p 选项,它使操作具有可交互性:
$ file * | grep ASCII | cut -d":" -f1 | xargs -p vi vi alert_DBA102.log dba102_cjq0_14493.trc dba102_mmnl_14497.trc
dba102_reco_14491.trc dba102_rvwr_14518.trc ?...
此处的 xarg 要求您在运行每个命令之前进行确认。如果您按下 "y",则执行命令。当您对文件进行某些可能有破坏且不可恢复的操作(如删除或覆盖)时,您会发现该选项非常有用。
-t 选项使用一个详细模式;它显示要运行的命令,是调试过程中一个非常有帮助的选项。
如果传递给 xargs 的输出为空怎么办?考虑以下命令:
$ file * | grep SSSSSS | cut -d":" -f1 | xargs -t wc -l wc -l 0 $在此处,搜索 "SSSSSS" 后没有匹配的内容;因此 xargs 的输入均为空,如第二行所示(由于我们使用 -t 这个详细选项而产生的结果)。虽然这可能会有所帮助,但在某些情况下,如果没有要处理的内容,您可能希望停止 xargs;如果是这样,可以使用 -r 选项:
$ file * | grep SSSSSS | cut -d":" -f1 | xargs -t -r wc -l $
如果没有要运行的内容,该命令退出。
假设您希望使用 rm 命令(该命令将作为 xargs 命令的参数)删除文件。然而,rm 只能接受有限数量的参数。如果您的参数列表超出该限制怎么办?xargs 的 -n 选项限制单个命令行的参数个数。
下面显示了如何限制每个命令行仅使用两个参数:即使向 xargs ls -ltr 传递五个文件,但每次向 ls -ltr 仅传递两个文件。
$ file * | grep ASCII | cut -d":" -f1 | xargs -t -n2 ls -ltr ls -ltr alert_DBA102.log dba102_cjq0_14493.trc -rw-r----- 1 oracle dba 738 Aug 10 19:18 dba102_cjq0_14493.trc -rw-r--r-- 1 oracle dba 2410225 Aug 13 05:31 alert_DBA102.log ls -ltr dba102_mmnl_14497.trc dba102_reco_14491.trc -rw-r----- 1 oracle dba 5386163 Aug 10 17:55 dba102_mmnl_14497.trc -rw-r----- 1 oracle dba 6808 Aug 13 05:21 dba102_reco_14491.trc ls -ltr dba102_rvwr_14518.trc -rw-r----- 1 oracle dba 2087 Aug 10 04:30 dba102_rvwr_14518.trc
使用该方法,您可以快速重命名目录中的文件。
$ ls | xargs -t -i mv {} {}.bak
-i 选项告诉 xargs 用每项的名称替换 {}。
rename
正如您所知道的那样,mv 命令对文件进行重命名。例如,
$ mv oldname newname将 oldname 文件重命名为 newname。但如果您不知道文件名,那该怎么办? rename 命令在此处就可以大显身手了。
rename .log .log.‘date +%F-%H:%M:%S‘ *
用 .log. 替换所有扩展名为 .log 的文件。因此,sqlnet.log 变为 sqlnet.log.2006-09-12-23:26:28。
find
最受 Oracle 用户欢迎的命令之一是 find 命令。到目前为止,您了解了如何使用 find 在给定目录中查找文件。下面的示例显示在当前目录中查找以单词 "file" 开头的文件:
$ find . -name "file*" ./file2 ./file1 ./file3 ./file4
然而,如果您希望搜索 FILE1、FILE2 等名称怎么办?-name "file*" 不会与之匹配。对于区分大小写的搜索,可以使用 -iname 选项:
$ find . -iname "file*" ./file2 ./file1 ./file3 ./file4 ./FILE1 ./FILE2
您可以限制搜索范围,仅搜索特定类型的文件。例如,上述命令将获得所有类型的文件:普通文件、目录、符号链接等。如果仅搜索普通文件,可使用 -type f 参数。
$ find . -name "orapw*" -type f ./orapw+ASM ./orapwDBA102 ./orapwRMANTEST ./orapwRMANDUP ./orapwTESTAUX
-type 可以接受修饰符 f(普通文件)、l(符号链接)、d(目录)、b(块设备)、p(命名管道)、c(字符设备)、s(套接字)。
对上述命令的一个小技巧是,将其与您在第 1 部分中学到的 file 命令相结合。file 命令告诉您文件的类型。您可以将其作为 find 命令的输出的后处理器进行传递。-exec 参数执行该参数后面的命令。在该示例中,在 find 后执行的命令是 file:
$ find . -name "*oraenv*" -type f -exec file {} ; ./coraenv: Bourne shell script text executable ./oraenv: Bourne shell script text executable
当您希望弄清楚 ASCII 文本文件是否可能是某种类型的 shell 脚本时,该命令非常有用。
如果您用 -ok 替换 -exec,则执行该命令之前要求您先进行确认。下面就是一个例子:
$ find . -name "sqlplus*" -ok {} ; < {} ... ./sqlplus > ? y SQL*Plus
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/174388/viewspace-903164/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/174388/viewspace-903164/