成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Oracle單實(shí)例安裝環(huán)境一鍵配置腳本(CentOS6 + 11gR2 )

li21 / 3498人閱讀

摘要:這是自己曾經(jīng)寫的一個(gè)在服務(wù)器上,一鍵配置安裝環(huán)境的腳本,能快速完成安裝前環(huán)境的配置。

這是自己曾經(jīng)寫的一個(gè)oracle 11gR2在CentOS6 x86_64服務(wù)器上,一鍵配置安裝環(huán)境的腳本,能快速完成安裝前環(huán)境的配置。

具體完成以下工作:

備份系統(tǒng)配置文件,以防出錯(cuò)

添加oracle用戶和用戶組

創(chuàng)建安裝目錄

關(guān)閉selinux

在.bash_profile中修改環(huán)境變量

修改sysctl.conf文件

修改limits.conf文件

修改PAM的login文件

安裝必要的依賴包

使用注意事項(xiàng):

root的用戶執(zhí)行,chmod +x oraclePreInstCheck.sh

./oraclePreInstCheck.sh運(yùn)行后,請(qǐng)仔細(xì)閱讀說(shuō)明,再?zèng)Q定是否使用該腳本

該腳本默認(rèn)參數(shù)適用于2核4G內(nèi)存的環(huán)境,你可以根據(jù)需要修改kernelset()部分

執(zhí)行完后,你檢查一下你的安裝目錄及權(quán)限(默認(rèn)/db/oracle

該腳本會(huì)有提示輸入的地方,請(qǐng)不要挑戰(zhàn)它的健壯性,比如輸入安裝根目錄時(shí),不要帶入空格

腳本只需執(zhí)行一次,修改系統(tǒng)參數(shù)如sysctl.conf之前,都有備份成xxx.ora_bak

請(qǐng)確保可以通過(guò)yum方式安裝軟件包(使用掛載DVD鏡像或聯(lián)網(wǎng))

建議結(jié)合tee將執(zhí)行過(guò)程記錄在日志文件中,./oraclePreInstCheck.sh | tee oraclePreInstCheck.log

#!/bin/bash
# author       zhouxiao
# date         2014-03-07
# description  oracle 11g R2 for linux 6.0+ x86_64 安裝輔助腳本

#定義常量
SYSCTL=/etc/sysctl.conf
LIMITS=/etc/security/limits.conf
PAM=/etc/pam.d/login
PROFILE=/etc/profile
BASH_PROFILE=/home/oracle/.bash_profile
#循環(huán)變量
i=1
#定義顯示顏色
#顏色定義 信息(33黃色) 警示(31紅色) 過(guò)程(36淺藍(lán))

usage()
{
    echo "Scripts: initialize the required env settings for Oracle 11gR2 installation on Linux 6.0+ x86_64"
    echo "Make sure you have prepared conditions list bellow:"
    echo -e "  
e[1;33m yum, hosts, user oracle"s passwd, oralce SID, DISPLAY location e[0m"
    echo "The Script will backup config files with .ora_bak in case failure "
    echo "The Script will set the following change:"
    echo "  - add user oracle and group oinstall/dba/oper, etc."
    echo "  - make directory ORACLE_HOME and change owner"
    echo "  - modify oracle .bash_profile"
    echo "  - modify /etc/sysctl.conf kernel parameters like shmall/shmmax"
    echo "  - modify /etc/security/limits.conf "
    echo "  - install necessary packages like libgcc/libaio/unixODBC, etc."
    echo "  - IF anything goes wrong, you need to recover ora_bak files manually."
    echo -e "
e[1;33m Continue? (y/n [n]): e[0m"
    read singal
    if [ $singal != "y" ]; then
        exit 0
    else
        echo "God Bless you! Settings started."
        echo ""
        echo ""
    fi
}

#判斷執(zhí)行用戶是否root
isroot()
{
    if [ $USER != "root" ];then
        echo -e "
e[1;31m the user must be root,and now you user is $USER,please su to root. e[0m"
        exit4
    else
        echo -e "
e[1;36m check root ... OK! e[0m"
    fi
}
#掛在光盤到/mnt/cdrom目錄下
mount_cdrom()
{
echo -e "
e[1;31m please insert RHEL to CDROM,press any key ...e[0m"
read -n 1
if [ -d /mnt/cdrom ];then
     mount -t auto -o ro /dev/cdrom /mnt/cdrom
else
    mkdir -p /mnt/cdrom
    mount -t auto -o ro /dev/cdrom /mnt/cdrom
fi
if [ $? -eq 0 ];then
    echo -e "
e[1;36m CDROM mount on /mnt/cdrom ... OK! e[0m"
fi
}
#設(shè)置yum本地光盤源
yum_repo()
{
    rm -rf /etc/yum.repos.d/* && cat <> /etc/yum.repos.d/Server.repo
[Server]
name=MyRPM
baseurl=file:///mnt/cdrom/Server
enabled=1
gpgkey=file:///mnt/cdrom/RPM-GPG-KEY-redhat-release
EOF
if [ $? -eq 0 ];then
echo -e "
e[1;36m  /etc/yum.repos.d/Server.repo  ... OK! e[0m"
fi
}
#添加oracle用戶,添加oracle用戶所屬組oinstall及附加組dba
ouseradd()
{
    if [[ `grep "oracle" /etc/passwd` != "" ]];then
        userdel -r oracle
    fi
    if [[ `grep "oinstall" /etc/group` = "" ]];then
        groupadd -g 501 oinstall
    fi
    if [[ `grep "dba" /etc/group` = "" ]];then
        groupadd -g 502 dba
        groupadd -g 503 oper
        groupadd -g 504 asmadmin
        groupadd -g 506 asmdba
        groupadd -g 505 asmoper
    fi
    useradd oracle -g oinstall -G dba,asmdba,oper && echo $1 |passwd oracle --stdin
    if [ $? -eq 0 ];then
        echo -e "
e[1;36m oracle"s password updated successfully  --- OK! e[0m"
    else
        echo -e "
e[1;31m oracle"s password set faild.   --- NO!e[0m"
    fi
}
#檢查oracle所需軟件包并安裝
packagecheck()
{
for package in binutils compat-libcap1 compat-libstdc++-33  compat-libstdc++-33*i686 gcc gcc-c++ glibc glibc-2*i686 glibc-devel glibc-devel-2*i686  glibc-headers-2.* libgcc libgcc-4*i686 libstdc++ libstdc++-4*i686 libstdc++-devel libstdc++-devel-4*i686 libaio-0* libaio-0*i686 libaio-devel libaio-devel-0*i686 unixODBC unixODBC-2*i686 unixODBC-devel unixODBC-devel-2*i686 make sysstat ksh 
do
    rpm -q $package 2> /dev/null
    if [ $? != 0 ];then
        yum -y install $package 2> /dev/null
        echo  -e "
e[1;36m $package is installed ... OK! e[0m"
    fi
done
}
#安裝桌面套件 X Window System / Desktop
xdesk()
{
    LANG=C yum -y groupinstall "X Window System" "Desktop"
    if [ $? -eq 0 ];then
        echo  -e "
e[1;36m $package is already installed ... OK! e[0m"
    fi
}
# 設(shè)置內(nèi)核參數(shù)
# shmall 物理內(nèi)存<8G =2097152     >8G MemTotal/4kb
# shmmax 物理內(nèi)存<8G = 4294967296 >8G 16GMemTotal = 10G=10*1024^3
kernelset()
{
    cp $SYSCTL{,.ora_bak} && cat <>$SYSCTL
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 4294967296
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 [ $? -eq 0 ];then
        echo -e "
e[1;36m kernel parameters updated successfully --- OK! e[0m"
    fi
sysctl -p
}
#設(shè)置oracle資源限制
oralimit()
{
    cp $LIMITS{,.ora_bak} && cat <> $LIMITS
oracle      soft    nproc   2047
oracle      hard    nproc   16384
oracle      soft    nofile  1024
oracle      hard    nofile  65536
oracle      soft    stack   10240
EOF
    if [ $? -eq 0 ];then
        echo  -e "
e[1;36m $LIMITS updated successfully ... OK! e[0m"
    fi
cat $LIMITS | grep "^o"
}
#設(shè)置login文件
setlogin()
{
    cp $PAM{,.ora_bak} && cat <>$PAM
session     required    pam_limits.so
EOF
    if [ $? -eq 0 ];then
        echo -e "
e[1;36m  $PAM updated successfully ... OK! e[0m"
    fi
}
#設(shè)置profile文件
setprofile()
{
    cp $PROFILE{,.ora_bak} && cat <>$PROFILE
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 [ $? -eq 0 ];then
        echo -e "
e[1;36m  $PROFILE updated successfully ... OK! e[0m"
    fi
}
#設(shè)置oracle的profile文件
setbash_profile()
{
    cp $BASH_PROFILE{,.ora_bak} && cat <> $BASH_PROFILE
umask 022

#oracle settings
TMP=/tmp; export TMP

TMPDIR=$TMP; export TMPDIR
ORACLE_BASE=$1/oracle
ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
ORACLE_SID=$2
PATH=$ORACLE_HOME/bin/:$PATH
LANG=en_US.UTF-8
ORACLE_TERM=xterm
export ORACLE_BASE ORACLE_HOME ORACLE_SID ORACLE_TERM

LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib; export LD_LIBRARY_PATH
CLASSPATH=$ORACLE_HOME/jre:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib
export CLASSPATH

EOF
    if [ $? -eq 0 ];then
        echo -e "
e[1;36m $BASH_PROFILE updated successfully ... OK! e[0m"
    fi
su - oracle -c source $BASH_PROFILE
}
#系統(tǒng)環(huán)境檢查
oscheck()
{
#查看內(nèi)存大小是否大于1G
echo -e "
 check MEM Size ..."
if [ `cat /proc/meminfo | grep MemTotal | awk "{print $2}"` -lt 1048576 ];then
    echo  -e "
e[1;33m Memory Small e[0m"
    exit 1
else
    echo -e "
e[1;36m Memory checked PASS e[0m"
fi
#查看tmp空間大小
echo -e "
 check tmpfs Size ..."
cp /etc/fstab{,.ora_bak}
while true;do
if [ `df | awk "/tmpfs/ {print $2}"` -lt 1048576 ];then
    echo -e "
e[1;33m tmpfs Smaill e[0m"
    sed -i "/tmpfs/s/defaults/defaults,size=1G/" /etc/fstab && mount -o remount /dev/shm
    if [ $? != 0 ];then
    i=i+1
        if [ $i -eq 3 ];then
            echo -e "
e[1;31m set tmpfs faild. e[0m"
            exit 3
        fi
    else
        echo -e "
e[1;36 tmpfs updated successfully. e[0m"
        break
    fi
else
    echo -e "
e[1;36m tmpfs checked PASS e[0m"
    break
fi
done
}

usage

#停止防火墻IPTABLES
service iptables stop
#chkconfig iptables off
#關(guān)閉SELINUX
cp /etc/selinux/config{,.ora_bak} && sed -i "/SELINUX/s/enforcing/disabled/;/SELINUX/s/permissive/disabled/"   /etc/selinux/config
setenforce 0
#執(zhí)行以上函數(shù)
isroot
#oscheck
#yum_repo
#mount_cdrom
packagecheck
#xdesk
kernelset
oralimit
setlogin
setprofile
echo -e "
e[1;33m please input oracle"s user passwd: e[0m"
read oraclepw
ouseradd $oraclepw

echo -e "
e[1;33m please input oracle install PATH (default /db) e[0m"
read oraclepath
if [ -z $oraclepath ];then
    oraclepath=/db
fi
if [ ! -x "$oraclepath" ];then
    mkdir -p "$oraclepath"
    chown oracle.oinstall $oraclepath
    echo -e "
e[1;36 $oraclepath created. e[0m"
fi

echo -e "
e[1;33m  please input oracle_sid, just for env (default TSDB) e[0m"
read orasid
if [ -z orasid ];then
    orasid=TSDB
fi
setbash_profile $oraclepath $orasid
mkdir -p $oraclepath/oracle/product/11.2.0/db_1 && chown -R oracle:oinstall $oraclepath && chmod -R 755 $oraclepath
unset i

echo -e "
e[1;33m please input where to display the X Window (default 127.0.0.1:0.0) e[0m" 
read xdpy
if [ -z $xdpy ];then
    xdpy=127.0.0.1:0.0
fi
su - oracle -c export DISPLAY=$xdpy && host +

echo -e "
e[1;35m Oracle install pre-setting finish! && please run oracle installer as user oracle e[0m"


原文鏈接地址:http://seanlook.com/2014/12/02/oracle11gr2_installation_precheck_scripts/


文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/17375.html

相關(guān)文章

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<