oracle 11gR2全靜默方式安裝

1默勾、系統(tǒng)參數(shù)如下

os:centos 7.2 x86_64

db:11.2.0.4

硬件參數(shù)不一一列舉了棘幸,自行根據(jù)情況適當(dāng)調(diào)整,系統(tǒng)必需要能使用yum進行安裝rpm包翼闽,切記。

1洲炊、靜默安裝數(shù)據(jù)庫軟件

腳本如下:

#!/bin/bash

export PATH=$PATH

###set firewalld&selinux

os=`cat /etc/redhat-release|awk '{print $4}'|awk -F'.' '{print $1}'`

if [ ${os} == "7" ];then

systemctl disable firewalld && systemctl stop firewalld

if [ `getenforce` == "Enforcing" ];then

setenforce 0

sed -i "s!SELINUX=enforcing!SELINUX=disabled!g" /etc/selinux/config

elif [ `getenforce` == "Permissive" ];then

sed -i "s!SELINUX=enforcing!SELINUX=disabled!g" /etc/selinux/config

else

continue

fi

else

chkconfig iptables off && chkconfig ip6tables off && service iptables stop && service ip6tables stop

if [ `getenforce` == "Enforcing" ];then

? ? ? ? ? ? ? ? setenforce 0

? ? ? ? ? ? ? ? sed -i "s!SELINUX=enforcing!SELINUX=disabled!g" /etc/selinux/config

? ? ? ? elif [ `getenforce` == "Permissive" ];then

? ? ? ? ? ? ? ? sed -i "s!SELINUX=enforcing!SELINUX=disabled!g" /etc/selinux/config

? ? ? ? else

? ? ? ? ? ? ? ? continue

? ? ? ? fi

fi

###set the ip in hosts

hostname=`hostname`

ip=`ip a|grep 'inet '|grep -v '127.0.0.1'|awk '{print $2}'|awk -F '/' '{print $1}'`

for i in ${ip}

do

a=`grep "${i}" /etc/hosts`

if [ ! -n "${a}" ];then

echo "${i} ${hostname}" >> /etc/hosts

else

break

fi

done

###create group&user

ora_user=oracle

ora_group=('oinstall' 'dba' 'oper')

for i in ${ora_group[@]}

do

a=`grep '${i}' /etc/group`

if [ ! -n ${a} ];then

groupdel ${i} && groupadd ${i}

else

groupadd ${i}

fi

done

a=`grep 'oracle' /etc/passwd`

if [ ! -n ${a} ];then

userdel -r ${ora_user} && useradd -g ${ora_group[0]} -G ${ora_group[1]},${ora_group[2]} ${ora_user}

else

useradd -g ${ora_group[0]} -G ${ora_group[1]},${ora_group[2]} ${ora_user}

fi

###create directory and grant priv

count=0

while [ $count -lt 3 ]

do

read -p "Please input the ORACLE_SID(e.g:orcl):" S1

read -p "Please input the ORACLE_SID again(e.g:orcl):" S2

if [ "${S1}" == "${S2}" ];then

export ORACLE_SID=${S1}

break

else

echo "You input ORACLE_SID not same."

count=$[${count}+1]

fi

done

count=0

while [ $count -lt 3 ]

do

? ? ? ? read -p "Please input the ORACLE_BASE(e.g:/oracle/app):" S1

? ? ? ? read -p "Please input the ORACLE_BASE again(e.g:/oracle/app):" S2

? ? ? ? if [ "${S1}" == "${S2}" ];then

? ? ? ? ? ? ? ? export ORACLE_BASE=${S1}

? ? ? ? ? ? ? ? break

? ? ? ? else? ?

? ? ? ? ? ? ? ? echo "You input ORACLE_BASE not same."

? ? ? ? ? ? ? ? count=$[${count}+1]

? ? ? ? fi

done

count=0

while [ $count -lt 3 ]

do

? ? ? ? read -p "Please input the ORACLE_HOME(e.g:/oracle/app/db):" S1

? ? ? ? read -p "Please input the ORACLE_HOME again(e.g:/oracle/app/db):" S2

? ? ? ? if [ "${S1}" == "${S2}" ];then

? ? ? ? ? ? ? ? export ORACLE_HOME=${S1}

? ? ? ? ? ? ? ? break

? ? ? ? else? ? ? ?

? ? ? ? ? ? ? ? echo "You input ORACLE_HOME not same."

? ? ? ? ? ? ? ? count=$[${count}+1]

? ? ? ? fi? ? ?

done

if [ ! -d ${ORACLE_HOME} ];then

mkdir -p ${ORACLE_HOME}

else

continue

fi

if [ ! -d ${ORACLE_BASE}/data ];then

mkdir -p ${ORACLE_BASE}/data

else

continue

fi

if [ ! -d ${ORACLE_BASE}/recovery ];then

mkdir -p ${ORACLE_BASE}/recovery

else

continue

fi

ora_dir=`echo ${ORACLE_HOME}|awk -F '/' '{print $2}'`

last_dir=`echo ${ORACLE_HOME}|awk -F '/' '{print $NF}'`

###install require packages

yum -y install binutils compat-libcap1 compat-libstdc++-33 gcc gcc-c++ glibc glibc-devel ksh libaio libaio-devel libgcc libstdc++ libstdc++-devel libXi libXtst make sysstat unixODBC unixODBC-devel zip unzip tree

###set the sysctl,limits and profile

a=`grep 'fs.aio-max-nr' /etc/sysctl.conf`

if [ ! -n "${a}" ];then

cat << EOF >> /etc/sysctl.conf

fs.aio-max-nr = 1048576

fs.file-max = 6815744

kernel.shmall = 2097152

kernel.shmmax = 536870912

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

EOF

else

continue

fi

a=`grep 'oracle' /etc/security/limits.conf`

if [ ! -n "${a}" ];then

cat << EOF >> /etc/security/limits.conf

oracle soft nproc 2047

oracle hard nproc 16384

oracle soft nofile 1024

oracle hard nofile 65536

oracle soft stack 10240

EOF

else

continue

fi

a=`grep 'ORACLE_SID' /home/${ora_user}/.bash_profile`

if [ ! -n "${a}" ];then

cat << EOF >> /home/${ora_user}/.bash_profile

export ORACLE_SID=${ORACLE_SID}

export ORACLE_BASE=${ORACLE_BASE}

export ORACLE_HOME=\$ORACLE_BASE/${last_dir}

export PATH=\$PATH:\$ORACLE_HOME/bin

EOF

else

continue

fi

sysctl -p && source /home/${ora_user}/.bash_profile

###unzip the install package and set response file

count=0

while [ $count -lt 3 ]

do

read -p "Please input the zip file location(e.g:/oracle/db.zip):" zfile

if [ ! -f ${zfile} ];then

echo "You input location not found zip file."

count=$[${count}+1]

else

export zfile=${zfile}

break

fi

done

unzip ${zfile} -od /${ora_dir} && chown -R ${ora_user}:${ora_group[0]}? /${ora_dir} && chmod -R 775 /${ora_dir}

free_m=`free -m | grep 'Mem:'|awk '{print $2}'`

db_response_file=`find / -type f -name db_install.rsp`

data_dir=${ORACLE_BASE}/data

recovery_dir=${ORACLE_BASE}/recovery

cd `find / -type f -name db_install.rsp | sed -n 's:/[^/]*$::p'` && cd ../

install_dir=`pwd`

sed -i "s!oracle.install.option=!oracle.install.option=INSTALL_DB_SWONLY!g" ${db_response_file}

sed -i "s!ORACLE_HOSTNAME=!ORACLE_HOSTNAME=${hostname}!g" ${db_response_file}

sed -i "s!UNIX_GROUP_NAME=!UNIX_GROUP_NAME=${ora_group[0]}!g" ${db_response_file}

sed -i "s!INVENTORY_LOCATION=!INVENTORY_LOCATION=${ORACLE_BASE}/oraInventory!g" ${db_response_file}

sed -i "s!SELECTED_LANGUAGES=en!SELECTED_LANGUAGES=en,zh_CN!g" ${db_response_file}

sed -i "s!ORACLE_HOME=!ORACLE_HOME=${ORACLE_HOME}!g" ${db_response_file}

sed -i "s!ORACLE_BASE=!ORACLE_BASE=${ORACLE_BASE}!g" ${db_response_file}

sed -i "s!oracle.install.db.InstallEdition=!oracle.install.db.InstallEdition=EE!g" ${db_response_file}

sed -i "s!oracle.install.db.DBA_GROUP=!oracle.install.db.DBA_GROUP=${ora_group[1]}!g" ${db_response_file}

sed -i "s!oracle.install.db.OPER_GROUP=!oracle.install.db.OPER_GROUP=${ora_group[2]}!g" ${db_response_file}

sed -i "s!oracle.install.db.config.starterdb.type=!oracle.install.db.config.starterdb.type=GENERAL_PURPOSE!g" ${db_response_file}

sed -i "s!oracle.install.db.config.starterdb.globalDBName=!oracle.install.db.config.starterdb.globalDBName=${ORACLE_SID}!g" ${db_response_file}

sed -i "s!oracle.install.db.config.starterdb.SID=!oracle.install.db.config.starterdb.SID=${ORACLE_SID}!g" ${db_response_file}

sed -i "s!oracle.install.db.config.starterdb.characterSet=AL32UTF8!oracle.install.db.config.starterdb.characterSet=ZHS16GBK!g" ${db_response_file}

sed -i "s!oracle.install.db.config.starterdb.memoryLimit=!oracle.install.db.config.starterdb.memoryLimit=$[free_m*8/10]!g" ${db_response_file}

sed -i "s!oracle.install.db.config.starterdb.password.ALL=!oracle.install.db.config.starterdb.password.ALL=wincenter!g" ${db_response_file}

sed -i "s!oracle.install.db.config.starterdb.storageType=!oracle.install.db.config.starterdb.storageType=FILE_SYSTEM_STORAGE!g" ${db_response_file}

sed -i "s!oracle.install.db.config.starterdb.fileSystemStorage.dataLocation=!oracle.install.db.config.starterdb.fileSystemStorage.dataLocation=${data_dir}!g" ${db_response_file}

sed -i "s!oracle.install.db.config.starterdb.fileSystemStorage.recoveryLocation=!oracle.install.db.config.starterdb.fileSystemStorage.recoveryLocation=${recovery_dir}!g" ${db_response_file}

sed -i "s!oracle.installer.autoupdates.option=!oracle.installer.autoupdates.option=SKIP_UPDATES!g" ${db_response_file}

sed -i "s!SECURITY_UPDATES=!SECURITY_UPDATES=true!g" ${db_response_file}

su - oracle -c "${install_dir}/runInstaller -silent -responseFile ${db_response_file}"

2感局、靜默安裝監(jiān)聽及建庫

腳本如下:

#!/bin/bash

export PATH=$PATH

PASSWORD="wincenter"

ORACLE_SID=`su - oracle -c 'source ~/.bash_profile && echo $ORACLE_SID'`

ORACLE_BASE=`su - oracle -c 'source ~/.bash_profile && echo $ORACLE_BASE'`

ORACLE_HOME=`su - oracle -c 'source ~/.bash_profile && echo $ORACLE_HOME'`

temp=`ls ${ORACLE_BASE}|grep 'data'`

if [ ! -n ${temp} ];then

? ? ? ? mkdir ${ORACLE_BASE}/data

? ? ? ? export DATAFILE=${ORACLE_BASE}/data

else

? ? ? ? export DATAFILE=${ORACLE_BASE}/data

fi

temp=`ls ${ORACLE_BASE}|grep 'area'`

if [ ! -n ${temp} ];then

? ? ? ? mkdir ${ORACLE_BASE}/flash_recovery_area

? ? ? ? export RECOVERY=${ORACLE_BASE}/flash_recovery_area

else

? ? ? ? export RECOVERY=${ORACLE_BASE}/flash_recovery_area

fi

NETCA=`find / -type f -name netca.rsp`

sed -i "s!INSTALL_TYPE=""typical""!INSTALL_TYPE=""custom""!g" ${NETCA}

MEM=`free -m|grep 'Mem:'|awk '{print $2}'`

TOTAL=$[MEM*8/10]

###set listener&tnsnames

su - oracle << EOF

source ~/.bash_profile

${ORACLE_HOME}/bin/netca -silent -responsefile ${NETCA}

dbca -silent -createDatabase -templateName General_Purpose.dbc -gdbname ${ORACLE_SID} -sid ${ORACLE_SID} -sysPassword ${PASSWORD} -systemPassword ${PASSWORD} -responseFile NO_VALUE -datafileDestination ${DATAFILE} -redoLogFileSize 1000 -recoveryAreaDestination ${RECOVERY} -storageType FS -characterSet ZHS16GBK -nationalCharacterSet AL16UTF16 -sampleSchema false -memoryPercentage 80 -totalMemory $TOTAL -databaseType OLTP -emConfiguration NONE

EOF

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市暂衡,隨后出現(xiàn)的幾起案子询微,更是在濱河造成了極大的恐慌,老刑警劉巖狂巢,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件撑毛,死亡現(xiàn)場離奇詭異,居然都是意外死亡唧领,警方通過查閱死者的電腦和手機藻雌,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進店門雌续,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人胯杭,你說我怎么就攤上這事驯杜。” “怎么了做个?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵鸽心,是天一觀的道長。 經(jīng)常有香客問我居暖,道長顽频,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任太闺,我火速辦了婚禮冲九,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘跟束。我一直安慰自己莺奸,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布冀宴。 她就那樣靜靜地躺著灭贷,像睡著了一般。 火紅的嫁衣襯著肌膚如雪略贮。 梳的紋絲不亂的頭發(fā)上甚疟,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天,我揣著相機與錄音逃延,去河邊找鬼览妖。 笑死,一個胖子當(dāng)著我的面吹牛揽祥,可吹牛的內(nèi)容都是我干的讽膏。 我是一名探鬼主播,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼拄丰,長吁一口氣:“原來是場噩夢啊……” “哼府树!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起料按,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤奄侠,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后载矿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體垄潮,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了弯洗。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片甫题。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖涂召,靈堂內(nèi)的尸體忽然破棺而出坠非,到底是詐尸還是另有隱情,我是刑警寧澤果正,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布炎码,位于F島的核電站,受9級特大地震影響秋泳,放射性物質(zhì)發(fā)生泄漏潦闲。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一迫皱、第九天 我趴在偏房一處隱蔽的房頂上張望歉闰。 院中可真熱鬧,春花似錦卓起、人聲如沸和敬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽昼弟。三九已至,卻和暖如春奕筐,著一層夾襖步出監(jiān)牢的瞬間舱痘,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工离赫, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留芭逝,地道東北人。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓渊胸,卻偏偏與公主長得像旬盯,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子蹬刷,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,828評論 2 345

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