Centos7静默安装Oracle11g并设置开机自启「终于解决」

Centos7静默安装Oracle11g并设置开机自启「终于解决」这里记录一下安装的过程用于备忘。 执行这个命令,会给出安装oracle11g所缺少的依赖。一般来说在centos7中都能通过: 这个方式来进行安装。 不过由于我这里安装时处于内网环境,同时系统也是由公安局自行安装在某地的虚拟机上,所以我通过阿里的镜像站进行了所有依赖包的下载,就…

之前由于工作需要,在某县公安局安装Oracle数据库,由于公安局的内网环境无法使用访问互联网,所以参考了某位大佬的文章进行了安装:

静默安装Oracle11G

这里记录一下安装的过程用于备忘。

1.环境准备

操作系统:Centos7.6 64位
Oracle11g压缩包:linux.x64_11gR2_database_1of2.zip、linux.x64_11gR2_database_2of2.zip (下载链接:pan.baidu.com/s/1sNEu2XQr… 提取码:5m9r)

2.检测依赖

运行命令

rpm -q binutils compat-libstdc++-33 elfutils-libelf elfutils-libelf-devel gcc gcc-c++ glibc glibc-common glibc-devel glibc-headers kernel-headers ksh libaio  libaio-devel libgcc libgomp libstdc++ libstdc++-devel make numactl-devel sysstat unixODBC unixODBC-devel

执行这个命令,会给出安装oracle11g所缺少的依赖。一般来说在centos7中都能通过:

yum -y install xxx(缺少的依赖名)

这个方式来进行安装。
不过由于我这里安装时处于内网环境,同时系统也是由公安局自行安装在某地的虚拟机上,所以我通过阿里的镜像站进行了所有依赖包的下载,就是缺什么依赖就在这里搜什么名称,然后将rpm文件下载下来再一起打包传到服务器上解压安装。

Centos7静默安装Oracle11g并设置开机自启「终于解决」

下载rpm包,通过命令:

rpm -ivh xxx.rpm

来进行安装

3.安装前的准备

创建目录修改属组和权限

groupadd oinstall
groupadd dba
useradd -g oinstall -G dba oracle
passwd oracle 
mkdir -p /u01/app/oracle/product/11.2.0/db_1
mkdir -p /u01/app/oracle/oradata
mkdir -p /u01/app/oracle/inventory
mkdir -p /u01/app/oracle/fast_recovery_area
chown -R oracle.oinstall /u01/app/oracle
chmod -R 755 /u01/app/oracle

语句的作用依次为:前面创建的目录主要作用为 Oracle家目录、数据文件存放位置,安装日志存放位置,快速恢复区 修改属组,修改权限

服务器配置修改

#修改主机名
vim /etc/hosts
#host文件中添加
127.0.0.1 oracledb
#开放端口1521
firewall-cmd --zone=public --add-port=1521/tcp --permanent #--permanent参数使设置永久生效
firewall-cmd --reload #重新加载防火墙
firewall-cmd --list-ports --zone=public  #查看是否开放
#关闭selinux
vim /etc/sysconfig/selinux
#修改selinux中的值
SELINUX=disabled
#修改后重启服务器,或执行以下命令皆可生效:
setenforce 0           
#修改内核参数
vim /etc/sysctl.conf
#####添加以下内容
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 1073741824
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
#####其中kernel.shmmax = 1073741824为本机物理内存(2G)的一半,单位为byte。
sysctl -p #使修改生效
#修改用户限制文件
vim /etc/security/limits.conf
####添加以下内容
oracle    soft    nproc    2047
oracle    hard    nproc    16384
oracle    soft    nofile    1024
oracle    hard    nofile    65536
oracle    soft    stack    10240
####
#修改/etc/pam.d/login文件
vim /etc/pam.d/login
#添加以下内容
session required  /lib64/security/pam_limits.so
session required   pam_limits.so

这里limits.conf配置的比较随意,我找了一篇limits.conf的参考

#配置oracle用户的环境变量
su - oracle
vim ~/.bash_profile
###添加
ORACLE_BASE=/u01/app/oracle
ORACLE_HOME=$ORACLE_BASE/product/11.2.0/db_1
ORACLE_SID=orcl
PATH=$PATH:$ORACLE_HOME/bin
export ORACLE_BASE ORACLE_HOME ORACLE_SID PATH
###
#使文件中的配置立即生效
. ~/.bash_profile

4.正式安装

#切换到root用户
su root
cd /tmp/
mkdir oracle
cd oracle
#通过rz命令上传linux.x64_11gR2_database的两个压缩包
#解压
unzip linux.x64_11gR2_database_1of2.zip & unzip linux.x64_11gR2_database_2of2.zip 

解压完成后

#编辑静默安装响应文件
cd /tmp/oracle/database/response/
vim db_install.rsp
###修改以下内容
oracle.install.option=INSTALL_DB_SWONLY
ORACLE_HOSTNAME=oracle         
UNIX_GROUP_NAME=oinstall
INVENTORY_LOCATION=/u01/app/oracle/inventory
SELECTED_LANGUAGES=en,zh_CN
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=dba
DECLINE_SECURITY_UPDATES=true
###
#开始安装软件
chown -R oracle:oinstall /tmp/oracle/
su - oracle
cd /tmp/oracle/database/
./runInstaller -silent -responseFile /tmp/oracle/database/response/db_install.rsp -ignorePrereq

看到如下打印,则已经开始安装

Centos7静默安装Oracle11g并设置开机自启「终于解决」

此时可以另外开一个窗口查看日志文件

Centos7静默安装Oracle11g并设置开机自启「终于解决」

经过一段时间日志输出,看见原来的窗口出现如下文字

Centos7静默安装Oracle11g并设置开机自启「终于解决」

切换到root用户执行上述的脚本

exit
/u01/app/oracle/inventory/orainstRoot.sh
/u01/app/oracle/product/11.2.0/db_1/root.sh

静默方式配置监听:

su - oracle
netca /silent /responseFile /tmp/oracle/database/response/netca.rsp

出现如下文字,则监听启动完成:

Centos7静默安装Oracle11g并设置开机自启「终于解决」

查看端口1521是否能被监听:

netstat -tnulp | grep 1521

Centos7静默安装Oracle11g并设置开机自启「终于解决」

监听的启动和关闭命令

lsnrctl start 
lsnrctl stop

静默方式建库:

cd /tmp/oracle/database/response/
cp dbca.rsp dbca.rsp.bak
vim dbca.rsp
###设置以下参数:
GDBNAME= "orcl"
SID =" orcl"
SYSPASSWORD= "oracle"
SYSTEMPASSWORD= "oracle"
SYSMANPASSWORD= "oracle"
DBSNMPPASSWORD= "oracle"
DATAFILEDESTINATION=/u01/app/oracle/oradata
RECOVERYAREADESTINATION=/u01/app/oracle/fast_recovery_area
CHARACTERSET= "ZHS16GBK" #这里不设置应该默认是UTF-8
TOTALMEMORY= "1638"
###其中TOTALMEMORY ="1638" 为1638MB,物理内存2G*80%。
#执行命令,进度达到100%则创建完成
dbca -silent -responseFile /tmp/oracle/database/response/dbca.rsp
#测试是否可用
sqlplus / as sysdba
SQL> select 1 from dual;
 1 ----------
 1 SQL> exit; 

安装完毕

启动/关闭实例

sqlplus / as sysdba
SQL> startup; #启动
SQL> shutdown; #关闭

5.设置开机自启

su - oracle
#修改该路径下的dbstart dbshut脚本,将两个脚本中的ORACLE_HOME_LISTNER=$1,修改为ORACLE_HOME_LISTNER=$ORACLE_HOME
cd /u01/app/oracle/product/11.2.0/db_1/bin/
#修改完成后
exit
#修改配置
vim /etc/oratab
orcl:/u01/app/oracle/product/11.2.0/db_1:X改为orcl:/u01/app/oracle/product/11.2.0/db_1:Y
#修改rc.local文件
chmod 755 /etc/rc.d/rc.local
vim /etc/rc.d/rc.local
#在rc.local中添加:
su oracle -lc "/u01/app/oracle/product/11.2.0/db_1/bin/lsnrctl start"  #加上引号才能把空格后的start也当作命令的一部分
su oracle -lc /u01/app/oracle/product/11.2.0/db_1/bin/dbstart

添加完成后即可

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/13500.html

(0)

相关推荐

  • 用Python编写Pygame游戏中的交互按钮

    用Python编写Pygame游戏中的交互按钮Pygame是一种由Python开发的游戏开发库,它提供了许多方便的游戏开发接口和工具。它是一种很好的选择,可以帮助我们编写桌面游戏。

    2024-04-06
    83
  • Python中根号的表示方法

    Python中根号的表示方法根号(square root)是高中数学中常用的符号,表示一个数的平方根。在Python中,我们同样可以通过代码实现这个数学运算。需要注意的是,Python并没有提供原生的根号函数,而是通过一些库函数来实现。

    2024-09-21
    15
  • flink datasource_chatgpt python

    flink datasource_chatgpt pythonApache Flink Apache Flink 是一个兼顾高吞吐、低延迟、高性能的分布式处理框架。在实时计算崛起的今天,Flink正在飞速发展。由于性能的优势和兼顾批处理,流处理的特性,Flink

    2022-12-30
    174
  • Python饼图实现:统计数据可视化

    Python饼图实现:统计数据可视化随着数据的快速增长,数据可视化也成为了数据分析的重要手段之一。Python作为一种强大的编程语言,在数据分析领域也有着十分广泛的应用。饼图是一种常见的数据可视化图表,通过饼图可以直观地展示数据集的组成部分占比,也方便读者对数据进行理解和分析。

    2024-05-14
    73
  • oracle analyze table_MySQL source

    oracle analyze table_MySQL source原文地址:https://mysqlserverteam.com/mysql-explain-analyze/ MySQL 8.0.18刚刚发布(译者注:原文发表时间为October 17, 2019

    2023-03-06
    148
  • 珍藏的数据库SQL基础练习题答案

    珍藏的数据库SQL基础练习题答案一,基本表的定义与删除. 题1: 用SQL语句创建如下三张表:学生(Student),课程表(Course),和学生选课表(SC),这三张表的结构如表1-1到表1-3所示。 表1-1 Student表

    2023-03-03
    143
  • centos7.2 数据库定时备份 crond实现(以kingbase7为例)

    centos7.2 数据库定时备份 crond实现(以kingbase7为例)项目上线时,经常需要定时对数据库进行备份,以应对不确定的环境和未知的问题。整理如下: crond是什么? crond 和crontab是不可分割的。crontab是一个命令,常见于Unix和类Uni…

    2022-12-16
    171
  • sqlserver分区表实战_sql删除分区表的分区数据

    sqlserver分区表实战_sql删除分区表的分区数据一、分区表概念 1.1、什么是分区表? 分区表是在SQL Server 2005之后的版本引入的特性,这个特性允许把逻辑上的一个表在物理上分为很多部分。换句话说,分区表从物理上看是将一个大表分成几个小

    2023-04-23
    150

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注