CentOS 7.4下安裝Oracle 11.2.0.4數(shù)據(jù)庫

在Linux下安裝Oracle數(shù)據(jù)庫是一件較為麻煩的事情惩坑。

由于Linux的安裝過程中可能會選擇不同的安裝包哄褒,會導(dǎo)致Oracle安裝過程中缺失或多一些軟件包距辆,很難一次性的安裝成功。所以堤舒,本文詳細記錄了Oracle在Linux上的安裝過程踢京,以供參考誉碴。

本環(huán)境僅供軟件開發(fā)和測試環(huán)境使用,并不適合用于生產(chǎn)環(huán)境瓣距。

Oracle官方支持的Linux發(fā)行版本有RedHat和Oracle Linux黔帕,所以,我們在CentOS(7.4)下安裝Oracle(11gR2)時蹈丸,還需要做一些特別的準備工作成黄。

本文的CentOS 7.4使用官網(wǎng)上下載的CentOS-7-x86_64-DVD-1708.iso文件安裝,安裝時選擇Server with GUI白华,并選擇FTP Server慨默。語言使用英語。

選擇安裝包

為了日常使用方便弧腥,執(zhí)行命令systemctl set-default multi-user.target厦取,讓linux啟動后,直接進入字符界面管搪。

本文的Oracle數(shù)據(jù)庫使用的是11.2.0.4(這個版本適配紅帽7虾攻,官網(wǎng)免費下載的版本并不適用于紅帽7)。

附下載地址更鲁,請使用迅雷下載即可霎箍。

https://updates.oracle.com/Orion/Services/download/p13390677_112040_Linux-x86-64_1of7.zip?aru=16716375&patch_file=p13390677_112040_Linux-x86-64_1of7.zip
https://updates.oracle.com/Orion/Services/download/p13390677_112040_Linux-x86-64_2of7.zip?aru=16716375&patch_file=p13390677_112040_Linux-x86-64_2of7.zip
https://updates.oracle.com/Orion/Services/download/p13390677_112040_Linux-x86-64_3of7.zip?aru=16716375&patch_file=p13390677_112040_Linux-x86-64_3of7.zip
https://updates.oracle.com/Orion/Services/download/p13390677_112040_Linux-x86-64_4of7.zip?aru=16716375&patch_file=p13390677_112040_Linux-x86-64_4of7.zip
https://updates.oracle.com/Orion/Services/download/p13390677_112040_Linux-x86-64_5of7.zip?aru=16716375&patch_file=p13390677_112040_Linux-x86-64_5of7.zip
https://updates.oracle.com/Orion/Services/download/p13390677_112040_Linux-x86-64_6of7.zip?aru=16716375&patch_file=p13390677_112040_Linux-x86-64_6of7.zip
https://updates.oracle.com/Orion/Services/download/p13390677_112040_Linux-x86-64_7of7.zip?aru=16716375&patch_file=p13390677_112040_Linux-x86-64_7of7.zip

1. 關(guān)閉防火墻

由于是開發(fā)測試環(huán)境,為了方便澡为,將防火墻關(guān)閉漂坏。但是,在正式的生產(chǎn)環(huán)境,千萬不要這樣做顶别。

首先執(zhí)行命令systemctl status firewalld.service檢查防火墻狀態(tài)谷徙,

檢查防火墻狀態(tài)

然后,執(zhí)行命令systemctl stop firewalld.service關(guān)閉防火墻驯绎。

當(dāng)然完慧,我們可以執(zhí)行命令systemctl disable firewalld.service,禁用防火墻剩失。

禁用防火墻

2. 關(guān)閉selinux

selinux提供了很多Linux的系統(tǒng)安全措施屈尼,演示系統(tǒng)中,將其關(guān)閉拴孤,方便操作脾歧。需要注意的是,在正式生產(chǎn)環(huán)境下演熟,也千萬不要這樣做涨椒。

執(zhí)行命令getenforce查看selinux的狀態(tài),初始安裝的CentOS7是打開狀態(tài)绽媒。

執(zhí)行命令vi /etc/selinux/config,編輯文件免猾,配置SELINUX=disabled是辕,關(guān)閉selinux。

3. 為yum配置阿里源

在安裝Oracle的過程中猎提,需要安裝一些依賴包获三。為了加快安裝速度,最好將yum源更新為國內(nèi)的锨苏,首推阿里yum源疙教。

  1. 執(zhí)行命令cd /etc/yum.repos.d/,然后執(zhí)行命令wget http://mirrors.aliyun.com/repo/Centos-7.repo下載阿里yum源伞租。

  2. 執(zhí)行命令mv CentOS-Base.repo CentOS-Base.repo.bak備份現(xiàn)有源信息贞谓。

  3. 執(zhí)行命令mv Centos-7.repo CentOS-Base.repo,使用上一步中下載回來的阿里yum源葵诈。

  4. 依次執(zhí)行命令yum clean all裸弦、yum makecacheyum update,更新yum源作喘。

4. (可選)為虛擬機生成快照

為了保險起見理疙,為虛擬機生成一份快照,避免后續(xù)安裝出錯泞坦,重頭再來安裝操作系統(tǒng)窖贤。

5. 創(chuàng)建數(shù)據(jù)庫目錄

創(chuàng)建Oracle數(shù)據(jù)庫的安裝目錄到/opt下。

  1. 執(zhí)行命令mkdir -p /opt/oracle,創(chuàng)建oracle安裝目錄赃梧;

  2. 執(zhí)行命令mkdir -p /opt/oraInventory滤蝠,創(chuàng)建oracle數(shù)據(jù)庫配置文件目錄;

  3. 執(zhí)行命令chown -R oracle:oinstall /opt/oracle槽奕,設(shè)置oracle為目錄的所有者几睛;

  4. 執(zhí)行命令chown -R oracle:oinstall /opt/oraInventory,設(shè)置oracle為目錄的所有者粤攒。

6. 創(chuàng)建用戶和用戶組

Oracle安裝過程中所森,需要使用固定的用戶和用戶組。

  1. 執(zhí)行命令groupadd oinstall夯接,創(chuàng)建oinstall用戶組焕济;

  2. 執(zhí)行命令groupadd dba,創(chuàng)建dba用戶組盔几;

  3. 執(zhí)行命令useradd -g oinstall -g dba -m oracle晴弃,創(chuàng)建oracle用戶;

  4. 執(zhí)行命令passwd oracle逊拍,為oracle用戶設(shè)置密碼上鞠,為了好記密碼為123456;

  5. 執(zhí)行命令id oracle芯丧,查看剛剛創(chuàng)建的oracle用戶信息芍阎。

創(chuàng)建用戶組及用戶

執(zhí)行命令vi /home/oracle/.bash_profile,添加如下內(nèi)容缨恒,為oracle用戶設(shè)置環(huán)境變量谴咸。

export ORACLE_BASE=/opt/oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1
export ORACLE_SID=orcl
export ORACLE_TERM=xterm
export PATH=$ORACLE_HOME/bin:/usr/sbin:$PATH
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
export LANG=C
export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK

執(zhí)行命令source /home/oracle/.bash_profile,讓配置立即生效骗露。

7. 對oracle用戶設(shè)置限制

為了提高軟件運行性能岭佳,需要對oracle用戶設(shè)置限制。

執(zhí)行命令vi /etc/security/limits.conf萧锉,添加如下內(nèi)容:

oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536

驗證最新版的PAM 已經(jīng)被加載珊随,如果不存在的話,在 /etc/pam.d/login 文件中添加如下內(nèi)容:

session required pam_limits.so

驗證當(dāng)前的ulimits驹暑,并啟用玫恳。 這個可以通過很多方式來做, 在/etc/profile添加如下內(nèi)容是推薦的方式:

if [ $USER = "oracle" ]; then  
    if [ $SHELL = "/bin/ksh" ]; then  
       ulimit -u 16384   
       ulimit -n 65536  
    else  
       ulimit -u 16384 -n 65536  
    fi  
fi

8. 修改OS系統(tǒng)標識

Oracle數(shù)據(jù)庫支持在紅帽和Oracle Linux上安裝优俘,不支持在CentOS上安裝京办,所以需要修改OS系統(tǒng)標識為紅帽。

執(zhí)行命令vi /etc/redhat-release帆焕,修改系統(tǒng)標識為redhat-7惭婿。

9. 修改內(nèi)核參數(shù)

部分參數(shù)不恭,在Oracle安裝過程中,可自動修復(fù)(使用root用戶執(zhí)行Oracle安裝程序給出的修復(fù)腳本)财饥,但是有部分不能自動修復(fù)换吧。

執(zhí)行命令vi /etc/sysctl.conf

修改的內(nèi)核參數(shù)如下:

kernel.shmall = 2097152
kernel.sem = 250 32000 100 128
fs.file-max = 6815744
net.ipv4.ip_local_port_range = 9000 65500
net.core.rmem_default = 262144
net.core.wmem_default = 262144
net.core.rmem_max = 4194304
net.core.wmem_max = 1048576
kernel.shmmax = 2079272960
kernel.shmmni = 4096
fs.aio-max-nr = 1048576

執(zhí)行命令sysctl -p,使修改的內(nèi)核參數(shù)生效钥星。

10. 安裝依賴的軟件包

Oracle11gR2在CentOS7.4上安裝沾瓦,缺少如下19個包,需要執(zhí)行命令yum install -y gcc libaio glibc.i686 compat-libstdc++-33 compat-libstdc++-33.i686 elfutils-libelf-devel glibc-devel glibc-headers gcc-c++ libaio-devel libaio-devel.i686 libgcc.i686 libstdc++ libstdc++.i686 unixODBC unixODBC.i686 unixODBC-devel unixODBC-devel.i686 ksh谦炒,來安裝需要的19個依賴包贯莺。

針對pdksh找不到的問題,可安裝ksh即可宁改。據(jù)說oracle使用新的ksh了缕探,但是檢查腳本中還使用的是pdksh

缺少的依賴包

在ssh終端中安裝完依賴的包后,再次檢查環(huán)境还蹲,發(fā)現(xiàn)還有以下包缺失爹耗。其實是xxx(i386),CentOS7中已經(jīng)使用i686的緣故谜喊,直接忽略潭兽,繼續(xù)安裝即可。

安裝完依賴包

11. 安裝Oracle

啟動圖形安裝界面斗遏,按照提示安裝讼溺,檢查通不過的時候,請選擇忽略即可最易。

進入Oracle數(shù)據(jù)庫的安裝文件目錄,如/software/database炫狱,執(zhí)行命令./runInstaller藻懒,啟動Oracle數(shù)據(jù)庫安裝程序。

啟動安裝器

按照安裝向?qū)崾臼右耄徊揭徊降耐掳惭b嬉荆,需要注意的是使用中文一般要選ZHS16GBK,否則會出現(xiàn)亂碼酷含。

安裝過程中

安裝時到70%左右會出現(xiàn)一個錯誤

Error in invoking target 'agent nmhs' of makefile '/u01/oracle/product/11.2.0/db_1/sysman/lib/ins_emagent.mk'

解決方案:保留安裝過程鄙早,另外開啟一個終端窗口,將ins_emagent.mk文件中的(MK_EMAGENT_NMECTL)更改為$(MK_EMAGENT_NMECTL) -lnnz11椅亚,然后在安裝過程中點擊Retry即可限番。

在vim中,鍵入 / 執(zhí)行查找呀舔,鍵入 i 切換到插入狀態(tài)弥虐。

大約10分鐘后,安裝成功。

安裝成功

為了方便后續(xù)備份數(shù)據(jù)的正確導(dǎo)出霜瘪,也就是說0行數(shù)據(jù)的表結(jié)構(gòu)也要導(dǎo)出珠插,需要對新安裝的Oracle做如下設(shè)置。在sqlplus中執(zhí)行命令alter system set deferred_segment_creation=false;即可颖对。

Oracle11g默認對空表不分配segment捻撑,故使用exp導(dǎo)出Oracle11g數(shù)據(jù)庫時,空表不會導(dǎo)出缤底。

12 啟動關(guān)閉

用oracle用戶登錄系統(tǒng)顾患,執(zhí)行命令sqlplus / as sysdba,連接到數(shù)據(jù)庫训堆。

啟動命令:startup

關(guān)閉命令:shutdown

啟動監(jiān)聽器描验,在linux命令行下(不是在sqlplus)執(zhí)行lsnrctl start命令。

附:常用Oracle語句

恢復(fù)數(shù)據(jù):

CREATE OR REPLACE DIRECTORY DB_BAK AS '/software/ORA_BACKUP';

CREATE TABLESPACE RISKMON LOGGING DATAFILE '/opt/oracle/oradata/orcl/RISKMON.DBF' SIZE 256M AUTOEXTEND ON NEXT 50M MAXSIZE 20480M;

CREATE USER RISKMON IDENTIFIED BY 123456 DEFAULT TABLESPACE RISKMON;

GRANT READ, WRITE ON DIRECTORY DB_BAK TO RISKMON;
GRANT IMP_FULL_DATABASE TO RISKMON;
GRANT DBA TO RISKMON;

IMPDP RISKMON/123456@ORCL DIRECTORY=DB_BAK DUMPFILE=RISKMON_RISKMON.DMP

導(dǎo)入語句:

IMPDP RISKMON/123456@ORCL DIRECTORY=DB_BAK DUMPFILE=GZPOC_RISKMON.DMP REMAP_SCHEMA=GZPOC:RISKMON REMAP_TABLESPACE=RISKMON:RISKMON

導(dǎo)出數(shù)據(jù):

EXPDP RISKMON/123456@ORCL DIRECTORY=DB_BAK DUMPFILE=RISKMON_RISKMON.DMP SCHEMAS=RISKMON LOGFILE=RISKMON.LOG

其他操作:

--查詢所有用戶
SELECT USERNAME FROM DBA_USERS;

--刪除用戶
DROP USER GZPOC CASCADE;
    --刪除了GZPOC坑鱼,并刪除了該用戶下的SCHEMA OBJECTS膘流,但是不會刪除相應(yīng)的TABLESPACE

--刪除表空間
DROP TABLESPACE GZPOC_DATA INCLUDING CONTENTS AND DATAFILES;

--修改表空間名稱
ALTER TABLESPACE RISK_DATA RENAME TO RISK;

--修改數(shù)據(jù)文件名稱(如磁盤空間不夠了,移動數(shù)據(jù)文件到另外一個磁盤上)
ALTER TABLESPACE RISK_DATA OFFLINE;
ALTER TABLESPACE RISK_DATA RENAME DATAFILE 'C:\ORACLE\APP\ORACLE\ORADATA\XE\GZPOC.DBF' TO 'D:\ORACLE\APP\ORACLE\ORADATA\XE\AUDIT.DBF';  
ALTER TABLESPACE RISK_DATA ONLINE; 

Kevin 2017年12月4日鲁沥,成都呼股。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市画恰,隨后出現(xiàn)的幾起案子彭谁,更是在濱河造成了極大的恐慌,老刑警劉巖允扇,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缠局,死亡現(xiàn)場離奇詭異,居然都是意外死亡考润,警方通過查閱死者的電腦和手機狭园,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來糊治,“玉大人唱矛,你說我怎么就攤上這事【迹” “怎么了绎谦?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長粥脚。 經(jīng)常有香客問我窃肠,道長,這世上最難降的妖魔是什么刷允? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任铭拧,我火速辦了婚禮赃蛛,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘搀菩。我一直安慰自己呕臂,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布肪跋。 她就那樣靜靜地躺著歧蒋,像睡著了一般。 火紅的嫁衣襯著肌膚如雪州既。 梳的紋絲不亂的頭發(fā)上谜洽,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天,我揣著相機與錄音吴叶,去河邊找鬼阐虚。 笑死,一個胖子當(dāng)著我的面吹牛蚌卤,可吹牛的內(nèi)容都是我干的实束。 我是一名探鬼主播,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼逊彭,長吁一口氣:“原來是場噩夢啊……” “哼咸灿!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起侮叮,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤避矢,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后囊榜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體审胸,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年卸勺,在試婚紗的時候發(fā)現(xiàn)自己被綠了歹嘹。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡孔庭,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出材蛛,到底是詐尸還是另有隱情圆到,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布卑吭,位于F島的核電站芽淡,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏豆赏。R本人自食惡果不足惜挣菲,卻給世界環(huán)境...
    茶點故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一富稻、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧白胀,春花似錦椭赋、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至向抢,卻和暖如春认境,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背挟鸠。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工叉信, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人艘希。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓硼身,卻偏偏與公主長得像,于是被迫代替她去往敵國和親枢冤。 傳聞我的和親對象是個殘疾皇子鸠姨,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,675評論 2 359

推薦閱讀更多精彩內(nèi)容