BBED在Oracle 10g/11g上安裝筆記
Oracle BBED(Oracle Block Browser and Editor)工具是Oracle內部提供的資料塊級別檢視和修改工具。藉助這個工具,我們可以方便的檢視到Oracle塊block級別的儲存細節資訊,更好的瞭解Oracle Internal結構技術細節。
1、環境介紹
首先,要說明BBED是非Oracle推薦使用的工具,只提供給內部進行恢復處理使用,對外是不提供任何資料和相關技術支援。所以,我們如果計劃使用該工具,特別是在生產環境下使用,都是我們的最後選擇方案。一定要在有備份能恢復的時候進行使用,否則貿然使用BBED,容易造成資料庫啟動失敗或者更嚴重的問題。
BBED提供的版本中,只有Linux/Unix,在Windows上是沒有對應版本的。索引使用BBED的環境通常是命令列方式。而且BBED在Oracle內部是沒有提供編譯好的現成版本,需要我們手工性編譯連結操作。
本篇分別針對Oracle 10g和11g上編譯BBED方法進行記錄,權當一個備忘。
2、Oracle 10g下編譯BBED
本方法適用於Oracle 10g以及之前的可見版本。
首先檢視系統中相關環境變數,定位到BBED的庫檔案目錄。
[oracle@oracle10g ~]$ env | grep ORACLE
ORACLE_SID=wilson
ORACLE_BASE=/u01
ORACLE_HOME=/u01/oracle
BBED對應的物件object檔案通常是在$ORACLE_HOME/rdbms/lib裡。
[oracle@oracle10g ~]$ cd $ORACLE_HOME/rdbms/lib
[oracle@oracle10g lib]$ pwd
/u01/oracle/rdbms/lib
之後,使用Linux系統的make命令進行編譯和連線,生成執行程式bbed。
[oracle@oracle10g lib]$ make -f ins_rdbms.mk $ORACLE_HOME/rdbms/lib/bbed
Linking BBED utility (bbed)
rm -f /u01/oracle/rdbms/lib/bbed
gcc -o /u01/oracle/rdbms/lib/bbed -L/u01/oracle/rdbms/lib/ -L/u01/oracle/lib/ -L/u01/oracle/lib/stubs/ -L/usr/lib -lirc /u01/oracle/lib/s0main.o /u01/oracle/rdbms/lib/ssbbded.o /u01/oracle/rdbms/lib/sbbdpt.o `cat /u01/oracle/lib/ldflags` -lnsslb10 -lncrypt10 -lnsgr10 -lnzjs10 -ln10 -lnnz10 -lnl10 /u01/oracle/rdbms/lib/defopt.o -ldbtools10 -lclntsh `cat /u01/oracle/lib/ldflags` -lnsslb10 -lncrypt10 -lnsgr10 -lnzjs10 -ln10 -lnnz10 -lnl10 -lnro10 `cat /u01/oracle/lib/ldflags` -lnsslb10 -lncrypt10 -lnsgr10 -lnzjs10 -ln10 -lnnz10 -lnl10 -lclient10 -lnnetd10 -lvsn10 -lcommon10 -lgeneric10 -lmm -lsnls10 -lnls10 -lcore10 -lsnls10 -lnls10 -lcore10 -lsnls10 -lnls10 -lxml10 -lcore10 -lunls10 -lsnls10 -lnls10 -lcore10 -lnls10 `cat /u01/oracle/lib/ldflags` -lnsslb10 -lncrypt10 -lnsgr10 -lnzjs10 -ln10 -lnnz10 -lnl10 -lnro10 `cat /u01/oracle/lib/ldflags` -lnsslb10 -lncrypt10 -lnsgr10 -lnzjs10 -ln10 -lnnz10 -lnl10 -lclient10 -lnnetd10 -lvsn10 -lcommon10 -lgeneric10 -lsnls10 -lnls10 -lcore10 -lsnls10 -lnls10 -lcore10 -lsnls10 -lnls10 -lxml10 -lcore10 -lunls10 -lsnls10 -lnls10 -lcore10 -lnls10 -lclient10 -lnnetd10 -lvsn10 -lcommon10 -lgeneric10 -lsnls10 -lnls10 -lcore10 -lsnls10 -lnls10 -lcore10 -lsnls10 -lnls10 -lxml10 -lcore10 -lunls10 -lsnls10 -lnls10 -lcore10 -lnls10 `cat /u01/oracle/lib/sysliblist` -Wl,-rpath,/u01/oracle/lib -lm `cat /u01/oracle/lib/sysliblist` -ldl -lm -L/u01/oracle/lib
就可以檢視到生成的可執行檔案bbed。
[oracle@oracle10g lib]$ ls -l bbed
-rwxr-xr-x 1 oracle oinstall 540313 Jun 16 09:15 bbed
通常將bbed複製到目錄$ORACLE_HOME/bin目錄下,因為該目錄是被加入到PATH環境變數裡,系統全域性各個位置都能訪問到。之後,就是構建常用的引數檔案一類的內容。
[oracle@oracle10g lib]$ cp bbed $ORACLE_HOME/bin
[oracle@oracle10g bin]$ ls -l bbed
-rwxr-xr-x 1 oracle oinstall 540313 Jun 16 09:20 bbed
[oracle@oracle10g bin]$ cat par.txt
blocksize=8192
listfile=filelist.txt
mode=edit
嘗試啟動BBED。
[oracle@oracle10g bin]$ bbed
Password:
BBED: Release 2.0.0.0.0 - Limited Production on Thu Jun 16 09:23:18 2011
Copyright (c) 1982, 2005, Oracle. All rights reserved.
************* !!! For Oracle Internal Use only !!! ***************
BBED>
安裝成功!
3、Oracle11g下BBED的使用
Oracle10g以及以前的版本,用上述的方法就可以使用了。但是在Oracle11g中,還是需要一些額外處理才可以。根本的原因在於編譯11g下BBED的時候,會報出庫obj檔案缺失的錯誤。
解決的思路也很簡單,就是從Oracle10g下對應的obj檔案複製出,放置在11g下就可以了。
從oracle10g的$ORACLE_HOME/rdbms/lib中,複製ssbbded.o, sbbdpt.o
$ORACLE_HOME/rdbms/msg中,複製bbedus.msb
在11g下:
[oracle@bspdev ~]$ cd $ORACLE_HOME/rdbms/lib
[oracle@bspdev lib]$ pwd
/u01/app/oracle/rdbms/lib
[oracle@bspdev lib]$
編譯過程相似:
[oracle@bspdev lib]$ make -f ins_rdbms.mk $ORACLE_HOME/rdbms/lib/bbed
Linking BBED utility (bbed)
rm -f /u01/app/oracle/rdbms/lib/bbed
gcc -o /u01/app/oracle/rdbms/lib/bbed -m32 -L/u01/app/oracle/rdbms/lib/ -L/u01/app/oracle/lib/ -L/u01/app/oracle/lib/stubs/ -L/u01/app/oracle/lib/ -lirc -lipgo /u01/app/oracle/lib/s0main.o /u01/app/oracle/rdbms/lib/ssbbded.o /u01/app/oracle/rdbms/lib/sbbdpt.o `cat /u01/app/oracle/lib/ldflags` -lncrypt11 -lnsgr11 -lnzjs11 -ln11 -lnl11 -ldbtools11 -lclntsh `cat /u01/app/oracle/lib/ldflags` -lncrypt11 -lnsgr11 -lnzjs11 -ln11 -lnl11 -lnro11 `cat /u01/app/oracle/lib/ldflags` -lncrypt11 -lnsgr11 -lnzjs11 -ln11 -lnl11 -lnnz11 -lzt11 -lztkg11 -lclient11 -lnnetd11 -lvsn11 -lcommon11 -lgeneric11 -lmm -lsnls11 -lnls11 -lcore11 -lsnls11 -lnls11 -lcore11 -lsnls11 -lnls11 -lxml11 -lcore11 -lunls11 -lsnls11 -lnls11 -lcore11 -lnls11 `cat /u01/app/oracle/lib/ldflags` -lncrypt11 -lnsgr11 -lnzjs11 -ln11 -lnl11 -lnro11 `cat /u01/app/oracle/lib/ldflags` -lncrypt11 -lnsgr11 -lnzjs11 -ln11 -lnl11 -lclient11 -lnnetd11 -lvsn11 -lcommon11 -lgeneric11 -lsnls11 -lnls11 -lcore11 -lsnls11 -lnls11 -lcore11 -lsnls11 -lnls11 -lxml11 -lcore11 -lunls11 -lsnls11 -lnls11 -lcore11 -lnls11 -lclient11 -lnnetd11 -lvsn11 -lcommon11 -lgeneric11 -lsnls11 -lnls11 -lcore11 -lsnls11 -lnls11 -lcore11 -lsnls11 -lnls11 -lxml11 -lcore11 -lunls11 -lsnls11 -lnls11 -lcore11 -lnls11 `cat /u01/app/oracle/lib/sysliblist` -Wl,-rpath,/u01/app/oracle/lib -lm `cat /u01/app/oracle/lib/sysliblist` -ldl -lm -L/u01/app/oracle/lib
編譯成功,之後同樣是複製到指定的$ORACLE_HOME/bin目錄下即可使用。
4、結論
Oracle BBED是一個小巧而強大的內部使用工具,對我們瞭解Oracle結構可以起到很大作用。但在研究Oracle的漫長道路上,任何工具都只是手段,都是我們資料庫知識應用體現的途徑。希望我們都不會捨本逐末!
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/17203031/viewspace-700204/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle 11G 安裝 bbed 工具Oracle
- oracle之 11.2.0.4 bbed安裝Oracle
- centos7.3上安裝oracle xe 11gCentOSOracle
- ISO 映象安裝oracle 10gOracle 10g
- Oracle bbed一鍵安裝工具分享Oracle
- Oracle 11G 安裝文件Oracle
- 在 Debian 上安裝 IntelliJ IDEA 筆記(含 JDK 的安裝)IntelliJIdea筆記JDK
- oracle 10g在linux下的安裝及簡單命令Oracle 10gLinux
- Oracle 11G RAC叢集安裝(3)——安裝OracleOracle
- 在Oracle Linux 7.1上安裝DockerOracleLinuxDocker
- Oracle Linux 6.7 靜預設安裝Oracle 11gOracleLinux
- windows2008R2安裝oracle 10gWindowsOracle 10g
- 在FC5上安裝oracle 9204Oracle
- Linux下Oracle 11.2.0.1 RAC安裝筆記LinuxOracle筆記
- BBED 的安裝
- CentOS 7.5靜默安裝Oracle 11gCentOSOracle
- Oracle 11G RAC叢集安裝(2)——安裝gridOracle
- Oracle:Redhat 7 + Oracle RAC 11g 安裝 bug 總結OracleRedhat
- 靜默方式安裝oracle 11g 完整攻略Oracle
- 靜默安裝Oracle資料庫11gOracle資料庫
- Oracle 10g 在linux redhat as4 系統安裝圖解全過程Oracle 10gLinuxRedhat圖解
- oracle監聽檔案listener.ora for 10g/11gOracle
- 通過ORACLE VM virtualbox環境安裝oracle 11G RAC(ASM)OracleASM
- Oracle 11G資料庫單例項安裝Oracle資料庫單例
- oracle 11g RAC 安裝前準備指令碼Oracle指令碼
- Oracle從10g升級到11g詳細步驟Oracle
- Oracle 11G RAC叢集安裝(1)——安裝前的準備Oracle
- Linux 筆記分享十四:YUM 線上安裝Linux筆記
- oracle 11g 單例項資料庫的安裝Oracle單例資料庫
- 超詳細oracle 11g安裝步驟 win版本Oracle
- Manjaro安裝筆記JAR筆記
- [20210311]如何建立bbed安裝包.txt
- 【靜默】在RHEL 6.5上靜默安裝Oracle 18cOracle
- 在Centos 上安裝oracle-database-preinstall-19c軟體包CentOSOracleDatabase
- Intel MKL 在VS中的配置與安裝筆記Intel筆記
- TensorRT 筆記 - 在 Conda 虛擬環境中安裝筆記
- 【安裝】安裝centos79的筆記CentOS筆記
- 在CentOS上安裝dockerCentOSDocker
- 在Windows上安裝MavenWindowsMaven