CentOS 7.4下安裝Oracle 11.2.0.4資料庫

weixin_34337265發表於2017-12-04

在Linux下安裝Oracle資料庫是一件較為麻煩的事情。

由於Linux的安裝過程中可能會選擇不同的安裝包,會導致Oracle安裝過程中缺失或多一些軟體包,很難一次性的安裝成功。所以,本文詳細記錄了Oracle在Linux上的安裝過程,以供參考。

本環境僅供軟體開發和測試環境使用,並不適合用於生產環境。

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

本文的CentOS 7.4使用官網上下載的CentOS-7-x86_64-DVD-1708.iso檔案安裝,安裝時選擇Server with GUI,並選擇FTP Server。語言使用英語。

7781994-13accb1efa82fd87.png
選擇安裝包

為了日常使用方便,執行命令systemctl set-default multi-user.target,讓linux啟動後,直接進入字元介面。

本文的Oracle資料庫使用的是11.2.0.4(這個版本適配紅帽7,官網免費下載的版本並不適用於紅帽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. 關閉防火牆

由於是開發測試環境,為了方便,將防火牆關閉。但是,在正式的生產環境,千萬不要這樣做。

首先執行命令systemctl status firewalld.service檢查防火牆狀態,

7781994-bf4700e79056fe1b.png
檢查防火牆狀態

然後,執行命令systemctl stop firewalld.service關閉防火牆。

當然,我們可以執行命令systemctl disable firewalld.service,禁用防火牆。

7781994-7e4dae6751a64372.png
禁用防火牆

2. 關閉selinux

selinux提供了很多Linux的系統安全措施,演示系統中,將其關閉,方便操作。需要注意的是,在正式生產環境下,也千萬不要這樣做。

執行命令getenforce檢視selinux的狀態,初始安裝的CentOS7是開啟狀態。

執行命令vi /etc/selinux/config,編輯檔案,配置SELINUX=disabled,關閉selinux。

3. 為yum配置阿里源

在安裝Oracle的過程中,需要安裝一些依賴包。為了加快安裝速度,最好將yum源更新為國內的,首推阿里yum源。

  1. 執行命令cd /etc/yum.repos.d/,然後執行命令wget http://mirrors.aliyun.com/repo/Centos-7.repo下載阿里yum源。

  2. 執行命令mv CentOS-Base.repo CentOS-Base.repo.bak備份現有源資訊。

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

  4. 依次執行命令yum clean allyum makecacheyum update,更新yum源。

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

為了保險起見,為虛擬機器生成一份快照,避免後續安裝出錯,重頭再來安裝作業系統。

5. 建立資料庫目錄

建立Oracle資料庫的安裝目錄到/opt下。

  1. 執行命令mkdir -p /opt/oracle,建立oracle安裝目錄;

  2. 執行命令mkdir -p /opt/oraInventory,建立oracle資料庫配置檔案目錄;

  3. 執行命令chown -R oracle:oinstall /opt/oracle,設定oracle為目錄的所有者;

  4. 執行命令chown -R oracle:oinstall /opt/oraInventory,設定oracle為目錄的所有者。

6. 建立使用者和使用者組

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

  1. 執行命令groupadd oinstall,建立oinstall使用者組;

  2. 執行命令groupadd dba,建立dba使用者組;

  3. 執行命令useradd -g oinstall -g dba -m oracle,建立oracle使用者;

  4. 執行命令passwd oracle,為oracle使用者設定密碼,為了好記密碼為123456;

  5. 執行命令id oracle,檢視剛剛建立的oracle使用者資訊。

7781994-a36c02c6b04f3714.png
建立使用者組及使用者

執行命令vi /home/oracle/.bash_profile,新增如下內容,為oracle使用者設定環境變數。

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

執行命令source /home/oracle/.bash_profile,讓配置立即生效。

7. 對oracle使用者設定限制

為了提高軟體執行效能,需要對oracle使用者設定限制。

執行命令vi /etc/security/limits.conf,新增如下內容:

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

驗證最新版的PAM 已經被載入,如果不存在的話,在 /etc/pam.d/login 檔案中新增如下內容:

session required pam_limits.so

驗證當前的ulimits,並啟用。 這個可以通過很多方式來做, 在/etc/profile新增如下內容是推薦的方式:

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系統標識

Oracle資料庫支援在紅帽和Oracle Linux上安裝,不支援在CentOS上安裝,所以需要修改OS系統標識為紅帽。

執行命令vi /etc/redhat-release,修改系統標識為redhat-7

9. 修改核心引數

部分引數,在Oracle安裝過程中,可自動修復(使用root使用者執行Oracle安裝程式給出的修復指令碼),但是有部分不能自動修復。

執行命令vi /etc/sysctl.conf

修改的核心引數如下:

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

執行命令sysctl -p,使修改的核心引數生效。

10. 安裝依賴的軟體包

Oracle11gR2在CentOS7.4上安裝,缺少如下19個包,需要執行命令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即可。據說oracle使用新的ksh了,但是檢查指令碼中還使用的是pdksh

7781994-7791d4f27d8298d1.png
缺少的依賴包

在ssh終端中安裝完依賴的包後,再次檢查環境,發現還有以下包缺失。其實是xxx(i386),CentOS7中已經使用i686的緣故,直接忽略,繼續安裝即可。

7781994-dac5153bc724f86f.png
安裝完依賴包

11. 安裝Oracle

啟動圖形安裝介面,按照提示安裝,檢查通不過的時候,請選擇忽略即可。

進入Oracle資料庫的安裝檔案目錄,如/software/database,執行命令./runInstaller,啟動Oracle資料庫安裝程式。

7781994-f44aecfaaf218b09.png
啟動安裝器

按照安裝嚮導提示,一步一步的往下安裝,需要注意的是使用中文一般要選ZHS16GBK,否則會出現亂碼。

7781994-39e8b1aa1656abee.png
安裝過程中

安裝時到70%左右會出現一個錯誤

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中,鍵入 / 執行查詢,鍵入 i 切換到插入狀態。

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

7781994-0fc992337b83beae.png
安裝成功

為了方便後續備份資料的正確匯出,也就是說0行資料的表結構也要匯出,需要對新安裝的Oracle做如下設定。在sqlplus中執行命令alter system set deferred_segment_creation=false;即可。

Oracle11g預設對空表不分配segment,故使用exp匯出Oracle11g資料庫時,空表不會匯出。

12 啟動關閉

用oracle使用者登入系統,執行命令sqlplus / as sysdba,連線到資料庫。

啟動命令:startup

關閉命令:shutdown

啟動監聽器,在linux命令列下(不是在sqlplus)執行lsnrctl start命令。

附:常用Oracle語句

恢復資料:

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

匯入語句:

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

匯出資料:

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,但是不會刪除相應的TABLESPACE

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

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

--修改資料檔名稱(如磁碟空間不夠了,移動資料檔案到另外一個磁碟上)
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日,成都。

相關文章