脚本实现Oracle19c_pdb单实例自动安装部署

2024-06-13 23:38

本文主要是介绍脚本实现Oracle19c_pdb单实例自动安装部署,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目地址:Oracle19c_pdb_autoinstall
脚本使用说明具体请查看github上的README.md,使用上有什么问题,请反馈问题到我邮箱,谢谢!!
说明:脚本已经配置oracle服务自启动,并配置为系统服务,启动与停止时使用root用户操作

停止
# service oracle stop
启动
# service oracle start

oracle19c(12.2.0.3)版本在linux系统环境的使用说明:

The following Linux x86-64 kernels are supported:
1、Oracle Linux 7.4 with the Unbreakable Enterprise Kernel 4: 4.1.12-112.16.7.el7uek.x86_64 or later
2、Oracle Linux 7.4 with the Unbreakable Enterprise Kernel 5: 4.14.35-1818.1.6.el7uek.x86_64 or later
3、Oracle Linux 7.4 with the Red Hat Compatible kernel: 3.10.0-693.5.2.0.1.el7.x86_64 or later
4、Red Hat Enterprise Linux 7.4: 3.10.0-693.5.2.0.1.el7.x86_64 or later
5、SUSE Linux Enterprise Server 12 SP3: 4.4.103-92.56-default or later

以下为脚本所有内容,请参阅!

#!/bin/bash
#script_name: oracle19c_pdb_install.sh
#Author: Danrtsey.Shun
#Email:mydefiniteaim@126.com
#auto_install_oracle19c version=12.2.0.3
####################  Steup 1 Install oracle software ####################
# attentions1:
# 1.上传19c软件安装包至随意路径下,脚本提示路径是 /opt
#
# LINUX.X64_193000_db_home.zip
#
# 2.预设oracle用户的密码为 Danrtsey.com 请根据需要修改
#####################################
#ORACLE_OS_PWD=                     #
#if [ "$ORACLE_OS_PWD" = "" ]; then #
#    ORACLE_OS_PWD="Danrtsey.com"   #
#fi                                 #
#####################################
# 3.选择数据库字符集与国家字符集
# CharacterSet: ZHS16GBK or AL32UTF8
# NationalCharacterSet: AL16UTF16 or UTF8
# 4.执行
# chmod + oracle19c_pdb_install.sh
# sh -x oracle19c_pdb_install.sh
#
#################### Steup 2 Install oracle listener & dbca  ####################
# attentions2:
########################################
# 1.according to the different environment to set the processes && sessions value
# alter system set processes=1000 scope=spfile;
# alter system set sessions=1522 scope=spfile;
########################################export PATH=$PATH
#Source function library.
. /etc/init.d/functions#Require root to run this script.
uid=`id | cut -d\( -f1 | cut -d= -f2`
if [ $uid -ne 0 ];thenaction "Please run this script as root." /bin/falseexit 1
fi##set oracle password
ORACLE_OS_PWD=
if [ "$ORACLE_OS_PWD" = "" ]; thenORACLE_OS_PWD="Danrtsey.com"
fi###install require packages
echo -e "\033[34mInstallNotice >>\033[0m \033[32moracle install dependency \033[05m...\033[0m"
yum -y install epel-release
cp /etc/yum.repos.d/epel.repo /etc/yum.repos.d/epel.repo.bak
cp /etc/yum.repos.d/epel-testing.repo /etc/yum.repos.d/epel-testing.repo.bak
sed -e 's!^metalink=!#metalink=!g' \-e 's!^#baseurl=!baseurl=!g' \-e 's!//download\.fedoraproject\.org/pub!//mirrors.tuna.tsinghua.edu.cn!g' \-e 's!http://mirrors\.tuna!https://mirrors.tuna!g' \-i /etc/yum.repos.d/epel.repo /etc/yum.repos.d/epel-testing.repo
yum makecache fastyum -y install gcc gcc-c++ make binutils compat-libstdc++-33 elfutils-libelf elfutils-libelf-devel glibc glibc-common \glibc-devel libaio libaio-devel libgcc libstdc++ libstdc++-devel unixODBC unixODBC-devel elfutils-libelf-devel-static \numactl-devel sysstat pcre-devel readline compat-libcap1 libXi libXtst libxcb ksh \zip unzip tree vim lrzsz net-tools wget ntpdate ntp
if [[ $? == 0 ]];thenecho -e "\033[34mInstallNotice >>\033[0m \033[32myum install dependency successed\033[0m"
elseecho -e "\033[34mInstallNotice >>\033[0m \033[32myum install dependency faild, pls check your network\033[0m"exit
fi###set firewalld & optimize the os system & set selinux
echo "################# Optimize system parameters  ##########################"
firewall_status=`systemctl status firewalld | grep Active |awk '{print $3}'`
if [ ${firewall_status} == "(running)" ];thenfirewall-cmd --permanent --zone=public --add-port=1521/tcp && firewall-cmd --reload
elsesystemctl start firewalldfirewall-cmd --permanent --zone=public --add-port=1521/tcp && firewall-cmd --reload
fiSELINUX=`cat /etc/selinux/config |grep ^SELINUX=|awk -F '=' '{print $2}'`
if [ ${SELINUX} == "enforcing" ];thensed -i "s@SELINUX=enforcing@SELINUX=disabled@g" /etc/selinux/config
elseif [ ${SELINUX} == "permissive" ];thensed -i "s@SELINUX=permissive@SELINUX=disabled@g" /etc/selinux/configfi
fi
setenforce 0echo "================更改为中文字符集================="\cp /etc/locale.conf  /etc/locale.conf.$(date +%F)
cat >>/etc/locale.conf<<EOF
LANG="zh_CN.UTF-8"
#LANG="en_US.UTF-8"
EOF
source /etc/locale.conf
grep LANG /etc/locale.conf
action "更改字符集zh_CN.UTF-8完成" /bin/true
echo "================================================="
echo ""###set the ip in hosts
echo "############################   Ip&Hosts Configuration  #######################################"
hostname=`hostname`
HostIP=`ip a|grep 'inet '|grep -v '127.0.0.1'|awk '{print $2}'|awk -F '/' '{print $1}'`
for i in ${HostIP}
doA=`grep "${i}" /etc/hosts`if [ ! -n "${A}" ];thenecho "${i} ${hostname}" >> /etc/hosts elsebreakfi
done###create group&user
echo "############################   Create Group&User  #######################################"
ora_user=oracle
ora_group=('oinstall' 'dba' 'oper')
for i in ${ora_group[@]}
doB=`grep '${i}' /etc/group`if [ ! -n ${B} ];thengroupdel ${i} && groupadd ${i}else    groupadd ${i}fi
done
C=`grep 'oracle' /etc/passwd`
if [ ! -n ${C} ];thenuserdel -r ${ora_user} && useradd -u 501 -g ${ora_group[0]} -G ${ora_group[1]},${ora_group[2]} ${ora_user}
elseuseradd -u 501 -g ${ora_group[0]} -G ${ora_group[1]},${ora_group[2]} ${ora_user}
fi
echo "${ORACLE_OS_PWD}" | passwd --stdin ${ora_user}###create directory and grant priv
echo "############################ Create DIR & set privileges & set OracleSid ##################"
echo "############################   Create OracleBaseDi #######################################"
echo "############################   Create OracleHomeDir #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the ORACLE_SID(e.g:orcl):" S1read -p "Please input the ORACLE_SID again(orcl):" S2if [ "${S1}" == "${S2}" ];thenexport ORACLE_SID=${S1}breakelseecho "You input ORACLE_SID not same."count=$[${count}+1]fi
done
count=0
while [ $count -lt 3 ]
doread -p "Please input the ORACLE_BASE(e.g:/u01/oracle):" S1read -p "Please input the ORACLE_BASE again(/u01/oracle):" S2if [ "${S1}" == "${S2}" ];thenexport ORACLE_BASE=${S1}breakelse    echo "You input ORACLE_BASE not same."count=$[${count}+1]fi 
done
count=0
while [ $count -lt 3 ]
doread -p "Please input the ORACLE_HOME(e.g:/u01/oracle/product/19c/dbhome_1):" S1read -p "Please input the ORACLE_HOME again(/u01/oracle/product/19c/dbhome_1):" S2if [ "${S1}" == "${S2}" ];thenexport ORACLE_HOME=${S1}breakelse        echo "You input ORACLE_HOME not same."count=$[${count}+1]fi      
done
if [ ! -d ${ORACLE_HOME} ];thenmkdir -p ${ORACLE_HOME}
fi
if [ ! -d ${ORACLE_BASE}/data ];thenmkdir -p ${ORACLE_BASE}/data
fi
if [ ! -d ${ORACLE_BASE}/recovery ];thenmkdir -p ${ORACLE_BASE}/recovery
fi
ora_dir=`echo ${ORACLE_BASE}|awk -F '/' '{print $2}'`
if [ ! -d /${ora_dir}/install ];thenmkdir -p /${ora_dir}/install
fi
if [ ! -d /${ora_dir}/assistants ];thenmkdir -p /${ora_dir}/assistants
fi###set the sysctl,limits and profile
echo "############################   Configure environment variables #######################################"
D=`grep 'fs.aio-max-nr' /etc/sysctl.conf`
if [ ! -n "${D}" ];then
cat << EOF >> /etc/sysctl.conf
kernel.shmmax = 68719476736
kernel.shmmni = 4096
kernel.shmall = 16777216
kernel.sem = 1010 129280 1010 128
net.ipv4.ip_local_port_range = 9000 65500
net.core.rmem_default = 4194304
net.core.rmem_max = 4194304
net.core.wmem_default = 262144
net.core.wmem_max = 1048576
fs.aio-max-nr = 1048576
fs.file-max = 6815744
EOF
/sbin/sysctl -p
elsetail -11f /etc/sysctl.conf
fi
E=`grep 'oracle' /etc/security/limits.conf`
if [ ! -n "${E}" ];then
cat << EOF >> /etc/security/limits.conf
oracle soft nproc 16384
oracle hard nproc 16384
oracle soft nofile 65536
oracle hard nofile 65536
oracle soft memlock 4000000
oracle hard memlock 4000000
EOF
elsetail -5f /etc/security/limits.conf
fi
F=`grep 'ORACLE_SID' /home/${ora_user}/.bash_profile`
if [ ! -n "${F}" ];then
cat << EOF >> /home/${ora_user}/.bash_profile
export ORACLE_SID=${ORACLE_SID}
export ORACLE_BASE=${ORACLE_BASE}
export ORACLE_HOME=${ORACLE_HOME}
export PATH=\$PATH:\$ORACLE_HOME/bin
export NLS_LANG="AMERICAN_CHINA.ZHS16GBK"
EOF
elsetail -4f /home/${ora_user}/.bash_profile
fi
sed -i "/pam_namespace.so/a\session    required     pam_limits.so" /etc/pam.d/login
G=`grep 'oracle' /etc/profile`
if [ ! -n "${G}" ];then
cat << EOF >> /etc/profile
if [ \$USER = "oracle" ];thenif [ \$SHELL = "/bin/ksh" ];thenulimit -p 16384ulimit -n 65536elseulimit -u 16384 -n 65536fi
fi
EOF
elsetail -8f /etc/profile
fi###unzip the install package and set response file
echo "############################   unzip the install package  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the zip file location(e.g:/opt/LINUX.X64_193000_db_home.zip):" zfileif [ ! -f ${zfile} ];thenecho "You input location not found zip file."count=$[${count}+1]elseexport zfile=${zfile}breakfi
doneunzip ${zfile} -d $ORACLE_HOME && chown -R ${ora_user}:${ora_group[0]}  /${ora_dir}###set Oracle characterSet
echo "############################   set characterSet  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the CharacterSet(e.g:ZHS16GBK or AL32UTF8):" C1read -p "Please input the CharacterSet again(ZHS16GBK or AL32UTF8):" C2if [ "${C1}" == "${C2}" ];thenexport CharacterSet=${C1}breakelse        echo "You input characterSet not same."count=$[${count}+1]fi      
done###set Oracle nationalCharacterSet
echo "############################   set nationalCharacterSet  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the NationalCharacterSet(e.g:AL16UTF16 or UTF8):" N1read -p "Please input the NationalCharacterSet again(AL16UTF16 or UTF8):" N2if [ "${N1}" == "${N2}" ];thenexport NationalCharacterSet=${N1}breakelse        echo "You input nationalCharacterSet not same."count=$[${count}+1]fi      
done###set Oracle install.db.starterdb installSysPassword
echo "############################   set installSysPassword  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the installSysPassword(e.g:SysOracle2021):" S1read -p "Please input the installSysPassword again(SysOracle2021):" S2if [ "${S1}" == "${S2}" ];thenexport installSysPassword=${S1}breakelse        echo "You input installSysPassword not same."count=$[${count}+1]fi      
done###set Oracle install db config PDBName
echo "############################   set PDBName  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the PDBNAME(e.g:pdborcl):" S1read -p "Please input the PDBNAME again(pdborcl):" S2if [ "${S1}" == "${S2}" ];thenexport PDBNAME=${S1}breakelse        echo "You input PDBName not same."count=$[${count}+1]fi      
done###set Response File
echo "############################   set ResponseFile  #######################################"
db_response_file=`find ${ORACLE_HOME}/install -type f -name db_install.rsp`
cd `find ${ORACLE_HOME}/install -type f -name db_install.rsp | sed -n 's:/[^/]*$::p'` && cd ../../
install_dir=`pwd`
sed -i "s!oracle.install.responseFileVersion=/oracle/install/rspfmt_dbinstall_response_schema_v19.0.0!oracle.install.responseFileVersion=/${ora_dir}/install/rspfmt_dbinstall_response_schema_v19.0.0!g" ${db_response_file}
sed -i "s!oracle.install.option=!oracle.install.option=INSTALL_DB_SWONLY!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=/${ora_dir}/oraInventory!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.OSDBA_GROUP=!oracle.install.db.OSDBA_GROUP=${ora_group[1]}!g" ${db_response_file}
sed -i "s!oracle.install.db.OSOPER_GROUP=!oracle.install.db.OSOPER_GROUP=${ora_group[2]}!g" ${db_response_file}
sed -i "s!oracle.install.db.OSBACKUPDBA_GROUP=!oracle.install.db.OSBACKUPDBA_GROUP=${ora_group[1]}!g" ${db_response_file}
sed -i "s!oracle.install.db.OSDGDBA_GROUP=!oracle.install.db.OSDGDBA_GROUP=${ora_group[1]}!g" ${db_response_file}
sed -i "s!oracle.install.db.OSKMDBA_GROUP=!oracle.install.db.OSKMDBA_GROUP=${ora_group[1]}!g" ${db_response_file}
sed -i "s!oracle.install.db.OSRACDBA_GROUP=!oracle.install.db.OSRACDBA_GROUP=${ora_group[1]}!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=!oracle.install.db.config.starterdb.characterSet=${CharacterSet}!g" ${db_response_file}
sed -i "s!oracle.install.db.rootconfig.executeRootScript=!oracle.install.db.rootconfig.executeRootScript=false!g" ${db_response_file}
sed -i "s!oracle.install.db.config.starterdb.password.ALL=!oracle.install.db.config.starterdb.password.ALL=${installSysPassword}!g" ${db_response_file}
sed -i "s!oracle.install.db.rootconfig.configMethod=!oracle.install.db.rootconfig.configMethod=ROOT!g" ${db_response_file}
sed -i "s!oracle.install.db.ConfigureAsContainerDB=!oracle.install.db.ConfigureAsContainerDB=true!g" ${db_response_file}
sed -i "s!oracle.install.db.config.PDBName=!oracle.install.db.config.PDBName=${PDBNAME}!g" ${db_response_file}
sed -i "s!oracle.install.db.config.starterdb.installExampleSchemas=!oracle.install.db.config.starterdb.installExampleSchemas=false!g" ${db_response_file}###starting to install oracle software
echo "############################   Oracle Installing  #######################################"
oracle_out='/tmp/oracle.out'
touch ${oracle_out}
chown ${ora_user}:${ora_group[0]} ${oracle_out}
su - oracle -c "${install_dir}/runInstaller -silent -responseFile ${db_response_file}" > ${oracle_out} 2>&1
echo -e "\033[34mInstallNotice >>\033[0m \033[32moracle install starting \033[05m...\033[0m"
sleep 30
installActionslog=`find /${ora_dir}/oraInventory -name installActions*.log`
echo "You can check the oracle install log command: tail -100f ${installActionslog}"
while true; dogrep '[FATAL] [INS-10101]' ${oracle_out} &> /dev/nullif [[ $? == 0 ]];thenecho -e "\033[34mInstallNotice >>\033[0m \033[31moracle start install has [ERROR]\033[0m"cat ${oracle_out}exitfisleep 60cat /tmp/oracle.out  | grep shif [[ $? == 0 ]];then`cat /tmp/oracle.out  | grep sh | awk -F ' ' '{print $2}' |grep Root.sh`if [[ $? == 0 ]]; thenecho -e "\033[34mInstallNotice >>\033[0m \033[32mScript orainstRoot.sh run successed\033[0m"`cat /tmp/oracle.out  | grep sh | awk -F ' ' '{print $2}' |grep root.sh`if [[ $? == 0 ]];thenecho -e "\033[34mInstallNotice >>\033[0m \033[32mScript root.sh  run successed\033[0m"breakelseecho -e "\033[34mInstallNotice >>\033[0m \033[31mScript root.sh  run faild\033[0m"fielseecho -e "\033[34mInstallNotice >>\033[0m \033[31mScript orainstRoot.sh run faild\033[0m"fifi
doneecho "#######################   Oracle software 安装完成      ##############################"# install listener && dbca
echo "############################   install oracle listener && dbca  #######################################"
echo "############################   set oracle schema sysPassword  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the SYSPASSWORD(e.g:SysOracle2021):" S1read -p "Please input the SYSPASSWORD again(SysOracle2021):" S2if [ "${S1}" == "${S2}" ];thenexport SYSPASSWORD=${S1}breakelse        echo "You input SYSPASSWORD not same."count=$[${count}+1]fi      
done
echo "############################   set oracle app_user  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the USER_NAME(e.g:orcl):" S1read -p "Please input the USER_NAME again(orcl):" S2if [ "${S1}" == "${S2}" ];thenexport USER_NAME=${S1}breakelse        echo "You input USER_NAME not same."count=$[${count}+1]fi      
done
echo "############################   set oracle app_passwd  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the USER_PASSWD(e.g:Orcl2021):" S1read -p "Please input the USER_PASSWD again(Orcl2021):" S2if [ "${S1}" == "${S2}" ];thenexport USER_PASSWD=${S1}breakelse        echo "You input USER_PASSWD not same."count=$[${count}+1]fi      
done
echo "############################   set app_user tmp_dbf  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the TMP_DBF(e.g:orcl_temp):" S1read -p "Please input the TMP_DBF again(orcl_temp):" S2if [ "${S1}" == "${S2}" ];thenexport TMP_DBF=${S1}breakelse        echo "You input TMP_DBF not same."count=$[${count}+1]fi      
done
echo "############################   set app_user data_dbf  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the DATA_DBF(e.g:orcl_data):" S1read -p "Please input the DATA_DBF again(orcl_data):" S2if [ "${S1}" == "${S2}" ];thenexport DATA_DBF=${S1}breakelse        echo "You input DATA_DBF not same."count=$[${count}+1]fi      
done
echo "############################   set instances tablespace_dir  #######################################"
count=0
while [ $count -lt 3 ]
doread -p "Please input the DATA_DIR(e.g:/u01/oracle/data):" S1read -p "Please input the DATA_DIR again(/u01/oracle/data):" S2if [ "${S1}" == "${S2}" ];thenexport DATA_DIR=${S1}breakelse        echo "You input tablespace_dir not same."count=$[${count}+1]fi      
done
if [ ! -d ${DATA_DIR}/${ORACLE_SID} ];thenmkdir -p ${DATA_DIR}/${ORACLE_SID}data_dir=`echo ${DATA_DIR}|awk -F '/' '{print $2}'`chown -R ${ora_user}:${ora_group[0]}  /${data_dir}
fi
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'`
ora_dir=`echo ${ORACLE_BASE}|awk -F '/' '{print $2}'`
DB_SHUT=${ORACLE_HOME}/bin/dbshut
DB_START=${ORACLE_HOME}/bin/dbstart
BACKUP_DIR=${ORACLE_BASE}/backup
[ ! -f $BACKUP_DIR ] && mkdir $BACKUP_DIR
backup_dir=`echo ${BACKUP_DIR}|awk -F '/' '{print $2}'`
chown -R ${ora_user}:${ora_group[0]}  /${backup_dir}
MEM=`free -m|grep 'Mem:'|awk '{print $2}'`
TOTAL=$[MEM*8/10]PDB_SQL="
sqlplus / as sysdba << EOF
alter system set processes=1000 scope=spfile;
alter system set sessions=1522 scope=spfile;
shutdown immediate;
startup;
alter session set container=${PDBNAME};
alter pluggable database ${PDBNAME} open;
create temporary tablespace $TMP_DBF tempfile '$DATA_DIR/$ORACLE_SID/${TMP_DBF}.dbf' size 64m autoextend on next 64m maxsize unlimited extent management local;
create tablespace $DATA_DBF logging datafile '$DATA_DIR/$ORACLE_SID/${DATA_DBF}.dbf' size 64m autoextend on next 64m maxsize unlimited extent management local;
create user $USER_NAME identified by $USER_PASSWD default tablespace $DATA_DBF temporary tablespace $TMP_DBF;
grant connect,resource to $USER_NAME;
grant create view to $USER_NAME;
grant create public synonym to $USER_NAME;
grant drop public synonym to $USER_NAME;
grant unlimited tablespace to $USER_NAME;
create or replace directory dir_dump as '$BACKUP_DIR';
grant read,write on directory dir_dump to $USER_NAME;
ALTER PROFILE DEFAULT LIMIT PASSWORD_LIFE_TIME UNLIMITED;
exit
EOF
"PDB_AUTOSTART_SQL="
sqlplus / as sysdba << EOF
alter pluggable database all save state;
exit
EOF
"NETCA=`find ${ORACLE_HOME}/assistants -type f -name netca.rsp`###set listener&tnsnames
echo "############################   Oracle listener&dbca  #######################################"
###start listen
echo -e "\033[34mInstallNotice >>\033[0m \033[32mOracle start listen \033[05m...\033[0m"
su - oracle -c "${ORACLE_HOME}/bin/netca /silent /responsefile ${NETCA}"
netstat -anptu | grep 1521
if [[ $? == 0 ]]; thenecho -e "\033[34mInstallNotice >>\033[0m \033[32mOracle listen is running\033[0m"break
elseecho -e "\033[34mInstallNotice >>\033[0m \033[31mOracle listen is not running\033[0m"exit 5
fi###start install oracle instance
dbca_response_file=`find ${ORACLE_HOME}/assistants -type f -name dbca.rsp`
sed -i "s!responseFileVersion=/oracle/assistants/rspfmt_dbca_response_schema_v19.0.0=!responseFileVersion=/${ora_dir}/assistants/rspfmt_dbca_response_schema_v19.0.0!g" ${dbca_response_file}
sed -i "s!gdbName=!gdbName=${ORACLE_SID}!g" ${dbca_response_file}
sed -i "s!sid=!sid=${ORACLE_SID}!g" ${dbca_response_file}
sed -i "s!databaseConfigType=!databaseConfigType=SI!g" ${dbca_response_file}
sed -i "s!templateName=!templateName=General_Purpose.dbc!g" ${dbca_response_file}
sed -i "s!sysPassword=!sysPassword=${SYSPASSWORD}!g" ${dbca_response_file}
sed -i "s!systemPassword=!systemPassword=${SYSPASSWORD}!g" ${dbca_response_file}
sed -i "s!characterSet=!characterSet=${CharacterSet}!g" ${dbca_response_file}
sed -i "s!nationalCharacterSet=!nationalCharacterSet=${NationalCharacterSet}!g" ${dbca_response_file}
sed -i "s!createAsContainerDatabase=!createAsContainerDatabase=true!g" ${dbca_response_file}
sed -i "s!numberOfPDBs=!numberOfPDBs=1!g" ${dbca_response_file}
sed -i "s!pdbName=!pdbName=${PDBNAME}!g" ${dbca_response_file}
sed -i "s!pdbAdminPassword=!pdbAdminPassword=${SYSPASSWORD}!g" ${dbca_response_file}
sed -i "s!totalMemory=!totalMemory=${TOTAL}!g" ${dbca_response_file}su - oracle -c "${ORACLE_HOME}/bin/dbca -silent -createDatabase -responseFile ${dbca_response_file}"grep "${ORACLE_SID}" /etc/oratab
if [[ $? == 0 ]];thenecho -e "\033[34mInstallNotice >>\033[0m \033[32mOracle instances installed successful\033[0m"
elseecho -e "\033[34mInstallNotice >>\033[0m \033[31mOracle instances init failed\033[0m"exit 6
fised -i "s!${ORACLE_SID}:${ORACLE_HOME}:N!${ORACLE_SID}:${ORACLE_HOME}:Y!g" /etc/oratabAUTO_START_CONFIG=`cat /etc/oratab|grep ${ORACLE_SID} |awk -F ':' '{print $NF}'`
AUTO_START_CONFIG_expected='Y'if [ ${AUTO_START_CONFIG} = ${AUTO_START_CONFIG_expected} ];thenecho "AUTO_START_CONFIG successed!"
elseecho "AUTO_START_CONFIG failed!"exit 1
fi#deal with ORA-28040
sqlnet=$ORACLE_HOME/network/admin/sqlnet.ora
sed -i '4aSQLNET.ALLOWED_LOGON_VERSION_SERVER=11' $sqlnet
sed -i '4aSQLNET.ALLOWED_LOGON_VERSION_CLIENT=11' $sqlnet#set create app_user & app_passwd
echo "############################   Oracle sys_service  #######################################"
su - oracle -c "${PDB_SQL}"
if [ $? -eq 0 ];thenecho -e "\e[30 PDB_SQL execute successed \e[0m"
elseaction "oracle create app_user && app_passwd failed." /bin/falseexit 5
fi#set PDB instances auto start
echo "############################   Oracle pdb_service  #######################################"
su - oracle -c "${PDB_AUTOSTART_SQL}"
if [ $? -eq 0 ];thenecho -e "\e[30 PDB_AUTOSTART_SQL execute successed \e[0m"
elseaction "oracle set PDB instances auto start failed." /bin/falseexit 5
fi#set oracle start&stop sys_service
echo "############################   Oracle sys_service  #######################################"
su - oracle -c "touch /home/oracle/oracle"
cat >/etc/init.d/oracle <<EOF
#!/bin/sh
# chkconfig: 35 80 10
# description: Oracle auto start-stop script.
# Set ORACLE_HOME to be equivalent to the \$ORACLE_HOME
# Oracle database in ORACLE_HOME.
LOGFILE=/home/oracle/oracle
ORACLE_HOME=$ORACLE_HOME
ORACLE_OWNER=oracle
LOCK_FILE=/var/lock/subsys/oracle
if [ ! -f $ORACLE_HOME/bin/dbstart ]
thenecho "Oracle startup: cannot start"exit
fi
case "\$1" in
'start')
# Start the Oracle databases:
echo "Starting Oracle Databases ... "
echo "-------------------------------------------------" >> \${LOGFILE}
date +" %T %a %D : Starting Oracle Databases as part of system up." >> \${LOGFILE}
echo "-------------------------------------------------" >> \${LOGFILE}
su - \$ORACLE_OWNER -c "\$ORACLE_HOME/bin/dbstart $ORACLE_HOME" >> \${LOGFILE}
echo "Done"# Start the Listener:
echo "Starting Oracle Listeners ... "
echo "-------------------------------------------------" >> \${LOGFILE}
date +" %T %a %D : Starting Oracle Listeners as part of system up." >> \${LOGFILE}
echo "-------------------------------------------------" >> \${LOGFILE}
su - \$ORACLE_OWNER -c "\$ORACLE_HOME/bin/lsnrctl start" >> \${LOGFILE}
echo "Done."
echo "-------------------------------------------------" >> \${LOGFILE}
date +" %T %a %D : Finished." >> \${LOGFILE}
echo "-------------------------------------------------" >> \${LOGFILE}
touch \$LOCK_FILE
;;'stop')
# Stop the Oracle Listener:
echo "Stoping Oracle Listeners ... "
echo "-------------------------------------------------" >> \${LOGFILE}
date +" %T %a %D : Stoping Oracle Listener as part of system down." >> \${LOGFILE}
echo "-------------------------------------------------" >> \${LOGFILE}
su - \$ORACLE_OWNER -c "\$ORACLE_HOME/bin/lsnrctl stop" >> \${LOGFILE}
echo "Done."
rm -f \$LOCK_FILE# Stop the Oracle Database:
echo "Stoping Oracle Databases ... "
echo "-------------------------------------------------" >> \${LOGFILE}
date +" %T %a %D : Stoping Oracle Databases as part of system down." >> \${LOGFILE}
echo "-------------------------------------------------" >> \${LOGFILE}
su - \$ORACLE_OWNER -c "\$ORACLE_HOME/bin/dbshut $ORACLE_HOME" >> \${LOGFILE}
echo "Done."
echo ""
echo "-------------------------------------------------" >> \${LOGFILE}
date +" %T %a %D : Finished." >> \${LOGFILE}
echo "-------------------------------------------------" >> \${LOGFILE}
;;'restart')
\$0 stop
\$0 start
;;
esac
EOF
#set privileges
chmod +x /etc/init.d/oracle
chkconfig oracle on
# check oracle service
service oracle start
if [ $? -ne 0 ];thenaction "oracle service start failed." /bin/falseexit 2
fiservice oracle stop
if [ $? -ne 0 ];thenaction "oracle service stop failed." /bin/falseexit 3
fiservice oracle restart
if [ $? -ne 0 ];thenaction "oracle service restart failed." /bin/falseexit 4
fiecho "####################### oracle listener && dbca  安装完成 请记录数据库信息      ##############################"echo "#####   oracle用户系统登录密码:      #####"
echo -e "\e[31;47;5m $ORACLE_OS_PWD \e[0m"echo "#####   数据库实例名:      #####"
echo -e "\e[30;47;5m $ORACLE_SID \e[0m"echo "#####   数据库install.db.starterdb密码:      #####"
echo -e "\e[31;47;5m $installSysPassword \e[0m"echo "#####   数据库实例的sys管理用户密码:      #####"
echo -e "\e[30;47;5m $SYSPASSWORD \e[0m"echo "#####   数据库pdbname:      #####"
echo -e "\e[31;47;5m $PDBNAME \e[0m"echo "#####   数据库应用连接用户名:      #####"
echo -e "\e[30;47;5m $USER_NAME \e[0m"echo "#####   数据库应用连接用户名对应的密码:      #####"
echo -e "\e[31;47;5m $USER_PASSWD \e[0m"echo "#####   数据库临时表空间名:      #####"
echo -e "\e[30;47;5m $TMP_DBF \e[0m"echo "#####   数据库数据表空间名:      #####"
echo -e "\e[31;47;5m $DATA_DBF \e[0m"echo "#####   数据库表空间存储路径:      #####"
echo -e "\e[30;47;5m ${DATA_DIR} \e[0m"

这篇关于脚本实现Oracle19c_pdb单实例自动安装部署的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1058758

相关文章

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

mac安装redis全过程

《mac安装redis全过程》文章内容主要介绍了如何从官网下载指定版本的Redis,以及如何在自定义目录下安装和启动Redis,还提到了如何修改Redis的密码和配置文件,以及使用RedisInsig... 目录MAC安装Redis安装启动redis 配置redis 常用命令总结mac安装redis官网下

Python pyinstaller实现图形化打包工具

《Pythonpyinstaller实现图形化打包工具》:本文主要介绍一个使用PythonPYQT5制作的关于pyinstaller打包工具,代替传统的cmd黑窗口模式打包页面,实现更快捷方便的... 目录1.简介2.运行效果3.相关源码1.简介一个使用python PYQT5制作的关于pyinstall

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

C#实现文件读写到SQLite数据库

《C#实现文件读写到SQLite数据库》这篇文章主要为大家详细介绍了使用C#将文件读写到SQLite数据库的几种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录1. 使用 BLOB 存储文件2. 存储文件路径3. 分块存储文件《文件读写到SQLite数据库China编程的方法》博客中,介绍了文