linux安裝Oracle11G

linux安裝Oracle11G

0、下載Orcle11G

oracle10G/11G官方下載地址合集(直接迅雷下載)html

說明一下:
[root@myYUn install]#中的myYUn
等價於
[root@iz2f570bi1k56uz install]#中的iz2f570bi1k56uz;
這是爲了界面效果調整的,可是有些沒調整到,理解一哈。

 

一、上傳文件到服務器或虛擬機的/install目錄下

[root@myYUn install]# rz –ylinux

若是rz –y命令不能使用,可用以下方法解決c++

yum install lrzsz -y

二、解壓文件到當前目錄:

[root@myYUn install]# unzip linux.x64_11gR2_database_1of2.zipsql

[root@myYUn install]# unzip linux.x64_11gR2_database_2of2.zip數據庫

若是unzip命令不能使用,依次執行以下命令:vim

     yum list | grep zip/unzip

     yum install zip

     yum install unzip 

將解壓後的文件夾直接移動到/software目錄下:bash

[root@myYUn install]# mv database/ /software/服務器

[root@myYUn install]# cd /softwaresession

[root@myYUn install]# lloracle

 

三、關閉selinux

[root@myYUn software]# vim /etc/selinux/config

設置SELINUX=disabled

[root@myYUn software]# setenforce 0

四、關閉防火牆

查看系統版本

[root@myYUn software]# cat /etc/redhat-release

CentOS Linux release 7.3.1611 (Core)

[root@myYUn software]# getconf LONG_BIT

64

 

若是是6及如下:

[root@myYUn software]# service iptables stop

[root@myYUn software]# service iptables status

[root@myYUn software]# chkconfig iptables off

 

若是是centenOS7:

[root@myYUn software]# systemctl restart firewalld.service

[root@myYUn software]# systemctl list-unit-files|grep firewalld.service

firewalld.service                             disabled

[root@myYUn software]# systemctl disable firewalld.service

 

五、安裝Oracle 11g依賴包

[root@myYUn software]# yum install gcc make binutils gcc-c++ compat-libstdc++-33elfutils-libelf-devel elfutils-libelf-devel-static ksh libaio libaio-develnumactl-devel sysstat unixODBC unixODBC-devel pcre-devel –y

 

六、添加安裝用戶和用戶組

[root@myYUn software]# groupadd oinstall

[root@myYUn software]# groupadd dba

[root@myYUn software]# useradd -g oinstall -G dba oracle

[root@myYUn software]# passwd oracle

Changing password for user oracle.

New password:

BAD PASSWORD: The password is shorter than 8 characters

Retype new password:

passwd: all authentication tokens updated successfully.

[root@myYUn software]# id oracle

uid=1001(oracle) gid=1001(oinstall) groups=1001(oinstall),1002(dba)

 

七、修改內核參數配置文件

[root@myYUn software]# vim /etc/sysctl.conf

在末尾添加如下內容:

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

查看是否成功寫進/etc/sysctl.conf文件中:

[root@myYUn software]# sysctl -p

其中kernel.shmmax = 1073741824爲本機物理內存(2G)的一半,單位爲byte。

 

八、修改用戶的限制文件

修改/etc/security/limits.conf文件:

[root@myYUn software]# vim /etc/security/limits.conf

在末尾添加如下內容:

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

修改/etc/pam.d/login文件:

[root@myYUn software]# vim /etc/pam.d/login

在末尾添加如下內容:

session required  /lib64/security/pam_limits.so
session required   pam_limits.so 

修改/etc/profile文件:

[root@ myYUn software]# vim /etc/profile

在末尾添加如下內容:

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

 

九、建立安裝目錄和設置文件權限

[root@myYUn software]# mkdir -p /data/oracle/product/11.2.0

[root@myYUn software]# mkdir /data/oracle/oradata

[root@myYUn software]# mkdir /data/oracle/inventory

[root@myYUn software]# mkdir /data/oracle/fast_recovery_area

[root@myYUn software]# chown -R oracle:oinstall /data/oracle

[root@myYUn software]# chmod -R 775 /data/oracle

 

十、設置oracle用戶環境變量

首先切換到oracle用戶下:

[root@myYUn software]# su -l oracle

 

[oracle@myYUn ~]$ vim .bash_profile

在末尾添加以下內容:

ORACLE_BASE=/data/oracle

ORACLE_HOME=$ORACLE_BASE/product/11.2.0

ORACLE_SID=orcl

PATH=$PATH:$ORACLE_HOME/bin

export ORACLE_BASE ORACLE_HOME ORACLE_SID PATH

注意,標紅處必須與建立的數據庫實例名稱一致,不然數據庫啓動後沒法訪問。第一次配置完記得source一下。

[oracle@myYUn ~]$ source .bash_profile

 

十一、編輯靜默安裝響應文件

複製安裝文件夾response到當前oracle用戶的家目錄下:

[oracle@myYUn ~]$ cp -R /software/database/response/ .

[oracle@myYUn ~]$ cd response/

[oracle@myYUn response]$ vim db_install.rsp

須要設置的選項以下:

oracle.install.option=INSTALL_DB_SWONLY

ORACLE_HOSTNAME=CentOS

UNIX_GROUP_NAME=oinstall

INVENTORY_LOCATION=/data/oracle/inventory

SELECTED_LANGUAGES=en,zh_CN

ORACLE_HOME=/data/oracle/product/11.2.0

ORACLE_BASE=/data/oracle

oracle.install.db.InstallEdition=EE

oracle.install.db.DBA_GROUP=dba

oracle.install.db.OPER_GROUP=dba

DECLINE_SECURITY_UPDATES=true

 

十二、根據響應文件靜默安裝Oracle11g

[oracle@myYUn response]$ cd /software/database/

[oracle@myYUn database]$ ./runInstaller -silent -responseFile /home/oracle/response/db_install.rsp -ignorePrereq

 

若是執行以上命令出錯,會提示有參數格式,按照提示參數格式修改修改便可,通常是因爲word中的字體、符號格式複製到客戶端命令行後不一致引發,修改便可。

 

樓主遇到了交換空間不足的問題:

解決方案以下(在root用戶下執行):

[root@myYUn /]# free

[root@myYUn /]# dd if=/dev/zero of=swapfile bs=1024 count=500000

500000+0 records in

500000+0 records out

512000000 bytes (512 MB) copied, 1.67013 s, 307 MB/s

[root@myYUn /]# mkswap swapfile

Setting up swapspace version 1, size = 499996 KiB

no label, UUID=c5e355eb-e73e-4aa0-b882-cb6d1f88e6bc

[root@myYUn /]# swapon swapfile

swapon: /swapfile: insecure permissions 0644, 0600 suggested.

[root@myYUn /]# free

 

開始Oracle在後臺靜默安裝。安裝過程當中,若是提示[WARNING]沒必要理會,此時安裝程序仍在後臺進行,若是出現Successfully Setup Software,則安裝程序已經中止了。

 

能夠在如下位置找到本次安裝會話的日誌:/data/oracle/inventory/logs/installActions2018-05-13_02-14-55PM.log

 

能夠切換終端執行top命令查看後臺進程一直是在安裝的,/data目錄也在不斷增大,

當出現如下提示時,表明安裝成功:

按照要求執行腳本。

打開終端,退出到root身份登陸,執行腳本:

[oracle@iZ2f570bi1k56uZ database]$ exit

logout

[root@iZ2f570bi1k56uZ software]# sh /data/oracle/inventory/orainstRoot.sh

Changing permissions of /data/oracle/inventory.

Adding read,write permissions for group.

Removing read,write,execute permissions for world.

 

Changing groupname of /data/oracle/inventory to oinstall.

The execution of the script is complete.

[root@iZ2f570bi1k56uZ software]# sh /data/oracle/product/11.2.0/root.sh

Check /data/oracle/product/11.2.0/install/root_iZ2f570bi1k56uZ_2018-05-13_14-25-04.log for the output of root script

 

1三、以靜默方式配置監聽

從新使用oracle用戶登陸:

[root@myYUn software]# su -l oracle

Last login: Sun May 13 14:09:10 CST 2018 on pts/3

[oracle@myYUn ~]$ netca /silent /responseFile /home/oracle/response/netca.rsp 

注意此處,必須使用/silent /responseFile格式,而不是-silent -responseFile,由於是靜默安裝。

 

成功運行後,在/data/oracle/product/11.2.0/network/admin中生成listener.ora和sqlnet.ora

 

經過netstat命令能夠查看1521端口正在監聽。

 

Yum安裝netstat軟件,軟件包是在net-tools中。

[root@myYUn /]# yum install net-tools

[root@myYUn /]# yum install net-tools

 

1四、以靜默方式創建新庫,同時也創建一個對應的實例

[oracle@myYUn ~]$ vim /home/oracle/response/dbca.rsp

修改文件中如下參數:

[GENERAL]

# oracle版本,不能更改
RESPONSEFILE_VERSION = "11.2.0"

# Description   : Type of operation
OPERATION_TYPE = "createDatabase"

[CREATEDATABASE]

# Description   : Global database name of the database
# 全局數據庫的名字=SID+主機域名
# 第三方工具連接數據庫的時候使用的service名稱 GDBNAME
= "orcl.test" # Description : System identifier (SID) of the database # 對應的實例名字 SID = "orcl" # Description : Name of the template # 建庫用的模板文件 TEMPLATENAME = "General_Purpose.dbc" # Description : Password for SYS user # SYS管理員密碼 SYSPASSWORD = "123456" # Description : Password for SYSTEM user # SYSTEM管理員密碼 SYSTEMPASSWORD = "123456" # Description : Password for SYSMAN user # SYSMAN管理員密碼 SYSMANPASSWORD = "123456" # Description : Password for DBSNMP user # DBSNMP管理員密碼 DBSNMPPASSWORD = "123456" # Description : Location of the data file's # 數據文件存放目錄 DATAFILEDESTINATION =/data/oracle/oradata # Description : Location of the data file's # 恢復數據存放目錄 RECOVERYAREADESTINATION=/data/oracle/fast_recovery_area # Description : Character set of the database # 字符集,重要!!! 建庫後通常不能更改,因此建庫前要肯定清楚。 # (CHARACTERSET = "AL32UTF8" NATIONALCHARACTERSET= "UTF8") CHARACTERSET = "ZHS16GBK" # Description : total memory in MB to allocate to Oracle # oracle內存1638MB,物理內存2G*80% TOTALMEMORY = "1638" 

進行靜默配置:

[oracle@myYUn ~]$ dbca -silent -responseFile /home/oracle/response/dbca.rsp

建庫後進行實例進程檢查:

[oracle@myYUn ~]$ ps -ef | grep ora_ | grep -v grep

查看監聽狀態:

[oracle@myYUn ~]$ lsnrctl status

數據庫建立完成。

有關詳細信息, 請查看如下位置的日誌文件: /data/oracle/cfgtoollogs/dbca/orcl/orcl.log。

數據庫信息:

全局數據庫名:orcl.test

系統標識符 (SID):orcl

 

登陸查看實例狀態:

[oracle@myYUn ~]$ sqlplus / as sysdba

SQL> select status from v$instance;

 

linux 成功安裝oracle後,爲其建立一個登陸帳戶

 

若是報錯:【ORA-12162: TNS:net service name is incorrectly specified】

錯誤緣由:【這個錯誤是由於ORACLE_SID變量沒有傳進去形成的。】

解決方法:

1.查看當前ORACLE_SID

[oracle@iZ2f570bi1k56uZ ~]$ echo $ORACLE_SID

orcl                 

2.修改ORACLE_SID和/home/oracle/response/dbca.rsp中的同樣                                                                                                                                                                   

[oracle@iZ2f570bi1k56uZ ~]$ export ORACLE_SID=orcl

3.若是遇到ORA-12162: TNS:net service name is incorrectly specified.錯誤

參考文章:【ORA-12162: TNS:net service name is incorrectly specified.

4.若是依然不能登錄,嘗試修改orcle文件夾的權限

【若是本地鏈接時,出現監聽錯誤,參考Linux中安裝Oracle11g後出現監聽的問題及解決辦法

 

1五、命令行模式靜默刪除

一、首先查看dbca的幫助信息

dbca -help

 

修改/home/oracle/response/dbca.rsp文件裏如下幾個參數,下面三個參數根據建庫實際狀況進行修改:

OPERATION_TYPE = "deleteDatabase"

SOURCEDB = "orcl"

SYSDBAUSERNAME = "sys"

SYSDBAPASSWORD = "123456"

 

而後運行:

dbca -silent -responseFile /home/oracle/response/dbca.rsp

 

各參數含義以下:

-silent 表示以靜默方式刪除

-responseFile 表示使用哪一個響應文件,必需使用絕對路徑

RESPONSEFILE_VERSION 響應文件模板的版本,該參數不要更改

OPERATION_TYPE 安裝類型,該參數不要更改

SOURCEDB 數據庫名,不是全局數據庫名,即不包含db_domain

 

很簡單數據庫卸載完成了,請注意,只是數據庫卸載完了,數據庫軟件仍是在的。

 

二、使用DBCA卸載數據庫

dbca -silent -delete Database -responseFile dbca.rsp

 

a.選項-silent表示靜默安裝,免安裝交互,大部分安裝信息也不輸出

b.選項-responseFile指定應答文件,要求用絕對路徑

 

 


 

參考文章:

一、linux下安裝Oracle時交換空間不足的解決方法

二、sqlplus / as sysdba沒法登陸的奇怪報錯

三、Oracle 11g 基於CentOS7靜默安裝教程(無圖形界面,遠程安裝)

相關文章
相關標籤/搜索