Oracle Linux 7.8 静默安装 Oracle 11g R2 单机 ASM 详细教程

Oracle Linux 7.8 静默安装 Oracle 11g R2 单机 ASM 笔记


一、系统环境准备
  1. 操作系统要求

    • Oracle Linux 7.8 x86_64(内核:3.10.0-1127.el7.x86_64)
    • 内存:≥ 4GB(推荐 8GB)
    • 交换空间:≥ 8GB
    • 磁盘空间:
      • /tmp ≥ 1GB
      • Grid 安装目录:≥ 10GB
      • Oracle 安装目录:≥ 10GB
      • ASM 磁盘:≥ 20GB(推荐 3 块磁盘)
  2. 配置主机名和解析

    bash 复制代码
    hostnamectl set-hostname ol7-ora11g
    echo "192.168.1.100 ol7-ora11g" >> /etc/hosts
  3. 禁用 SELinux 和防火墙

    bash 复制代码
    setenforce 0
    sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
    systemctl stop firewalld
    systemctl disable firewalld
  4. 安装依赖包

    bash 复制代码
    yum install -y binutils compat-libcap1 compat-libstdc++-33 gcc gcc-c++ glibc glibc-devel \
    ksh libaio libaio-devel libgcc libstdc++ libstdc++-devel libXi libXtst make sysstat \
    unixODBC unixODBC-devel elfutils-libelf-devel

二、创建用户和组
bash 复制代码
groupadd -g 54321 oinstall
groupadd -g 54322 dba
groupadd -g 54323 oper
groupadd -g 54324 asmadmin
groupadd -g 54325 asmdba
groupadd -g 54326 asmoper

useradd -u 54321 -g oinstall -G dba,asmdba,oper oracle
useradd -u 54322 -g oinstall -G asmadmin,asmdba,asmoper,dba grid

echo "oracle:oracle" | chpasswd
echo "grid:grid" | chpasswd

三、内核参数优化

编辑 /etc/sysctl.conf

conf 复制代码
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 2147483648
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

应用配置:

bash 复制代码
sysctl -p

四、资源限制配置

编辑 /etc/security/limits.conf

conf 复制代码
oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536
oracle soft stack 10240
oracle hard stack 32768

grid soft nproc 2047
grid hard nproc 16384
grid soft nofile 1024
grid hard nofile 65536
grid soft stack 10240
grid hard stack 32768

五、禁用透明大页(THP)
  1. 编辑 /etc/default/grub

    conf 复制代码
    GRUB_CMDLINE_LINUX="... transparent_hugepage=never"
  2. 更新 GRUB:

    bash 复制代码
    grub2-mkconfig -o /boot/grub2/grub.cfg
    reboot
  3. 验证:

    bash 复制代码
    cat /sys/kernel/mm/transparent_hugepage/enabled
    # 输出:[never] ...

六、配置 ASM 磁盘
  1. 准备磁盘(示例:/dev/sdb, /dev/sdc)

    bash 复制代码
    fdisk /dev/sdb  # 创建分区(n → p → 1 → 回车 → t → 8e → w)
    fdisk /dev/sdc  # 同上
  2. 配置 UDEV 规则
    创建 /etc/udev/rules.d/99-oracle-asm.rules

    rules 复制代码
    KERNEL=="sdb1", OWNER="grid", GROUP="asmadmin", MODE="0660"
    KERNEL=="sdc1", OWNER="grid", GROUP="asmadmin", MODE="0660"

    生效配置:

    bash 复制代码
    udevadm control --reload-rules
    udevadm trigger

七、目录结构规划
bash 复制代码
mkdir -p /u01/app/grid
mkdir -p /u01/app/oracle
mkdir -p /u01/app/oraInventory
chown -R grid:oinstall /u01/app/grid /u01/app/oraInventory
chown -R oracle:oinstall /u01/app/oracle
chmod -R 775 /u01/app

八、上传并解压安装包
  1. 上传文件到 /opt

    • linux.x64_11gR2_grid.zip
    • linux.x64_11gR2_database_*.zip
  2. 解压文件

    bash 复制代码
    unzip linux.x64_11gR2_grid.zip -d /opt/grid
    unzip linux.x64_11gR2_database_1of2.zip -d /opt/database
    unzip linux.x64_11gR2_database_2of2.zip -d /opt/database
    chown -R grid:oinstall /opt/grid
    chown -R oracle:oinstall /opt/database

九、配置响应文件
  1. Grid 响应文件 (/opt/grid/grid.rsp)

    properties 复制代码
    oracle.install.responseFileVersion=/oracle/install/rspfmt_gridinstall_response_schema_v11_2_0
    INVENTORY_LOCATION=/u01/app/oraInventory
    SELECTED_LANGUAGES=en
    oracle.install.option=HA_CONFIG
    ORACLE_BASE=/u01/app/grid
    ORACLE_HOME=/u01/app/11.2.0/grid
    oracle.install.asm.OSDBA=asmdba
    oracle.install.asm.OSOPER=asmoper
    oracle.install.asm.OSASM=asmadmin
    oracle.install.crs.config.ClusterType=STANDALONE
    oracle.install.asm.SYSASMPassword=Oracle123
    oracle.install.asm.diskGroup.name=DATA
    oracle.install.asm.diskGroup.redundancy=EXTERNAL
    oracle.install.asm.diskGroup.AUSize=1
    oracle.install.asm.diskGroup.disks=/dev/sdb1,/dev/sdc1
    oracle.install.asm.diskGroup.diskDiscoveryString=/dev/sd*
    oracle.install.asm.monitorPassword=Oracle123
  2. DB 响应文件 (/opt/database/db.rsp)

    properties 复制代码
    oracle.install.responseFileVersion=/oracle/install/rspfmt_dbinstall_response_schema_v11_2_0
    oracle.install.option=INSTALL_DB_SWONLY
    UNIX_GROUP_NAME=oinstall
    INVENTORY_LOCATION=/u01/app/oraInventory
    SELECTED_LANGUAGES=en
    ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1
    ORACLE_BASE=/u01/app/oracle
    oracle.install.db.InstallEdition=EE
    oracle.install.db.DBA_GROUP=dba
    oracle.install.db.OPER_GROUP=oper
    DECLINE_SECURITY_UPDATES=true

十、静默安装 Grid Infrastructure
  1. 以 grid 用户运行

    bash 复制代码
    su - grid
    cd /opt/grid
    ./runInstaller -silent -responseFile /opt/grid/grid.rsp -ignorePrereq
  2. 执行 root 脚本

    bash 复制代码
    /u01/app/oraInventory/orainstRoot.sh
    /u01/app/11.2.0/grid/root.sh
  3. 验证 ASM 实例

    bash 复制代码
    export ORACLE_SID=+ASM
    sqlplus / as sysasm
    SQL> SELECT name, state FROM v$asm_diskgroup;

十一、静默安装 Oracle 数据库软件
  1. 以 oracle 用户运行

    bash 复制代码
    su - oracle
    cd /opt/database
    ./runInstaller -silent -responseFile /opt/database/db.rsp -ignorePrereq
  2. 执行 root 脚本

    bash 复制代码
    /u01/app/oracle/product/11.2.0/db_1/root.sh

十二、创建数据库(使用 DBCA)
  1. 准备 DBCA 响应文件 (/opt/database/dbca.rsp)

    properties 复制代码
    responseFileVersion=/oracle/assistants/rspfmt_dbca_response_schema_v11_2_0
    gdbName=orcl
    sid=orcl
    templateName=General_Purpose.dbc
    sysPassword=Oracle123
    systemPassword=Oracle123
    characterSet=AL32UTF8
    memoryPercentage=40
    databaseType=MULTIPURPOSE
    storageType=ASM
    diskGroupName=DATA
    recoveryGroupName=DATA
  2. 静默创建数据库

    bash 复制代码
    dbca -silent -responseFile /opt/database/dbca.rsp
  3. 验证数据库

    bash 复制代码
    sqlplus / as sysdba
    SQL> SELECT name, open_mode FROM v$database;

十三、配置环境变量
  1. grid 用户 (~grid/.bash_profile)

    bash 复制代码
    export ORACLE_HOME=/u01/app/11.2.0/grid
    export ORACLE_SID=+ASM
    export PATH=$PATH:$ORACLE_HOME/bin
  2. oracle 用户 (~oracle/.bash_profile)

    bash 复制代码
    export ORACLE_HOME=/u01/app/oracle/product/11.2.0/db_1
    export ORACLE_SID=orcl
    export PATH=$PATH:$ORACLE_HOME/bin

十四、验证安装
bash 复制代码
# 检查 ASM 实例
crsctl check has
sqlplus / as sysasm
SELECT * FROM v$asm_diskgroup;

# 检查数据库
lsnrctl status
sqlplus / as sysdba
SELECT * FROM v$version;

常见问题解决
  1. 磁盘权限问题

    bash 复制代码
    chown grid:asmadmin /dev/sd[b-c]1
  2. ORA-00845 错误
    确保 /dev/shm 大小 ≥ 内存设置:

    bash 复制代码
    mount -t tmpfs shmfs -o size=4g /dev/shm
  3. 安装日志路径

    • Grid: /u01/app/oraInventory/logs/installActions_*.log
    • DB: /u01/app/oracle/oraInventory/logs/installActions_*.log
相关推荐
全栈测试笔记1 天前
异步函数与异步生成器
linux·服务器·前端·数据库·python
Lee_SmallNorth1 天前
变态需求之【角色不同访问数据库的用户不同】
java·开发语言·数据库
李慕婉学姐1 天前
Springboot连锁火锅管理及预测系统sh5s1gn1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
dishugj1 天前
【oracle】19c集群巡检问题
数据库·oracle
知识分享小能手1 天前
Oracle 19c入门学习教程,从入门到精通,Oracle 其他数据对象 —— 语法详解与综合实践(11)
数据库·学习·oracle
木风小助理1 天前
JavaStreamAPI的性能审视,优雅语法背后的隐形成本与优化实践
java·前端·数据库
Knight_AL1 天前
MySQL InnoDB 锁机制深度解析:行锁、表锁、间隙锁、临键锁(Next-Key Lock)
数据库·mysql
良策金宝AI1 天前
工程设计企业AI试用落地路径:从效率验证到知识沉淀
数据库·人工智能·知识图谱·ai助手·工程设计
panzer_maus1 天前
Redis的简单介绍(2)-处理过期Key的策略
数据库·redis·缓存
仗剑恬雅人1 天前
LINUX数据库高频常用命令
linux·运维·服务器·数据库·ssh·运维开发