一、首先須要搭建一個Web站點,用於提供yum服務和oracle軟體下載,相似軟件資料庫同樣。(也可以使用Ftp服務代替Web服務,看本身的選擇)linux
二、Oracle軟件安裝時,建議不要安裝在根目錄下,因此此腳本中/u 目錄爲一個分區,若無/u分區,則相關目錄會在根目錄下。此腳本還能夠結合PXE+KICKSTART無人值守安裝實現批量部署。c++
三、腳本內容以下:bash
#!/bin/bash ################################################################################################ # Install softeare -- Install oracle 11g database software # # History: 2016/01/25 zhuwei First release ################################################################################################ # set a safe path before doing anything else PATH=/sbin:/usr/sbin:/bin:/usr/bin; export PATH WEBSITE="http://192.168.1.10" #----------------------------------------------------------------------------------------------- # This script must be executed as root RUID=`/usr/bin/id|awk -F\( '{print $1}'|awk -F\= '{print $2}'` if [ ${RUID} != "0" ];then $ECHO "This script must be executed as root" exit 1 fi #----------------------------------------------------------------------------------------------- prepareSystem(){ # Set SElinux to disabled mode regardless of its initial value sed -i -e 's/^SELINUX=.*/SELINUX=disabled/' /etc/selinux/config setenforce 0 # stop iptables /etc/init.d/iptables stop # *** Chkconfig section # Turn off unwanted services chkconfig --level 0123456 iptables off chkconfig --level 0123456 ip6tables off } #----------------------------------------------------------------------------------------------- # Display an error and exit errorExit() { echo "$@" >&2 exit 1 } #----------------------------------------------------------------------------------------------- # Display the normal print displayheader() { echo -e "\033[32m*******************************************************************\033[0m" echo -e "\033[32m*\033[0m"$@"" echo -e "\033[32m*******************************************************************\033[0m" echo "" } #----------------------------------------------------------------------------------------------- #download oracle software download(){ wget -N -q -P /u $WEBSITE/oracle11g/p10404530_112030_Linux-x86-64_1of7.zip wget -N -q -P /u $WEBSITE/oracle11g/p10404530_112030_Linux-x86-64_2of7.zip unzip -q -d /u /u/p10404530_112030_Linux-x86-64_1of7.zip unzip -q -d /u /u/p10404530_112030_Linux-x86-64_2of7.zip rm -rf /u/p10404530_112030_Linux-x86-64_1of7.zip rm -rf /u/p10404530_112030_Linux-x86-64_2of7.zip chown -R oracle:oinstall /u/database } #----------------------------------------------------------------------------------------------- #Configure the kernel params Configure1(){ cat >> /etc/sysctl.conf <<EOF fs.aio-max-nr = 1048576 fs.file-max = 6815744 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 if [ $? != 0 ]; then errorExit 'Unable to configure sysctl settings for database' fi return 0 } Configure2(){ cat >> /etc/security/limits.conf <<EOF oracle soft nproc 2047 oracle hard nproc 16384 oracle soft nofile 1024 oracle hard nofile 65536 EOF if [ $? != 0 ]; then errorExit 'Unable to configure settings for database' fi return 0 } Configure3(){ cat >> /etc/pam.d/login <<EOF session required pam_limits.so EOF if [ $? != 0 ]; then errorExit 'Unable to configure settings for database' fi return 0 } #----------------------------------------------------------------------------------------------- #In the table below for the list of users and user groups # # User Name Group Name # --------- ------- # oracle dba,oinstall # grid asmdba(If using the asm storage) # #Add Users and Groups addUsers(){ GROUPEXIT1=`grep oinstall /etc/group|awk -F: '{print $1}'` if [ -z ${GROUPEXIT1} ]; then /usr/sbin/groupadd oinstall || errorExit 'Unable to add oinstall group' fi GROUPEXIT2=`grep dba /etc/group|awk -F: '{print $1}'` if [ -z ${GROUPEXIT2} ]; then /usr/sbin/groupadd dba || errorExit 'Unable to add dba group' fi USERSEXIT=`grep oracle /etc/shadow | awk -F: '{print $1}'` if [ -z ${USERSEXIT} ]; then /usr/sbin/useradd -d /home/oracle -g oinstall -G dba oracle && passwd -l oracle \ || errorExit 'Unable to add oracle user' #這裏oracle用戶是鎖定的,不能經過ssh進行登陸的,使用su - oracle切換用戶以後操做是沒有 #問題的,其實這裏也能夠使用usermod -L oracle && chage -d 0 oracle 讓oracle用戶第一次登陸\ #時要求修改密碼。 fi return 0 } #----------------------------------------------------------------------------------------------- #Configure the oracle user's environment profile(){ cat >> /home/oracle/.bash_profile <<EOF export TMP=/tmp export TMPDIR=\$TMP export ORACLE_SID=test export ORACLE_BASE=/u/app/oracle export ORACLE_HOME=\$ORACLE_BASE/product/11.2.0/db_1 export TNS_ADMIN=\$ORACLE_HOME/network/admin export ORACLE_TERM=xterm export PATH=/usr/sbin:\$PATH export PATH=\$ORACLE_HOME/bin:\$PATH export LD_LIBRARY_PATH=\$ORACLE_HOME/lib:/lib:/usr/lib:\$ORACLE_HOME/jdbc/lib export CLASSPATH=\$ORACLE_HOME/JRE:\$ORACLE_HOME/jlib:\$ORACLE_HOME/rdbms/jlib export NLS_LANG="AMERICAN_AMERICA.GB2312" export NLS_DATE_FORMAT='yyyy/mm/dd hh24:mi:ss' umask 022 if [ $USER = "oracle" ]; then if [ $SHELL = "/bin/ksh" ]; then ulimit -p 16384 ulimit -n 65536 else ulimit -u 16384 -n 65536 fi fi EOF if [ $? != 0 ]; then errorExit 'bash_profile this file does not exist' fi return 0 } #----------------------------------------------------------------------------------------------- #To establish the oracle software installation directory directory(){ if [ ! -d "/u/app/oracle" ]; then mkdir -p /u/app/oracle fi chown -R oracle:oinstall /u/app chmod -R 775 /u/app } HOSTNAME=`hostname` PATH1="/u/database/response" #----------------------------------------------------------------------------------------------- #Configure the oracle silent installation files silent(){ ORACLE_BASE="\/u\/app\/oracle" ORACLE_HOME=${ORACLE_BASE}"\/product\/11\.2\.0\/db_1" A1="ORACLE_HOSTNAME\=" A2="INVENTORY_LOCATION\=" A3="ORACLE_HOME\=" A4="ORACLE_BASE\=" B1=${A1}${HOSTNAME} B2=${A2}${ORACLE_BASE}"\/oraInventory" B3=${A3}${ORACLE_HOME} B4=${A4}${ORACLE_BASE} mv -f $PATH1/db_install.rsp $PATH1/db_install.rsp.bak wget -N -q -P $PATH1 $WEBSITE/oracle11g/db_install.rsp sed -i -e "s/${A1}/${B1}/g" -e "s/${A2}/${B2}/g" -e "s/${A3}/${B3}/g" \ -e "s/${A4}/${B4}/g" $PATH1/db_install.rsp || errorExit "The configuration file failed!" #這裏的wget下載下來的db_install.rsp文件有一通用的部分我是處理過的,而後放到Web服務端 #提供下載,修改過的內容以下: #oracle.install.option=INSTALL_DB_SWONLY #UNIX_GROUP_NAME=oinstall #SELECTED_LANGUAGES=en #oracle.install.db.InstallEdition=EE #oracle.install.db.DBA_GROUP=dba #oracle.install.db.OPER_GROUP=dba #DECLINE_SECURITY_UPDATES=true } ################################################################################################ # Detect and install oracle rpm package you need VERSION1=`sed -n '1p' /etc/issue|awk 'BEGIN{OFS=""} {print $1,$2,$7}'` VERSION2=`sed -n '1p' /etc/issue|awk 'BEGIN{OFS=""} {print $1,$2,$7}'|awk -F. '{print $1}'` VALUE=`/usr/bin/getconf LONG_BIT` OSDIGIT=`/bin/uname -m` P_YUM="/etc/yum.repos.d/" #----------------------------------------------------------------------------------------------- # Download yum client configure file /usr/bin/wget -N -q -P $P_YUM $WEBSITE/rhelrepo/$VERSION2.repo \ || errorExit 'Failed to download the yum client files,Please manually configure!' /bin/sed -i 's/RedHat/'$VERSION1\_$OSDIGIT'/g' $P_YUM$VERSION2.repo \ || errorExit 'Replace the files is not successful,Please manually configure!' if [ -f $P_YUM$VERSION2.repo ]; then displayheader "Successfully configured yum client, please continue" fi #----------------------------------------------------------------------------------------------- # RedHat 5 and RedHat 6 install oracle software required RPM package Red5=(binutils-2* compat-libstdc++-33* elfutils-libelf-0.* elfutils-libelf-devel-0.* \ elfutils-libelf-devel-static-0.* gcc-4.* gcc-c++-4* glibc-2.* glibc-common-2.* glibc-devel-2.* \ glibc-headers-2* kernel-headers-2.* libaio-0.* libaio-devel-0.* libgcc-4.* libgomp-4.* \ libstdc++-4.* libstdc++-devel-* make-* numactl-devel-* sysstat-* pdksh-* ksh-* \ unixODBC-* unixODBC-devel-*) Red6=(binutils-2* compat-libstdc++-33* elfutils-libelf-0.* elfutils-libelf-devel-0.* \ gcc-4.* gcc-c++-4* glibc-2.* glibc-common-2.* glibc-devel-2.* glibc-headers-2* \ kernel-headers-2.* libaio-0.* libaio-devel-0.* libgcc-4.* libgomp-4.* libstdc++-4.* \ libstdc++-devel-* make-* numactl-devel-* sysstat-* pdksh-* unixODBC-* unixODBC-devel-*) len5=${#Red5[@]} len6=${#Red6[@]} COUNT=0 #----------------------------------------------------------------------------------------------- # Test your system has been installed the RPM package displayheader "You have installed the required RPM package is as follows:" if [ $VERSION2 == "RedHat5" ] ; then for((i=0;i<len5;i++)); do CHAR=${Red5[$i]} rpm -qa | grep "^$CHAR" if [ $? != 0 ] ; then UNINSTALL[$COUNT]=${Red5[$i]} COUNT=$(($COUNT+1)) fi done fi if [ $VERSION2 == "RedHat6" ] ; then for((i=0;i<len6;i++)); do CHAR=${Red6[$i]} rpm -qa | grep "^$CHAR" if [ $? != 0 ] ; then UNINSTALL[$COUNT]=${Red6[$i]} COUNT=$(($COUNT+1)) fi done fi printf '\n' #----------------------------------------------------------------------------------------------- # Will not install the RPM packages for installation if [ $COUNT -gt "0" ];then displayheader "Do you have "$COUNT" rpm package not installed,not installed patch is:" len=${#UNINSTALL[@]} for((j=0;j<len;j++)); do echo "${UNINSTALL[$j]}" done printf '\n' read -p "Are you sure to install the patch[yes or y]:" SELECT printf '\n' if [ $SELECT == "yes" -o $SELECT == "y" ]; then for((l=0;l<len;l++)); do VAR=${UNINSTALL[$l]} if [ $VAR == "pdksh-5.2.14-36.el5.x86_64.rpm" ]; then rpm -qa ksh-* if [ $? == 0 ]; then yum -q -y remove ksh-* fi fi yum -q -y install $VAR done fi else displayheader "Required RPM packages have been installed" fi prepareSystem || errorExit 'Failed to prepare system' Configure1 && displayheader "The configure1 successful execution" \ || errorExit 'Failed to system' Configure2 && displayheader "The configure2 successful execution" \ || errorExit 'Failed to system' Configure3 && displayheader "The configure1 successfu3 execution" \ || errorExit 'Failed to system' addUsers && displayheader "Building a successful oracle users and groups" \ || errorExit 'Failed to system' directory && displayheader "Building a successful directory" \ || errorExit 'Failed to system' profile || errorExit 'Failed to system' displayheader "Is the download file, please wait a few minutes" && download silent && displayheader "Modify db_install. RSP file successfully" \ || errorExit 'Failed to system' displayheader "Is database software installed, please wait" chmod a+x ${PATH1}/db_install.rsp chown oracle:oinstall ${PATH1}/db_install.rsp su - oracle -c "/u/database/./runInstaller -silent -force -responseFile \ ${PATH1}/db_install.rsp -ignoreSysPrereqs"
執行以上腳本後還須要執行$ORACLE_BASE/oraInventory/orainstRoot.sh和$ORACLE_HOME/root.sh兩個腳本。session