UNIX裡有數百條用來管理Oracle的命令。現在讓我們看看一些UNIX的技巧,它們對於Oracle專家來說是特別有用的。
定位UNIX服務器上任意位置的文件
你可以使用UNIX的find命令來定位某個特定的文件。
root> pwd
/
root> find . -print|grep -idbmspool.sql
./Oracle/product/9.1.2/rdbms/admin/dbmspool.sql
找到包含有特定字符串的Oracle文件
這是一個用於找到所有包含有指定字符串的最常用的外殼命令。例如,假設你正在試圖定位一個查詢V$PROCESS表格的腳本。
你可以使用下面的命令,UNIX會搜索所有的子目錄,在所有文件裡尋找V$PROCESS表格。
root> find . -print|xargsgrep v\$process
./TX_RBS.sql: v$process p,
./UNIX_WHO.sql:from v$session a, v$process b
./session.sql:fromv$session b, v$process a
定位最近創建的UNIX文件
下面的命令對於找到最近添加到你服務器裡的UNIX文件很有用。Oracle數據庫管理員的一部分任務是監測用來追蹤文件的BACKGROUND_DUMP_DEST和USER_DUMP_DEST,以及清除掉不再需要的追蹤文件。
下面的命令會列出在最近兩周裡創建的所有文件。
root> find . -mtime -14 -print
.
./janet1_ora_27714.trc
./janet1_ora_27716.trc
在UNIX服務器裡找到大型文件
下面的命令在UNIX文件系統被填滿的時候非常有用。正如你可能知道的,在Oracle必須展開一個表格空間卻無法擴展UNIX文件系統的時候,Oracle會掛起。
下面的腳本會顯示所有大於1MB的文件。要注意,你要預先將大小參數指定為KB。
root> find . -size +1024 -print
./prodsid_ora_22951.trc
獲得當前$ORACLE_HOME裡已安裝的Oracle產品的列表
下面的命令對於定位在你Oracle環境裡所有已安全的產品很有用。
cat $Oracle_HOME/unix.prd |\
nawk -F\" '{ printf ("%-40s %-10s %-20s\n", $6, $2, $4) }' |\
grep '^[^ ]'