最近工作需要安装oracle 11g R2在阿里云ECS上,因此编写了一个脚本来完成图形化安装界面之前的准备工作,这样节省时间,shell如下:
#!/bin/bash SYSCTL="/etc/sysctl.conf" LIMITS="/etc/security/limits.conf" PAM="/etc/pam.d/login" PROFILE="/etc/profile" BASH_PROFILE="/home/oracle/.bash_profile" oracle_passwd='oracle' SID=orcl lang="AMERICAN_AMERICA.AL32UTF8" #ora_install_dir=/u01 #ora_database_dir=/u02 ORACLE_BASE=$ora_install_dir/app/oracle ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db #初始化检查,OS版本、内存、磁盘情况 check_init() { OS=`cat /etc/redhat-release` MEM=`free -m |grep 'Mem' | awk '{print $2}'` CPUS=`grep -i "processor" /proc/cpuinfo | wc -l` echo "系统版本:$OS" echo "内存:${MEM}M" echo "CPU核数:$CPUS" } #检查swap空间是否分配 check_swap() { mem=`free -g |grep 'Mem' | awk '{print $2}'` mem_temp=$(($mem%2)) swap_all=`free -m |grep 'Swap' |awk '{print $2}'` if [ $mem_temp == 1 ];then mem=$(($mem+1)) swap=$(($mem/2)) echo -e "\n\e[1;32m 系统内存为 ${mem}GB \e[0m" fi swap_check="`grep -i 'swaptotal' /proc/meminfo |awk '{print $2}'`" if [[ $swap_check = "0" ]];then read -p " swap分区没有设置,请进行设置,输入[y] or [n]:" temp if [ $temp == "y" ];then COUNT=$(($swap * 1024)) echo -e "\n\e[1;31m 开始设置swap分区,/mnt/swap=${swap}GB \e[0m" dd if=/dev/zero of=/mnt/swap bs=1M count=${COUNT} mkswap /mnt/swap swapon /mnt/swap echo "/mnt/swap swap swap defaults 0 0" >> /etc/fstab else echo "请检查或手工设置swap分区后运行该脚本!" exit 1 fi else echo -e "\n\e[1;31m系统内存为${mem}GB 当前swap分区已经配置,大小为${swap_all}MB \e[0m" fi } #检查是否root用户执行脚本 isroot() { if [ $USER != "root" ];then echo -e "\n\e[1;31m The user must be root,and you user is $USER,please su to root.\e[0m" exit 4 fi } #创建oracle用户 oracle_useradd() { if [[ `grep "oracle" /etc/passwd` != "" ]];then echo -e "\e[1;31m User oracle exits, delete and create oracle! \e[0m" && sleep 2 userdel -rf oracle fi if [[ `grep "oinstall" /etc/group` = "" ]];then groupadd oinstall fi if [[ `grep "dba" /etc/group` = "" ]];then groupadd dba fi useradd oracle -g oinstall -G dba && echo $oracle_passwd |passwd oracle --stdin if [ $? -eq 0 ];then echo -e "\n\e[1;32m oracle's password update successfully ---OK! \e[0m" else echo -e "\n\e[1;31m oracle's password set failed. ---NO! \e[0m" fi } #创建oracle使用的目录 oracle_dirs() { read -p "please input oracle install dirname,default /u01": ora_install_dir read -p "please input oracle database dirname,default /u02": ora_database_dir mkdir -p $ora_install_dir/app/oracle/{oraInventory,product/11.2.0/db} mkdir -p "$ora_database_dir/oradata/oradb" chown -R oracle:oinstall $ora_install_dir chown -R oracle.oinstall $ora_database_dir chmod -R 755 $ora_install_dir $ora_database_dir if [ $? == 0 ];then echo "$ora_install_dir create sucessfully!" echo "$ora_database_dir create sucessfully!" else echo "$ora_install_dir or $ora_database_dir create Failed,please check!" exit 2 fi } #配置profile文件 oracle_profile() { if [ -f "/etc/profile.bak" ];then rm -rf /etc/profile >/dev/null cp /etc/profile.bak /etc/profile cat << EOF >>$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 else cp /etc/profile /etc/profile.bak cat << EOF >>$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 fi if [ $? -eq 0 ];then echo -e "\n\e[1;32m $PROFILE update successfully... OK! \e[0m" fi } #配置.bash_profile() oracle_bash() { if [ -f "/home/oracle/.bash_profile.bak" ];then rm -rf $BASH_PROFILE>/dev/null cp /home/oracle/.bash_profile.bak $BASH_PROFILE cat <> $BASH_PROFILE export ORACLE_BASE=$ORACLE_BASE export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db export ORACLE_SID=$SID export ORACLE_TERM=xterm export ORACLE_OWNER=oracle export TNS_ADMIN=$ORACLE_HOME/network/admin export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/network/lib:/lib:/usr/lib:/usr/local/lib export LIBPATH=$ORACLE_HOME/lib:$ORACLE_HOME/network/lib:/lib:/usr/lib:/usr/local/lib export PATH=$PATH:/sbin:/usr/bin:/usr/sbin:$JAVA_HOME/bin:$ORACLE_HOME/bin:$ORACLE_HOME/lib:$HOME/bin:$ORACLE_HOME/OPatch:. umask 022 export NLS_LANG=$lang EOF else cp $BASH_PROFILE /home/oracle/.bash_profile.bak cat < > $BASH_PROFILE export ORACLE_BASE=$ORACLE_BASE export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db export ORACLE_SID=$SID export ORACLE_TERM=xterm export ORACLE_OWNER=oracle export TNS_ADMIN=$ORACLE_HOME/network/admin export ORA_NLS33=$ORACLE_HOME/ocommon/nls/admin/data export LD_LIBRARY_PATH=$ORACLE_HOME/lib:$ORACLE_HOME/network/lib:/lib:/usr/lib:/usr/local/lib export LIBPATH=$ORACLE_HOME/lib:$ORACLE_HOME/network/lib:/lib:/usr/lib:/usr/local/lib export PATH=$PATH:/sbin:/usr/bin:/usr/sbin:$JAVA_HOME/bin:$ORACLE_HOME/bin:$ORACLE_HOME/lib:$HOME/bin:$ORACLE_HOME/OPatch:. umask 022 export NLS_LANG=$lang EOF fi if [ $? -eq 0 ];then echo -e "\n\e[1;32m $BASH_PROFILE update successfully...OK! \e[0m" fi } #设置limit资源限制 oracle_limit() { if [ -f "/etc/security/limits.conf.bak" ];then rm -rf $LIMITS>/dev/null cp /etc/security/limits.conf.bak $LIMITS cat < > $LIMITS oracle soft nproc 8192 oracle hard nproc 16384 oracle soft nofile 8192 oracle hard nofile 65536 EOF else cp $LIMITS /etc/security/limits.conf.bak cat < > $LIMITS oracle soft nproc 8192 oracle hard nproc 16384 oracle soft nofile 8192 oracle hard nofile 65536 EOF fi if [ $? -eq 0 ];then echo -e "\n\e[1;32m $LIMITS update sucessfully...OK! \e[0m" fi } #设置内核参数 oracle_kernal() { if [ -f /etc/sysctl.conf.bak ];then rm -rf $SYSCTL>/dev/null cp /etc/sysctl.conf.bak $SYSCTL sed -i 's/kernel.msgmnb.*/#kernel.msgmnb = 65536/g' $SYSCTL sed -i 's/kernel.msgmax.*/#kernel.msgmax = 65536/g' $SYSCTL sed -i 's/kernel.shmmax.*/#kernel.shmmax = 68719476736/g' $SYSCTL sed -i 's/kernel.shmall.*/#kernel.shmall = 4294967296/g' $SYSCTL cat < > $SYSCTL kernel.shmall = 2097152 kernel.shmmax = 2147483648 kernel.shmmni = 40960 kernel.sem = 250 32000 100 128 kernel.msgmni = 4096 kernel.msgmax = 65536 kernel.msgmnb = 84000 fs.file-max = 6815744 net.ipv4.ip_local_port_range = 9000 65500 fs.file-max = 6815744 net.core.rmem_default = 262144 net.core.rmem_max = 4194304 net.core.wmem_default = 262144 net.core.wmem_max = 1048576 fs.aio-max-nr = 1048576 net.ipv4.tcp_wmem = 262144 262144 262144 net.ipv4.tcp_rmem = 4194304 4194304 4194304 EOF else cp $SYSCTL /etc/sysctl.conf.bak sed -i 's/kernel.msgmnb.*/#kernel.msgmnb = 65536/g' $SYSCTL sed -i 's/kernel.msgmax.*/#kernel.msgmax = 65536/g' $SYSCTL sed -i 's/kernel.shmmax.*/#kernel.shmmax = 68719476736/g' $SYSCTL sed -i 's/kernel.shmall.*/#kernel.shmall = 4294967296/g' $SYSCTL cat < > $SYSCTL kernel.shmall = 2097152 kernel.shmmax = 2147483648 kernel.shmmni = 40960 kernel.sem = 250 32000 100 128 kernel.msgmni = 4096 kernel.msgmax = 65536 kernel.msgmnb = 84000 fs.file-max = 6815744 net.ipv4.ip_local_port_range = 9000 65500 fs.file-max = 6815744 net.core.rmem_default = 262144 net.core.rmem_max = 4194304 net.core.wmem_default = 262144 net.core.wmem_max = 1048576 fs.aio-max-nr = 1048576 net.ipv4.tcp_wmem = 262144 262144 262144 net.ipv4.tcp_rmem = 4194304 4194304 4194304 EOF fi if [ $? -eq 0 ];then echo -e "\n\e[1;32m $SYSCTL update sucessfully...OK! \e[0m" fi } #关闭iptables and selinux iptables_selinux() { service iptables stop && chkconfig iptables off setenforce 0 &>/dev/null sed -i '/SELINUX/s/enforcing/disabled/;/SELINUX/s/permissive/disabled/' /etc/selinux/config } #下载oracle安装文件 get_oracle() { wget http://10.139.96.23:8080/p13390677_112040_Linux-x86-64_1of7.zip -P /home/oracle && wget http://10.139.96.23:8080/p13390677_112040_Linux-x86-64_2of7.zip -P /home/oracle } #oracle安装准备主程序 main() { isroot check_init && sleep 1 check_swap && sleep 1 oracle_useradd && sleep 1 oracle_dirs && sleep 1 oracle_profile && sleep 1 oracle_bash && sleep 1 oracle_limit && sleep 1 oracle_kernal && sleep 1 iptables_selinux && sleep 1 get_oracle && sleep 1 if [ $? -eq 0 ] ;then echo -e "\n\e[1;32m oracle初始化配置已经完成,请确保图形化界面正常工作,执行./database安装程序! \e[0m" fi } main