一配置基礎環境linux
先對操做系統進行一次全面的更新c++
#yum updatesql
對oracle依賴包進行安裝和升級數據庫
#yum -y install \vim
binutils \安全
compat-libcap1 \bash
compat-libstdc++-33 \oracle
compat-libstdc++-33*.i686 \app
elfutils-libelf-devel \tcp
gcc \
gcc-c++ \
glibc*.i686 \
glibc \
glibc-devel \
glibc-devel*.i686 \
ksh \
libgcc*.i686 \
libgcc \
libstdc++ \
libstdc++*.i686 \
libstdc++-devel \
libstdc++-devel*.i686 \
libaio \
libaio*.i686 \
libaio-devel \
libaio-devel*.i686 \
make \
sysstat \
unixODBC \
unixODBC*.i686 \
unixODBC-devel \
unixODBC-devel*.i686 \
libXp
修改主機名,編輯netework文件,文件若是使用vim或者vi打開,修改以後保存(先按ESC鍵,以後輸入「:wq」,若是不想保存就先按ESC鍵,以後輸入「:q!」)
#vi/etc/sysconfig/network
修改主機名爲oracledb(可根據實際狀況改動)
重啓生效(重啓後需等待一會才能鏈接上)
#reboot
查看主機名,顯示oracledb,更改爲功
#hostname
添加主機名與IP對應記錄
#vi/etc/hosts
添加xx.xx.xx.xx oracledb 修改以後保存(先按ESC鍵,以後輸入「:wq」,回車)
關閉selinux
#setenforce 0
建立所需的操做系統組和用戶(這裏組名爲oinstall、dba,用戶名爲oracle,可根據實際狀況改動)
#groupaddoinstall && groupadd dba && useradd -g oinstall -G dba oracle
設置oracle用戶密碼(密碼本身定義,密碼安全性第一)
#passwdoracle
二 準備安裝文件
建立安裝目錄(可根據狀況,選擇比較多空間的目錄建立)
#mkdir -p /u01/app/
上傳oracle安裝文件上傳到/u01下
修改/u01目錄下設置oracle用戶權限
#chown -R oracle:oinstall /u01&& chmod -R 775 /u01/app/
建立/etc/oraInst.loc文件,內容以下(這個文件是不存在的,直接編輯就行)
#vi /etc/oraInst.loc 添加下面兩行
inventory_loc=/u01/app/oracle/oraInventory
inst_group=oinstall
修改以後保存(先按ESC鍵,以後輸入「:wq」,回車)
更改文件的權限
chown oracle:oinstall /etc/oraInst.loc&& chmod 664 /etc/oraInst.loc
解壓oracle安裝文件(oracle用戶執行)
#su - oracle
cd /u01
unzip linux.x64_11gR2_database_1of2.zip
unzip linux.x64_11gR2_database_2of2.zip
設置oracle環境變量,編輯~/.bash_profile文件
#vi ~/.bash_profile
在最後加上如下內容
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
exportPATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin$PATH:$ORACLE_HOME/bin
export ORACLE_SID=orcl
修改以後保存(先按ESC鍵,以後輸入「:wq」,回車)
使設置生效
source ~/.bash_profile
拷貝模板文件,進行受權
cp /u01/database/response/db_install.rsp/u01/database
chmod +x /u01/database/db_install.rsp
三 靜默安裝Oracle
修改安裝Oracle軟件的響應文件/u01/database/db_install.rsp
#vi /u01/database/db_install.rsp
oracle.install.option=INSTALL_DB_SWONLY// 安裝類型
ORACLE_HOSTNAME=oracledb // 主機名稱
UNIX_GROUP_NAME=oinstall // 安裝組
INVENTORY_LOCATION=/u01/app/oracle/oraInventory// INVENTORY目錄
SELECTED_LANGUAGES=en,zh_CN // 選擇語言
ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1// oracle_home
ORACLE_BASE=/u01/app/oracle //oracle_base
oracle.install.db.InstallEdition=EE //oracle版本
oracle.install.db.EEOptionsSelection=true
oracle.install.db.DBA_GROUP=dba // dba用戶組
oracle.install.db.OPER_GROUP=oinstall// oper用戶組
DECLINE_SECURITY_UPDATES=true
oracle.installer.autoupdates.option =SKIP_UPDATES
修改以後保存(先按ESC鍵,以後輸入「:wq」,回車)
切換到剛剛解壓的database目錄,進行安裝
#cd /u01/database
查看目錄下文件是否有db_install.rsp文件
#ls查看
開始靜默安裝oracle(執行完命令查看日誌)
#./runInstaller -silent -responsefile/u01/database/db_install.rsp -ignoresysprereqs -ignoreprereq
安裝中,若是提示[WARNING]沒必要理會,此時安裝程序仍在進行,若是出現[FATAL],則安裝程序已經中止了。
查看安裝日誌信息瞭解安裝進度
tail -f$ORACLE_BASE/oraInventory/logs/installActions*.log
出現相似以下提示表示安裝完成:
#-------------------------------------------------------------------
...
/u01/app/oracle/product/11.2.0/db_1/root.sh
To executethe configuration scripts:
1. Open aterminal window
2. Log in as"root"
3. Run thescripts
4. Return tothis window and hit "Enter" key to continue
SuccessfullySetup Software.
#-------------------------------------------------------------------
執行腳本文件,須要使用root用戶執行root.sh
#su - root
#/u01/app/oracle/product/11.2.0/db_1/root.sh
四安裝數據庫
創建數據庫(安裝前務必閱讀使用參數說明,根據本身實際狀況更改參數)
#dbca -h //查看幫助
#/u01/app/oracle/product/11.2.0/db_1/assistants/dbca/templates/General_Purpose.dbc-gdbName orcl -sid orcl -sysPassword xxxxx -systemPassword xxxxx -emConfiguration xxxxx -dbsnmpPassword xxxxxx-sysmanPassword xxxxx -characterSet AL32UTF8
使用參數說明:
-silent指以靜默方式執行dbca命令
-createDatabase指使用dbca
-templateName指定用來建立數據庫的模板名稱,這裏指定爲/u01/app/oracle/product/11.2.0/db_1/assistants/dbca/templates/General_Purpose.dbc,即通常用途的數據庫模板
-gdbName指定建立的全局數據庫名稱,這裏指定名稱爲orcl
-sid 指定數據庫系統標識符,這裏指定爲orcl,與數據庫同名
-sysPassword SYS 用戶口令設置爲oracle
-systemPassword SYSTEM 用戶口令設置爲oracle
-emConfiguration 指定Enterprise Management的管理選項。LOCAL表示數據庫由Enterprise Manager本地管理
-dbsnmpPassword DBSNMP 用戶口令設置爲oracle
-sysmanPassword SYSMAN 用戶口令設置爲oracle
-characterSet指定數據庫使用的字符集,這裏指定爲al32utf8
執行命令,檢查安裝,顯示以下:(100%進度很是快,有可能安裝失敗)
//開始安裝
Copyingdatabase files
1% complete
37% complete
Creating andstarting Oracle instance
40% complete
62% complete
CompletingDatabase Creation
66% complete
100% complete
Look at thelog file "/u01/app/oracle/cfgtoollogs/dbca/orcl/orcl.log" for furtherdetails.//安裝結束
# 檢查安裝
# lsnrctlstatus
安裝成功則最終會顯示:The command completed successfully
修改oracle啓動配置文件
#vi/etc/oratab
racl:/u01/app/oracle/product/11.2.0/db_1:Y//把「N」改爲「Y」
$ORACLE_SID:$ORACLE_HOME:Y:
設置Y能夠經過dbstart 啓動此實例,監聽器。
第一種啓動方法:
開啓全部oracle的進程,啓動監聽器。(開數據庫)
dbstart$ORACLE_HOME
關閉全部oracle的進程,中止監聽器。 (關數據庫)
dbshut$ORACLE_HOME
第二種啓動方法:
#lsnrctlstatus查看監聽器狀態
#lsnrctl stop中止監聽
#sqlplus / assysdba進入數據庫
#SQL>shutdown immediate; 中止數據庫
#SQL>exit 退出數據庫
#lsnrctlstart開啓監聽
#sqlplus / assysdba進入數據庫
#SQL>startup;啓動數據庫
#SQL>select open_mode from v$database; 查詢實例狀態
OPEN_MODE
------------------
READ WRITE
顯示READ WRITE
Oracle數據庫啓動成功!!!
五建立鏈接用戶
//建立用戶(這裏建立的用戶會在應用的數據庫鏈接文件中用到,牢記!!!)
SQL>createuser 用戶 identifiedby 密碼;
//給用戶受權
SQL>grantconnect,dba,resource to 用戶;
六歸檔檢查
sqlplus / as sysdba
SQL> shutdown immediate;
SQL> startup mount;
SQL> alter database archivelog;
SQL> alter database flashback on; (若是要啓用數據庫閃回功能則執行)
SQL> alter database open;
SQL> execute utl_recomp.recomp_serial();(從新編譯全部可能失效對象)
SQL> alter system archive log current; (手工歸檔測試)
七數據的導入
/////////////////////////////////////////////////////////////////////////////////////
###############導入數據start#################
使用expdp導出表,(注意若是使用expdp導出的數據只能使用impdp導入,下面用到的用戶密碼根據實際狀況變更)
建立導出目錄
#mkdir /home/oracle/dump/utrmdb
SQL>create directory dump_utrm as '/home/oracle/dump/utrmdb/';
SQL>select * from dba_directories;
SQL> grantread,write on directory dump_utrm to 用戶;
expdp 用戶/密碼 directory=dump_utrm dumpfile=文件名.dmp logfile=文件名.log
使用impdp導入表
mkdir/u01/utrm
chmod +x/u01/utrm/dump_201612131650.dmp
SQL>create directory dump_ut as ‘/u01/utrmdb’;
SQL>select * from dba_directories;
SQL> grantread,write on directory dump_ut to用戶;
impdp用戶/密碼_db directory=dump_ut dumpfile=文件名.dmp logfile=文件名.log full=y
###############導入數據stop#################
//////////////////////////////////////////////////////////////////////////////////////
八查看監聽狀態
#lsnrctl status
###################################
------------------------
Alias LISTENER
Version TNSLSNR for Linux: Version 11.2.0.1.0 - Production
Start Date 28-OCT-2016 18:12:21
Uptime 51 days 16 hr. 8 min. 45 sec
Trace Level off
Security ON: Local OS Authentication
SNMP OFF
Listener Parameter File /oracle/product/11g/db_1/network/admin/listener.ora
Listener Log File /oracle/diag/tnslsnr/master/listener/alert/log.xml
Listening Endpoints Summary...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=master)(PORT=1521)))
Services Summary...
Service "orcl" has 1 instance(s).
Instance "orcl", status READY, has 1 handler(s) for this service...
Service "orclXDB" has 1 instance(s).
Instance "orcl", status READY, has 1 handler(s) for this service...
The command completed successfully
###################################
顯示相似上分的文字就大功告成了!!!