Linux平台Oracle安装脚本
#脚本仅供交流学习使用!#脚本当前版本为1.0.实现了物理内存交换空间的检测,RPM包的自动安装(需配置Yum或者挂载光盘,如果你复制了所有需要的RPM包到某个目录,也O
# 脚本仅供交流学习使用!
# 脚本当前版本为1.0.实现了物理内存&交换空间的检测,RPM包的自动安装(需配置Yum或者挂载光盘,如果你复制了所有需要的RPM包到某个目录,也OK.),用户&用户组的创建,软件环境变量的配置,系统内核参数配置等功能.脚本执行成功后,即可将Oracle安装包解压然后runInstaller开启图形化安装了.
# 脚本已在Red Hat Enterprise Linux 5.4 64bit上测试通过(Oracle 10g/Oracle11g).原则上适用于RHEL 5和RHEL 6.
# 欢迎提出改进意见.
# 脚本可通过附件下载
#!/bin/bash
# Version 1.0
# AUTHOR: Xin23
#1.Oracle Version and System
GetOracleVersion() {
read -p "Which Version of Oracle You Will Install? [11|10]?
" VERSION
}
GetOracleVersion
SetVersion() {
if
[ $VERSION -eq 11 ]
then echo 'Oracle Version is 11!
'
elif [ $VERSION -eq 10 ]
then echo 'Oracle Version is 10!
'
else
echo 'Please Retype The Version of Oracle You Will Install!
'
GetOracleVersion
SetVersion
fi
}
SetVersion
MEMORY=$(cat /proc/meminfo | grep MemTotal | awk '{print $2}')
SWAP=$(cat /proc/meminfo | grep SwapTotal | awk '{print $2}')
MEMORY_REQ=1048576
if [ $MEMORY -lt $MEMORY_REQ ]
then echo 'Physical Memory is too small! '
exit 1
else
echo 'Physical Memory Check OK! '
fi
if [ $VERSION -eq 10 ]
then
if [ $MEMORY -lt 2097152 ]
then if [ $SWAP -lt $(echo "$MEMORY*3/2"|bc) ]
then echo 'Swap is too small! '
exit 2
else
echo 'Swap Check OK! '
fi
elif [ $MEMORY -gt 2097152 ] || [ $MEMORY -lt 8388608 ]
then if [ $SWAP -lt $MEMORY ]
then echo 'Swap is too small! '
exit 2
else
echo 'Swap Check OK! '
fi
elif [ $MEMORY -gt 8388608 ]
then if [ $SWAP -lt $(echo "$MEMORY*3/4"|bc) ]
then echo 'Swap is too small! '
exit 2
else
echo 'Swap Check OK! '
fi
fi
elif [ $VERSION -eq 11 ]
then
if
[ $MEMORY -lt 2097152 ]
then if [ $SWAP -lt $(echo "$MEMORY*3/2"|bc) ]
then echo 'Swap is too small! '
exit 2
else
echo 'Swap Check OK! '
fi
elif [ $MEMORY -gt 2097152 ] || [ $MEMORY -lt 16777216 ]
then if [ $SWAP -lt $MEMORY ]
then echo 'Swap is too small! '
exit 2
else
echo 'Swap Check OK! '
fi
elif [ $MEMORY -gt 16777216 ]
then if [ $SWAP -lt 16777216 ]
then echo 'Swap is too small! '
exit 2
else
echo 'Swap Check OK! '
fi
fi
fi
echo 'Oracle Version and System hardware has been checked! '
#2.Software
Rpm() {
rpm -ivh compat-libstdc++*
rpm -ivh compat-libstdc++*
rpm -ivh elfutils-libelf*i386.rpm
rpm -ivh elfutils-libelf*x86_64.rpm
rpm -ivh elfutils-libelf-devel-static*x86_64.rpm elfutils-libelf-devel*x86_64.rpm
rpm -ivh elfutils-libelf-devel-static*i386.rpm elfutils-libelf-devel*i386.rpm
rpm -ivh libaio-devel*
rpm -ivh sysstat*
rpm -ivh unixODBC-[[:digit:]]*
rpm -ivh unixODBC-devel*
rpm -ivh kernel-headers*
rpm -ivh glibc-headers*
rpm -ivh glibc-devel*
rpm -ivh libgomp*
rpm -ivh libstdc++-devel*x86_64.rpm
rpm -ivh libstdc++-devel*i386.rpm
rpm -ivh gcc-[[:digit:]]*
rpm -ivh gcc-c++*
rpm -ivh libXp-[[:digit:]]*
}
Yum() {
yum -y install compat-libstdc++
yum -y install elfutils-libelf-devel-static
yum -y install elfutils-libelf-devel
yum -y install libaio-devel
yum -y install sysstat
yum -y install unixODBC
yum -y install unixODBC-devel
yum -y install kernel-headers
yum -y install glibc-headers
yum -y install glibc-devel
yum -y install libgomp
yum -y install gcc
yum -y install gcc-c++
yum -y install libstdc++-devel
yum -y install libXp
}
GetYum() {
read -p "Have you config the yum? [y|n] " YUM
}
GetYum
RetroYum() {
if [ $YUM = y ]
then Yum
elif [ $YUM = n ]
then read -p "Please input rpm package's location: " MEDIA_DIR
cd $MEDIA_DIR
Rpm
else
GetYum
RetroYum
fi
}
RetroYum
echo 'Necessary RPM Package has been installed! '
#3.User and Groups
groupadd oinstall
groupadd dba
useradd -g oinstall -G dba oracle
mkdir -p /u01/app/oracle;chown -R oracle:oinstall /u01
read -p "Please input password for user oracle: " PASSWORD
echo "$PASSWORD" | passwd --stdin oracle
echo 'User and Group has been Created! '
#4.Environment
read -p "Please input ORACLE SID: " SID
su -c "echo 'export ORACLE_BASE=/u01/app/oracle' >> ~/.bash_profile" oracle
su -c "echo 'export ORACLE_SID=$SID' >> ~/.bash_profile" oracle
export ORACLE_BASE=/u01/app/oracle
if [ $VERSION = 11 ]
then su -c 'echo "export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1" >> ~/.bash_profile' oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0/dbhome_1
elif [ $VERSION = 10 ]
then su -c 'echo "export ORACLE_HOME=$ORACLE_BASE/product/10.2.0/db_1" >> ~/.bash_profile' oracle
export ORACLE_HOME=$ORACLE_BASE/product/10.2.0/db_1
else
exit 3
fi
su -c 'echo "export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin" >> ~/.bash_profile' oracle
echo 'Software Enviroment has been finished! '
#5.Operate System and Kernel Parameters
read -p "Please input your ip address: " IP_ADDRESS
echo "$IP_ADDRESS $(hostname)" >> /etc/hosts
echo 'fs.aio-max-nr = 1048576' >> /etc/sysctl.conf
echo 'fs.file-max = 6815744' >> /etc/sysctl.conf
echo 'kernel.shmmni = 4096' >> /etc/sysctl.conf
echo 'kernel.sem = 250 32000 100 128' >> /etc/sysctl.conf
echo 'net.core.rmem_default = 262144' >> /etc/sysctl.conf
echo 'net.core.rmem_max = 4194304' >> /etc/sysctl.conf
echo 'net.core.wmem_default = 262144' >> /etc/sysctl.conf
echo 'net.core.wmem_max = 1048586' >> /etc/sysctl.conf
if [ $VERSION = 11 ]
then echo 'net.ipv4.ip_local_port_range = 9000 65500' >> /etc/sysctl.conf
elif [ $VERSION = 10 ]
then echo 'net.ipv4.ip_local_port_range = 1024 65000' >> /etc/sysctl.conf
fi
sysctl -p
echo 'oracle soft nproc 2047' >> /etc/security/limits.conf
echo 'oracle hard nproc 16384' >> /etc/security/limits.conf
echo 'oracle soft nofile 1024' >> /etc/security/limits.conf
echo 'oracle hard nofile 65536' >> /etc/security/limits.conf
echo 'oracle soft stack 10240' >> /etc/security/limits.conf
echo 'Operate System and Kernel Parameter has been finished! '
echo 'Now You Can Run runInstaller to start Installation of Oracle! '
THE END
本文出自 “Xin23的流水账” 博客,香港空间,谢绝转载!
,香港虚拟主机,香港服务器
热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

MySQL在Web应用中的主要作用是存储和管理数据。1.MySQL高效处理用户信息、产品目录和交易记录等数据。2.通过SQL查询,开发者能从数据库提取信息生成动态内容。3.MySQL基于客户端-服务器模型工作,确保查询速度可接受。

InnoDB使用redologs和undologs确保数据一致性和可靠性。1.redologs记录数据页修改,确保崩溃恢复和事务持久性。2.undologs记录数据原始值,支持事务回滚和MVCC。

MySQL与其他编程语言相比,主要用于存储和管理数据,而其他语言如Python、Java、C 则用于逻辑处理和应用开发。 MySQL以其高性能、可扩展性和跨平台支持着称,适合数据管理需求,而其他语言在各自领域如数据分析、企业应用和系统编程中各有优势。

MySQL索引基数对查询性能有显着影响:1.高基数索引能更有效地缩小数据范围,提高查询效率;2.低基数索引可能导致全表扫描,降低查询性能;3.在联合索引中,应将高基数列放在前面以优化查询。

MySQL的基本操作包括创建数据库、表格,及使用SQL进行数据的CRUD操作。1.创建数据库:CREATEDATABASEmy_first_db;2.创建表格:CREATETABLEbooks(idINTAUTO_INCREMENTPRIMARYKEY,titleVARCHAR(100)NOTNULL,authorVARCHAR(100)NOTNULL,published_yearINT);3.插入数据:INSERTINTObooks(title,author,published_year)VA

MySQL适合Web应用和内容管理系统,因其开源、高性能和易用性而受欢迎。1)与PostgreSQL相比,MySQL在简单查询和高并发读操作上表现更好。2)相较Oracle,MySQL因开源和低成本更受中小企业青睐。3)对比MicrosoftSQLServer,MySQL更适合跨平台应用。4)与MongoDB不同,MySQL更适用于结构化数据和事务处理。

InnoDBBufferPool通过缓存数据和索引页来减少磁盘I/O,提升数据库性能。其工作原理包括:1.数据读取:从BufferPool中读取数据;2.数据写入:修改数据后写入BufferPool并定期刷新到磁盘;3.缓存管理:使用LRU算法管理缓存页;4.预读机制:提前加载相邻数据页。通过调整BufferPool大小和使用多个实例,可以优化数据库性能。

MySQL通过表结构和SQL查询高效管理结构化数据,并通过外键实现表间关系。1.创建表时定义数据格式和类型。2.使用外键建立表间关系。3.通过索引和查询优化提高性能。4.定期备份和监控数据库确保数据安全和性能优化。
